다음을 통해 공유


CVideoTransformFilter.Receive 메서드

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

메서드는 Receive 미디어 샘플을 수신하고, 처리하고, 출력 샘플을 다운스트림 필터에 전달합니다. 이 메서드는 CTransformFilter::Receive 메서드를 재정의합니다.

구문

HRESULT Receive(
   IMediaSample *pSample
);

매개 변수

pSample

입력 샘플의 IMediaSample 인터페이스에 대한 포인터입니다.

반환 값

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

반환 코드 설명
S_FALSE
업스트림 필터는 샘플 전송을 중지해야 합니다.
S_OK
성공.

설명

이 메서드는 CVideoTransformFilter::ShouldSkipFrame 을 호출하여 이 샘플을 제공해야 하는지 아니면 단순히 삭제해야 하는지를 결정합니다. ShouldSkipFrameFALSE를 반환하는 경우(샘플을 배달해야 함을 나타낸) 메서드는 다음을 수행합니다.

  1. CTransformFilter::InitializeOutputSample을 호출하여 출력 샘플을 준비합니다.
  2. CTransformFilter::Transform을 호출하여 입력 샘플을 처리합니다. 이 메서드는 순수 가상이며 파생 클래스에서 구현되어야 합니다.
  3. CBaseOutputPin::D eliver를 호출하여 출력 샘플을 제공합니다.

또한 이 메서드는 IMediaSample::GetMediaType을 호출하여 입력 또는 출력 샘플에서 형식 변경을 확인합니다. 형식 변경이 있는 경우 메서드는 해당 핀에 연결 형식을 설정합니다. 새 형식을 설정하기 전에 StopStreaming을 호출합니다. 새 형식을 설정한 후 StartStreaming을 호출합니다. 파생 클래스는 이러한 메서드를 사용하여 내부 상태를 업데이트할 수 있습니다. 파생 클래스는 Transform 메서드의 새 형식에 대해 검사 수도 있습니다.

요구 사항

요구 사항
헤더
Vtrans.h(Streams.h 포함)
라이브러리
Strmbase.lib(소매 빌드);
Strmbasd.lib(디버그 빌드)

추가 정보

CVideoTransformFilter 클래스