共用方式為


IPinFlowControl::Block 方法 (strmif.h)

[與此頁面相關的功能 DirectShow 是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對 Windows 10 和 Windows 11 進行優化。 Microsoft 強烈建議新程式代碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式代碼盡可能重寫為使用新的 API。

方法 Block 會封鎖或解除封鎖釘選的數據流程。

語法

HRESULT Block(
  [in] DWORD  dwBlockFlags,
  [in] HANDLE hEvent
);

參數

[in] dwBlockFlags

指出要封鎖或解除封鎖針腳的旗標。 必須為下列其中一個值:

  • 零:從針腳解除封鎖數據流。
  • AM_PIN_FLOW_CONTROL_BLOCK:封鎖來自針腳的數據流。

[in] hEvent

事件物件的句柄,或 NULL。 如果此參數為非 NULL,則方法為異步,並立即傳回。 作業完成時,事件會發出訊號。 如果此參數為 NULL,則方法為同步,而且在封鎖針腳之前不會完成。 如果 dwBlockFlags 為零,此參數必須是 NULL

傳回值

傳回 HRESULT 值。 可能的值如下。

傳回碼 Description
S_FALSE
Pin 已解除封鎖。
S_OK
成功。
VFW_E_PIN_ALREADY_BLOCKED
釘選已在另一個線程上遭到封鎖。
VFW_E_PIN_ALREADY_BLOCKED_ON_THIS_THREAD
呼叫線程上已封鎖 Pin。

備註

這個方法可以是同步或異步:

  • 若要以異步方式呼叫它,請使用 CreateEvent 函式來建立事件物件。 傳遞 hEvent 參數中的事件句柄。 方法會立即傳回 ,並在作業完成時發出事件訊號。 呼叫 WaitForSingleObject 等等候函式以等候事件。
  • 若要同步呼叫此方法,請將 hEvent 參數設定為 NULL。 方法會封鎖直到完成為止。 方法可能尚未完成,直到針腳準備好提供範例為止。 如果篩選已暫停,方法可能會無限期地封鎖。 因此,您不應該從主要應用程式線程同步呼叫此方法。

規格需求

需求
最低支援的用戶端 Windows XP [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2003 [僅限傳統型應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

動態重新連線

錯誤和成功碼

IPinFlowControl 介面