다음을 통해 공유


IMemInputPin::Receive 메서드(strmif.h)

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

메서드는 Receive 스트림의 다음 미디어 샘플을 받습니다.

구문

HRESULT Receive(
  [in] IMediaSample *pSample
);

매개 변수

[in] pSample

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

반환 값

HRESULT 값을 반환합니다. 가능한 값에는 다음 표에 표시된 값이 포함됩니다.

반환 코드 Description
S_OK
성공.
S_FALSE
샘플이 거부되었습니다.
E_POINTER
NULL 포인터 인수입니다.
VFW_E_INVALIDMEDIATYPE
미디어 유형이 잘못되었습니다.
VFW_E_RUNTIME_ERROR
런타임 오류가 발생했습니다.
VFW_E_WRONG_STATE
핀이 중지되었습니다.

설명

이 메서드는 동기적이며 차단될 수 있습니다. 핀은 다음 중 하나를 수행합니다.

  • 샘플을 거부합니다.
  • 즉시 를 반환하고 작업자 스레드에서 샘플을 처리합니다.
  • 반환하기 전에 샘플을 처리합니다.
마지막 경우 메서드가 무기한 차단될 수 있습니다. 이 경우 IMemInputPin::ReceiveCanBlock 메서드는 S_OK 반환합니다.

핀이 작업자 스레드를 사용하여 샘플을 처리하는 경우 샘플에 대한 참조 횟수를 보유합니다. 어떤 경우든 출력 핀은 이 샘플을 직접 다시 사용할 수 없습니다. 새 샘플을 가져오려면 IMemAllocator::GetBuffer 메서드를 호출해야 합니다.

이 메서드가 S_FALSE 또는 오류 코드를 반환하는 경우 그래프가 플러시 작업을 중지하거나 완료할 때까지 업스트림 필터가 샘플 전송을 중지해야 합니다. S_FALSE 반환 값의 일반적인 이유는 다음과 같습니다.

  • 다운스트림 핀이 플러시되고 있습니다. 즉, BeginFlush 호출을 수신했으며 아직 EndFlush 호출을 받지 못했습니다.
  • 다운스트림 필터가 스트림의 끝을 검색했습니다. (Stream 종료 알림을 참조하세요.)

요구 사항

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

추가 정보

오류 및 성공 코드

IMemInputPin 인터페이스