다음을 통해 공유


CBaseInputPin.ReceiveCanBlock 메서드

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

메서드는 ReceiveCanBlockIMemInputPin::Receive 메서드에 대한 호출이 차단될 수 있는지 여부를 결정합니다. 이 메서드는 IMemInputPin::ReceiveCanBlock 메서드를 구현합니다.

구문

HRESULT ReceiveCanBlock();

매개 변수

이 메서드에는 매개 변수가 없습니다.

반환 값

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

반환 코드 설명
S_FALSE
수신 호출 시 핀이 차단되지 않습니다.
S_OK
수신 호출 시 핀이 차단될 수 있습니다.

설명

Receive 메서드에 대한 호출이 차단되지 않도록 보장되면 S_FALSE 반환합니다. 그렇지 않으면 S_OK 또는 오류 코드를 반환합니다. Receive 메서드가 다운스트림 핀에서 Receive를 호출하면 다운스트림 핀이 차단될 수 있습니다. ReceiveCanBlock 는 해당 요소를 고려해야 합니다.

업스트림 필터는 이 메서드를 사용하여 스레딩 전략을 결정할 수 있습니다. Receive 메서드가 차단될 수 있는 경우 업스트림 필터는 데이터를 버퍼링하는 작업자 스레드를 사용하도록 결정할 수 있습니다. 이 전략의 구현 은 COutputQueue 클래스를 참조하세요.

기본 클래스에서 이 메서드는 다음 중 어느 것이라도 true이면 S_OK 반환합니다.

  • 필터에 출력 핀이 없습니다.
  • 이 필터에 연결된 입력 핀은 차단할 수 있음을 신호합니다.
  • 이 필터에 연결된 입력 핀은 IMemInputPin 인터페이스를 지원하지 않습니다.

요구 사항

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

추가 정보

CBaseInputPin 클래스