CBasePin.ReceiveConnection 方法

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

方法 ReceiveConnection 接受來自另一個針腳的連接。 這個方法會實作 IPin::ReceiveConnection 方法。

語法

HRESULT ReceiveConnection(
   IPin          *pConnector,
   AM_MEDIA_TYPE *pmt
);

參數

pConnector

連接針腳的 IPin 介面指標。

Pmt

指定媒體類型的 AM_MEDIA_TYPE 結構的指標。

傳回值

傳回 HRESULT 值。 可能的值包括下表中的值。

傳回碼 描述
S_OK
成功。
E_POINTER
Null 指標引數。
VFW_E_ALREADY_CONNECTED
針腳已經連接。
VFW_E_NOT_STOPPED
篩選準則為作用中,且針腳不支援動態重新連線。
VFW_E_TYPE_NOT_ACCEPTED
無法接受指定的媒體類型。

備註

輸出針腳會在輸入針腳上呼叫這個方法。 如果輸入針腳傳回錯誤碼,連線就會失敗。

在基類中,此方法會執行下列步驟:

如果上述所有步驟都成功,此方法會呼叫 CBasePin::CompleteConnectSetMediaType 方法以完成連線。 這些方法會儲存媒體類型和輸出針腳的指標。

如果 CheckConnectCheckMediaType 失敗,基類會呼叫 CBasePin::BreakConnect 方法來中斷連線,然後從 ReceiveConnection 傳回錯誤碼。

規格需求

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

另請參閱

CBasePin 類別