CBasePin.ReceiveConnection 方法
[與此頁面相關的功能 DirectShow是舊版功能。 它已被 MediaPlayer、 IMFMediaEngine和 Media Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayer、 IMFMediaEngine 和 音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式碼盡可能重寫為使用新的 API。
方法 ReceiveConnection
接受來自另一個針腳的連接。 這個方法會實作 IPin::ReceiveConnection 方法。
語法
HRESULT ReceiveConnection(
IPin *pConnector,
AM_MEDIA_TYPE *pmt
);
參數
-
pConnector
-
連接針腳的 IPin 介面指標。
-
Pmt
-
指定媒體類型的 AM_MEDIA_TYPE 結構的指標。
傳回值
傳回 HRESULT 值。 可能的值包括下表中的值。
傳回碼 | 描述 |
---|---|
|
成功。 |
|
Null 指標引數。 |
|
針腳已經連接。 |
|
篩選準則為作用中,且針腳不支援動態重新連線。 |
|
無法接受指定的媒體類型。 |
備註
輸出針腳會在輸入針腳上呼叫這個方法。 如果輸入針腳傳回錯誤碼,連線就會失敗。
在基類中,此方法會執行下列步驟:
- 檢查針腳是否已連線。
- 檢查篩選是否已停止。
- 呼叫 CBasePin::CheckConnect 方法,以測試連接針腳是否適合。
- 呼叫 CBasePin::CheckMediaType 方法,以測試媒體類型是否可接受。
如果上述所有步驟都成功,此方法會呼叫 CBasePin::CompleteConnect 和 SetMediaType 方法以完成連線。 這些方法會儲存媒體類型和輸出針腳的指標。
如果 CheckConnect 或 CheckMediaType 失敗,基類會呼叫 CBasePin::BreakConnect 方法來中斷連線,然後從 ReceiveConnection
傳回錯誤碼。
規格需求
需求 | 值 |
---|---|
標頭 |
|
程式庫 |
|