共用方式為


CDynamicOutputPin.ChangeMediaType 方法

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

方法 ChangeMediaType 會動態變更連接的媒體類型。 當篩選圖形正在執行時,可能會發生變更。 呼叫此方法之後,就無法傳遞具有舊媒體類型的範例。 呼叫端必須確保沒有任何舊的範例擱置中。

語法

HRESULT ChangeMediaType(
   const CMediaType *pmt
);

參數

Pmt

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

傳回值

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

傳回碼 描述
S_OK
成功。
E_FAIL
失敗。 可能擁有的篩選未呼叫 CDynamicOutputPin::SetConfigInfo
VFW_E_NOT_CONNECTED
針腳未連線。

備註

先呼叫 CDynamicOutputPin::StartUsingOutputPin 方法,再呼叫此方法。

此方法會先檢查下游輸入針腳是否可以接受新的格式,而不需重新連線。 它會查詢 IPinConnection 介面的輸入釘選。 如果輸入針腳支援 IPinConnection,此方法會使用建議的媒體類型呼叫 IPinConnection::D ynamicQueryAccept 方法。 如果輸入針腳接受新的媒體類型,此方法會呼叫 IPin::ReceiveConnection 方法,並重新分類配置器需求。

另一方面,如果下游針腳不支援 IPinConnection,或拒絕新的媒體類型,此方法會呼叫 CDynamicOutputPin::D ynamicReconnect 方法來執行動態重新連線。

規格需求

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

另請參閱

CDynamicOutputPin 類別