IFilterGraph2::AddSourceFilterForMoniker 메서드(strmif.h)
[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine 및 오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]
메서드는 AddSourceFilterForMoniker
IMoniker 포인터에서 원본 필터를 만들고 그래프에 필터를 추가합니다. 예를 들어 비디오 캡처 디바이스와 같은 시스템 디바이스에 대한 모니커를 가져오고 해당 디바이스에 대한 비디오 캡처 필터를 추가할 수 있습니다. (시스템 디바이스 모니커에 대한 자세한 내용은 ICreateDevEnum 인터페이스를 참조하세요.)
구문
HRESULT AddSourceFilterForMoniker(
[in] IMoniker *pMoniker,
[in] IBindCtx *pCtx,
[in] LPCWSTR lpcwstrFilterName,
[out] IBaseFilter **ppFilter
);
매개 변수
[in] pMoniker
IMoniker 인터페이스에 대한 포인터입니다.
[in] pCtx
IBindCtx 바인딩 컨텍스트 인터페이스에 대한 포인터입니다.
[in] lpcwstrFilterName
필터의 이름입니다.
[out] ppFilter
원본 필터의 IBaseFilter 포인터에 대한 포인터를 받습니다. 호출자는 인터페이스를 해제해야 합니다.
반환 값
및 HRESULT 값을 반환합니다. 가능한 값은 다음과 같습니다.
반환 코드 | 설명 |
---|---|
|
성공. |
|
성공; 지정한 이름이 중복되었으므로 Filter Graph Manager에서 이름을 수정했습니다. |
|
실패. |
|
메모리가 부족합니다. |
|
이름이 중복된 필터를 추가하지 못했습니다. |
|
에 대한 원본 필터를 로드할 수 없습니다. |
|
이 파일의 미디어 형식이 인식되지 않습니다. |
설명
필터 그래프 관리자는 필터가 그래프에서 제거되거나 필터 그래프 관리자가 해제될 때까지 필터에 대한 참조 수를 보유합니다.
예제
C++ |
---|
IBaseFilter *pSource = NULL; IMoniker *pMoniker = NULL; |
요구 사항
지원되는 최소 클라이언트 | Windows 2000 Professional[데스크톱 앱만] |
지원되는 최소 서버 | Windows 2000 Server[데스크톱 앱만] |
대상 플랫폼 | Windows |
헤더 | strmif.h(Dshow.h 포함) |
라이브러리 | Strmiids.lib |