iFilterGraph::AddFilter 方法 (strmif.h)
[與此頁面 相關的功能 DirectShow是舊版功能。 它已被 MediaPlayer、 IMFMediaEngine和 Media Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayer、 IMFMediaEngine 和 音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議盡可能重寫使用舊版 API 的現有程式碼,以使用新的 API。]
方法 AddFilter
會將篩選新增至圖形。
語法
HRESULT AddFilter(
[in] IBaseFilter *pFilter,
[in] LPCWSTR pName
);
參數
[in] pFilter
要加入之篩選的 IBaseFilter 介面指標。
[in] pName
包含篩選名稱之寬字元字串的指標。
傳回值
傳回 HRESULT 值。 可能的值如下。
傳回碼 | 描述 |
---|---|
|
成功。 |
|
已成功新增具有重複名稱的篩選準則。 |
|
失敗。 |
|
記憶體不足。 |
|
Null 指標引數。 |
|
使用此篩選會受限於軟體金鑰。 |
|
無法新增名稱重複的篩選。 |
備註
篩選的名稱可以是 Null,在此情況下,Filter Graph 管理員會產生名稱。 如果名稱不是 Null 且不是唯一的,這個方法會在嘗試產生新的唯一名稱時修改名稱。 如果成功,這個方法會傳回VFW_S_DUPLICATE_NAME。 如果無法產生唯一的名稱,則會傳回VFW_E_DUPLICATE_NAME。
AddFilter
會呼叫篩選準則的 IBaseFilter::JoinFilterGraph 方法,以通知已新增篩選。 AddFilter
必須先呼叫 ,才能嘗試使用 IGraphBuilder::Connect、 IFilterGraph::ConnectDirect或 IGraphBuilder::Render 方法來連接或轉譯屬於新增篩選準則的釘選。
篩選圖形管理員會保留篩選的參考計數,直到從圖形中移除篩選或篩選圖形管理員釋出為止。
規格需求
最低支援的用戶端 | Windows 2000 Professional [僅限傳統型應用程式] |
最低支援的伺服器 | Windows 2000 Server [僅限桌面應用程式] |
目標平台 | Windows |
標頭 | strmif.h (包含 Dshow.h) |
程式庫 | Strmiids.lib |