CBasePin.CheckConnect 方法
[與此頁面相關的功能 DirectShow是舊版功能。 它已被 MediaPlayer、 IMFMediaEngine和 Media Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayer、 IMFMediaEngine 和 音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式碼盡可能重寫為使用新的 API。
方法 CheckConnect
會判斷針腳連接是否適合。
語法
virtual HRESULT CheckConnect(
IPin *pPin
);
參數
-
pPin
-
指向另一個針腳的 IPin 介面指標。
傳回值
傳回下表所示的其中一個 HRESULT 值。
傳回碼 | 描述 |
---|---|
|
成功。 |
|
針腳方向不相容。 |
備註
在連接程式開始時,這兩個針腳上都會呼叫這個方法。 連接針腳會從 CBasePin::Connect 方法內呼叫它,而接收針腳會從 CBasePin::ReceiveConnection 方法內呼叫它。
使用這個方法來判斷 pPin 參數指定的針腳是否適合連線。 如果兩個針腳的輸入方向相同 (,或兩個輸出) ,基類會傳回錯誤。 衍生類別可以覆寫這個方法,以驗證針腳中的其他功能。 例如, CBaseOutputPin 類別會查詢其 IMemInputPin 介面的輸入針腳。
如果這個方法失敗,連線就會失敗,而針腳會呼叫 CBasePin::BreakConnect 方法。 使用 BreakConnect 釋放 中 CheckConnect
取得的任何資源。 例如,如果 CheckConnect
呼叫 QueryInterface 方法, BreakConnect 必須釋放 介面。
規格需求
需求 | 值 |
---|---|
標頭 |
|
程式庫 |
|