다음을 통해 공유


IBaseFilter::JoinFilterGraph 메서드(strmif.h)

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

메서드는 JoinFilterGraph 필터 그래프가 조인되었거나 필터 그래프를 떠났다는 것을 필터에 알 수 있습니다.

구문

HRESULT JoinFilterGraph(
  [in] IFilterGraph *pGraph,
  [in] LPCWSTR      pName
);

매개 변수

[in] pGraph

필터 그래프 관리자의 IFilterGraph 인터페이스에 대한 포인터이거나 필터가 그래프를 벗어나는 경우 NULL 입니다.

[in] pName

필터의 이름을 지정하는 와이드 문자열에 대한 포인터입니다.

반환 값

성공하면 S_OK 반환하거나 오류의 원인을 나타내는 HRESULT 값을 반환합니다.

설명

필터 그래프 관리자가 필터 그래프에 필터를 추가하면 자체에 대한 포인터를 사용하여 이 메서드를 호출합니다. pName 매개 변수를 통해 필터의 이 instance 이름을 할당합니다. 이름은 IBaseFilter::QueryFilterInfo 메서드를 호출하여 검색할 수 있습니다.

필터 그래프 관리자가 그래프에서 필터를 제거하면 NULL 포인터를 사용하여 이 메서드를 호출합니다.

애플리케이션은 이 메서드를 호출해서는 안 됩니다. 그래프에 필터를 추가하려면 필터 그래프 관리자에서 IFilterGraph::AddFilter 메서드를 호출합니다.

필터 개발자: 필터는 IFilterGraph 인터페이스 포인터를 저장하고 다른 Filter Graph Manager 인터페이스에 대해 쿼리할 수 있습니다. 그러나 필터 그래프 관리자에 대한 참조 수를 보유해서는 안 됩니다. 이렇게 하면 필터 그래프 관리자가 필터에 대한 참조 수를 유지하므로 순환 참조 수가 생성됩니다. 순환 참조 횟수는 인터페이스가 제대로 해제되지 않도록 하므로 교착 상태가 발생할 수 있습니다. IFilterGraph 인터페이스는 Filter Graph Manager가 NULL 값으로 이 메서드를 다시 호출할 때까지 유효합니다. 이 메서드의 구현은 CBaseFilter::JoinFilterGraph 메서드를 참조하세요.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 strmif.h(Dshow.h 포함)
라이브러리 Strmiids.lib

추가 정보

오류 및 성공 코드

IBaseFilter 인터페이스