CBasePin.CheckConnect 方法

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

方法 CheckConnect 會判斷針腳連接是否適合。

語法

virtual HRESULT CheckConnect(
   IPin *pPin
);

參數

pPin

指向另一個針腳的 IPin 介面指標。

傳回值

傳回下表所示的其中一個 HRESULT 值。

傳回碼 描述
S_OK
成功。
VFW_E_INVALID_DIRECTION
針腳方向不相容。

備註

在連接程式開始時,這兩個針腳上都會呼叫這個方法。 連接針腳會從 CBasePin::Connect 方法內呼叫它,而接收針腳會從 CBasePin::ReceiveConnection 方法內呼叫它。

使用這個方法來判斷 pPin 參數指定的針腳是否適合連線。 如果兩個針腳的輸入方向相同 (,或兩個輸出) ,基類會傳回錯誤。 衍生類別可以覆寫這個方法,以驗證針腳中的其他功能。 例如, CBaseOutputPin 類別會查詢其 IMemInputPin 介面的輸入針腳。

如果這個方法失敗,連線就會失敗,而針腳會呼叫 CBasePin::BreakConnect 方法。 使用 BreakConnect 釋放 中 CheckConnect 取得的任何資源。 例如,如果 CheckConnect 呼叫 QueryInterface 方法, BreakConnect 必須釋放 介面。

規格需求

需求
標頭
Amfilter.h (包含 Streams.h)
程式庫
Strmbase.lib (零售組建) ;
Strmbasd.lib (偵錯組建)

另請參閱

CBasePin 類別