IPinFlowControl::Block 메서드(strmif.h)
[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드에서 DirectShow 대신 MediaPlayer, IMFMediaEngine 및 오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]
메서드는 Block
핀에서 데이터 흐름을 차단하거나 차단 해제합니다.
구문
HRESULT Block(
[in] DWORD dwBlockFlags,
[in] HANDLE hEvent
);
매개 변수
[in] dwBlockFlags
핀 차단 또는 차단 해제 여부를 나타내는 플래그입니다. 다음 값 중 하나여야 합니다.
- 0: 핀에서 데이터 흐름 차단을 해제합니다.
- AM_PIN_FLOW_CONTROL_BLOCK: 핀에서 데이터 흐름을 차단합니다.
[in] hEvent
이벤트 개체 또는 NULL에 대한 핸들입니다. 이 매개 변수가 NULL이 아닌 경우 메서드는 비동기이며 즉시 반환됩니다. 작업이 완료되면 이벤트가 신호를 보냅니다. 이 매개 변수가 NULL인 경우 메서드는 동기적이며 핀이 차단될 때까지 완료되지 않습니다. dwBlockFlags가 0이면 이 매개 변수는 NULL이어야 합니다.
반환 값
HRESULT 값을 반환합니다. 가능한 값은 다음과 같습니다.
반환 코드 | 설명 |
---|---|
|
고정이 이미 차단 해제되어 있습니다. |
|
성공. |
|
다른 스레드에서 고정이 이미 차단되었습니다. |
|
호출 스레드에서 고정이 이미 차단되었습니다. |
설명
이 메서드는 동기 또는 비동기일 수 있습니다.
- 비동기적으로 호출하려면 CreateEvent 함수를 사용하여 이벤트 개체를 만듭니다. hEvent 매개 변수에서 이벤트 핸들을 전달합니다. 메서드는 즉시 를 반환하고 작업이 완료되면 이벤트를 신호합니다. WaitForSingleObject와 같은 대기 함수를 호출하여 이벤트를 기다립니다.
- 이 메서드를 동기적으로 호출하려면 hEvent 매개 변수를 NULL로 설정합니다. 메서드는 완료될 때까지 차단합니다. 핀이 샘플을 배달할 준비가 될 때까지 메서드가 완료되지 않을 수 있습니다. 필터가 일시 중지되면 메서드가 무기한 차단될 수 있습니다. 따라서 기본 애플리케이션 스레드에서 이 메서드를 동기적으로 호출해서는 안 됩니다.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows XP [데스크톱 앱만 해당] |
지원되는 최소 서버 | Windows Server 2003 [데스크톱 앱만 해당] |
대상 플랫폼 | Windows |
헤더 | strmif.h(Dshow.h 포함) |
라이브러리 | Strmiids.lib |