共用方式為


IEnumMediaTypes::Next 方法 (strmif.h)

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

Next 方法會擷取指定的媒體類型數目。

語法

HRESULT Next(
  [in]  ULONG         cMediaTypes,
  [out] AM_MEDIA_TYPE **ppMediaTypes,
  [out] ULONG         *pcFetched
);

參數

[in] cMediaTypes

要擷取的媒體類型數目。

[out] ppMediaTypes

AM_MEDIA_TYPE指標數位的位址。 陣列中的元素數目會在 cMediaTypes 參數中指定。

[out] pcFetched

接收 ppMediaTypes 中傳回的媒體類型數目。 如果 cMediaTypes 為 1,此參數可以是 NULL

傳回值

傳回下列其中一個 HRESULT 值。

傳回碼 Description
S_FALSE
未擷取所要求的媒體類型數目。
S_OK
成功。
E_INVALIDARG
無效引數。
E_POINTER
NULL 指標自變數。
VFW_E_ENUM_OUT_OF_SYNC
針腳的狀態已變更,現在與列舉值不一致。

備註

呼叫端會傳遞 ppMediaTypesAM_MEDIA_TYPE指標的陣列。 方法會配置等於 cMediaTypes 的數位AM_MEDIA_TYPE結構,或配置在列舉中保留的媒體類型數目,不論哪一個都少。 配置的結構數目會在 pcFetched中傳回。 藉由呼叫 DeleteMediaType 函式來刪除每個結構。

如果媒體類型集合變更,列舉值就會與擁有的針腳不一致。 在此情況下,方法會傳回VFW_E_ENUM_OUT_OF_SYNC。 捨棄從先前呼叫列舉值取得的任何數據,因為它可能無效。 呼叫 IEnumMediaTypes::Reset 方法,以更新列舉值。 然後,您可以安全地呼叫 Next 方法。

規格需求

需求
最低支援的用戶端 Windows 2000 專業版 [僅限傳統型應用程式]
最低支援的伺服器 Windows 2000 Server [僅限傳統型應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

列舉媒體類型

錯誤和成功碼

IEnumMediaTypes 介面