IEnumFilters::Next 方法 (strmif.h)
[與此頁面相關的功能 DirectShow 是舊版功能。 它已被 MediaPlayer、 IMFMediaEngine 和 Media Foundation 中的音訊/視訊擷取取代。 這些功能已針對 Windows 10 和 Windows 11 進行優化。 Microsoft 強烈建議新程式代碼盡可能使用 MediaPlayer、 IMFMediaEngine 和 音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式代碼盡可能重寫為使用新的 API。
方法 Next
會擷取列舉序列中指定的篩選數目。
語法
HRESULT Next(
[in] ULONG cFilters,
[out] IBaseFilter **ppFilter,
[out] ULONG *pcFetched
);
參數
[in] cFilters
要擷取的篩選數目。
[out] ppFilter
以IBaseFilter介面指標填入的大小 cFilters 陣列。 呼叫端必須釋放介面。
[out] pcFetched
接收擷取的篩選條件數目。 如果 cFilters 為 1,則可為 NULL。
傳回值
值 | Description |
---|---|
S_FALSE | 未如要求擷取太多篩選條件。 |
S_OK | 成功。 |
E_INVALIDARG | 無效引數。 |
E_POINTER | NULL 指標自變數。 |
VFW_E_ENUM_OUT_OF_SYNC | 圖表已變更,且現在與列舉值不一致。 |
備註
如果方法成功, IBaseFilter 指標全都有未處理的參考計數。 當您完成時,請務必釋出它們。
例如,如果篩選圖表變更 (,應用程式會移除篩選) ,列舉值不再與圖形一致,而且方法會傳回VFW_E_ENUM_OUT_OF_SYNC。 捨棄從先前呼叫列舉值取得的任何數據,因為它可能無效。 呼叫 IEnumFilters::Reset 方法來更新列舉值。 然後,您可以安全地呼叫 Next
方法。
規格需求
需求 | 值 |
---|---|
最低支援的用戶端 | Windows 2000 專業版 [僅限傳統型應用程式] |
最低支援的伺服器 | Windows 2000 Server [僅限傳統型應用程式] |
目標平台 | Windows |
標頭 | strmif.h (包含 Dshow.h) |
程式庫 | Strmiids.lib |