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 |
---|---|
|
성공. |
|
샘플이 거부되었습니다. |
|
NULL 포인터 인수입니다. |
|
미디어 유형이 잘못되었습니다. |
|
런타임 오류가 발생했습니다. |
|
핀이 중지되었습니다. |
설명
이 메서드는 동기적이며 차단될 수 있습니다. 핀은 다음 중 하나를 수행합니다.
- 샘플을 거부합니다.
- 즉시 를 반환하고 작업자 스레드에서 샘플을 처리합니다.
- 반환하기 전에 샘플을 처리합니다.
핀이 작업자 스레드를 사용하여 샘플을 처리하는 경우 샘플에 대한 참조 횟수를 보유합니다. 어떤 경우든 출력 핀은 이 샘플을 직접 다시 사용할 수 없습니다. 새 샘플을 가져오려면 IMemAllocator::GetBuffer 메서드를 호출해야 합니다.
이 메서드가 S_FALSE 또는 오류 코드를 반환하는 경우 그래프가 플러시 작업을 중지하거나 완료할 때까지 업스트림 필터가 샘플 전송을 중지해야 합니다. S_FALSE 반환 값의 일반적인 이유는 다음과 같습니다.
- 다운스트림 핀이 플러시되고 있습니다. 즉, BeginFlush 호출을 수신했으며 아직 EndFlush 호출을 받지 못했습니다.
- 다운스트림 필터가 스트림의 끝을 검색했습니다. (Stream 종료 알림을 참조하세요.)
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000 Professional[데스크톱 앱만] |
지원되는 최소 서버 | Windows 2000 Server[데스크톱 앱만] |
대상 플랫폼 | Windows |
헤더 | strmif.h(Dshow.h 포함) |
라이브러리 | Strmiids.lib |