다음을 통해 공유


ICaptureGraphBuilder::SetOutputFileName 메서드(strmif.h)

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngineMedia Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]

참고ICaptureGraphBuilder 인터페이스는 더 이상 사용되지 않습니다. 대신 ICaptureGraphBuilder2 를 사용합니다.
 
필터 그래프의 렌더링 섹션을 만들어 지정된 파일 이름으로 디스크에 비트를 저장합니다.

구문

HRESULT SetOutputFileName(
  [in]  const GUID      *pType,
  [in]  LPCOLESTR       lpstrFile,
  [out] IBaseFilter     **ppf,
  [out] IFileSinkFilter **ppSink
);

매개 변수

[in] pType

미디어 하위 형식을 나타내는 GUID 에 대한 포인터입니다. &MEDIASUBTYPE_Avi이어야 합니다.

[in] lpstrFile

출력 파일 이름을 포함하는 와이드 문자열에 대한 포인터입니다.

[out] ppf

멀티플렉서 필터를 나타내는 IBaseFilter 인터페이스에 대한 포인터의 주소입니다. 이 메서드는 IBaseFilter 인터페이스에서 참조 수를 증가시켜 필터를 사용할 때 이 매개 변수에 대해 Release 메서드를 사용하여 참조 수를 감소시켜야 합니다.

[out] ppSink

파일 작성기를 나타내는 IFileSinkFilter 인터페이스에 대한 포인터의 주소입니다. 이 메서드는 IFileSinkFilter 인터페이스에 대한 참조 수를 증가하므로 필터를 사용할 때 Release 를 사용하여 참조 수를 감소시켜야 합니다.

반환 값

HRESULT 값을 반환합니다. 가능한 값은 다음과 같습니다.

반환 코드 설명
E_FAIL
실패.
E_INVALIDARG
인수가 잘못되었습니다. Audio-Video AVI(Interleaved)는 유일하게 지원되는 출력 형식입니다.
E_OUTOFMEMORY
메모리가 부족합니다.
E_POINTER
NULL 포인터 인수입니다.
E_UNEXPECTED
예기치 않은 오류가 발생했습니다.
NOERROR
성공.
S_OK
AVI 멀티플렉서 필터의 인스턴스가 성공적으로 만들어졌습니다.

설명

이 메서드는 멀티플렉서와 파일 작성기를 필터 그래프에 삽입하고 IFileSinkFilter::SetFileName 을 호출하여 출력 파일 이름을 설정합니다.

RenderStream 호출에서 이 메서드에서 반환된 ppf 매개 변수를 pfRenderer 매개 변수로 사용할 수 있습니다.

SetFileName 호출에서 이 메서드의 pSink 매개 변수를 사용하여 로 설정된 ICaptureGraphBuilder::SetOutputFileName파일 이름을 변경할 수 있습니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 참조:_Dshowh
대상 플랫폼 Windows
헤더 strmif.h
DLL Quartz.dll

추가 정보

오류 및 성공 코드

ICaptureGraphBuilder 인터페이스