CBasePin.TryMediaTypes 方法

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

假設有媒體類型的清單, TryMediaTypes 此方法會嘗試使用其中一種類型來完成連線。

語法

virtual HRESULT TryMediaTypes(
         IPin            *pReceivePin,
   const CMediaType      *pmt,
         IEnumMediaTypes *pEnum
);

參數

pReceivePin

接收針腳的 IPin 介面指標。

Pmt

CMediaType物件的指標,該物件會限制可能的媒體類型或Null

pEnum

IEnumMediaTypes介面的指標,用來列舉媒體類型清單。

傳回值

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

傳回碼 描述
S_OK
成功。
VFW_E_NO_ACCEPTABLE_TYPES
找不到可接受的媒體類型。

備註

針對 IEnumMediaTypes 介面所傳回的每個媒體類型,此方法會呼叫 CBasePin::AttemptConnection 方法來嘗試連線。

如果 pmt 參數不是Null,則針腳會略過不符合此類型的媒體類型。 pmt參數可以指定部分媒體類型。 部分媒體類型具有主要類型、子類型或格式GUID_Null的值。 GUID_Null值符合任何類型,類似于「萬用字元」值。

規格需求

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

另請參閱

CBasePin 類別