iFilterGraph::AddFilter 方法 (strmif.h)

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

方法 AddFilter 會將篩選新增至圖形。

語法

HRESULT AddFilter(
  [in] IBaseFilter *pFilter,
  [in] LPCWSTR     pName
);

參數

[in] pFilter

要加入之篩選的 IBaseFilter 介面指標。

[in] pName

包含篩選名稱之寬字元字串的指標。

傳回值

傳回 HRESULT 值。 可能的值如下。

傳回碼 描述
S_OK
成功。
VFW_S_DUPLICATE_NAME
已成功新增具有重複名稱的篩選準則。
E_FAIL
失敗。
E_OUTOFMEMORY
記憶體不足。
E_POINTER
Null 指標引數。
VFW_E_CERTIFICATION_FAILURE
使用此篩選會受限於軟體金鑰。
VFW_E_DUPLICATE_NAME
無法新增名稱重複的篩選。

備註

篩選的名稱可以是 Null,在此情況下,Filter Graph 管理員會產生名稱。 如果名稱不是 Null 且不是唯一的,這個方法會在嘗試產生新的唯一名稱時修改名稱。 如果成功,這個方法會傳回VFW_S_DUPLICATE_NAME。 如果無法產生唯一的名稱,則會傳回VFW_E_DUPLICATE_NAME。

AddFilter 會呼叫篩選準則的 IBaseFilter::JoinFilterGraph 方法,以通知已新增篩選。 AddFilter 必須先呼叫 ,才能嘗試使用 IGraphBuilder::ConnectIFilterGraph::ConnectDirectIGraphBuilder::Render 方法來連接或轉譯屬於新增篩選準則的釘選。

篩選圖形管理員會保留篩選的參考計數,直到從圖形中移除篩選或篩選圖形管理員釋出為止。

規格需求

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

另請參閱

錯誤和成功碼

IFilterGraph 介面