IGraphConfig::P ushThroughData 메서드(strmif.h)

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

메서드는 PushThroughData 필터 그래프를 통해 지정된 핀으로 데이터를 푸시합니다.

구문

HRESULT PushThroughData(
  [in] IPin           *pOutputPin,
  [in] IPinConnection *pConnection,
  [in] HANDLE         hEventAbort
);

매개 변수

[in] pOutputPin

필터 그래프에서 출력 핀의 IPin 인터페이스에 대한 포인터입니다.

[in] pConnection

필터 그래프에서 입력 핀의 IPinConnection 인터페이스에 대한 포인터입니다. 이 매개 변수는 NULL일 수 있습니다.

[in] hEventAbort

이벤트에 대한 핸들. 호출자가 데이터 처리 스레드 중 하나에서 호출하는 필터인 경우 이 매개 변수는 필터가 중지된 상태로 전환될 때 신호를 받을 이벤트에 대한 핸들이어야 합니다. 그렇지 않으면 이 매개 변수는 NULL일 수 있습니다. 자세한 내용은 설명 부분을 참조하세요.

반환 값

성공하면 S_OK 반환합니다. 그렇지 않으면 다음 값 중 하나일 수 있는 오류 코드 또는 나열되지 않은 다른 값을 반환합니다.

반환 코드 설명
E_OUTOFMEMORY
필요한 메모리를 할당하지 못했습니다.
VFW_E_NOT_FOUND
후보 입력 핀을 찾을 수 없습니다.
VFW_E_STATE_CHANGED
작업 중에 필터 상태가 변경되었습니다.

설명

이 메서드는 지정된 출력 핀에서 지정된 입력 핀까지 보류 중인 데이터를 푸시합니다. 필요에 따라 입력 핀을 지정하지 않은 상태로 두고 메서드가 필터 그래프에서 가장 적합한 후보를 검색하도록 할 수 있습니다. 데이터를 푸시하는 스레드에서 이 메서드를 호출하지 마세요.

필터가 자체 데이터 처리 스레드 중 하나에서 이 메서드를 호출하면 교착 상태가 발생할 가능성이 있습니다. 메서드는 필터 그래프에 대한 잠금을 가져옵니다. 이 잠금은 필터가 IMediaFilter::Stop에 대한 호출 수신을 중지하지 못하도록 차단할 수 있습니다. 이 상황을 방지하기 위해 메서드는 필터에서 제공하는 이벤트 개체에 대한 핸들을 사용합니다. 필터는 Stop 메서드에 대한 호출을 수신하는 경우 이벤트에 신호를 보내야 합니다.

요구 사항

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

추가 정보

오류 및 성공 코드

IGraphConfig 인터페이스