共用方式為


iMediaFilter::GetState 方法 (strmif.h)

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

GetState方法會擷取篩選 (執行、停止或暫停) 的狀態。

語法

HRESULT GetState(
  [in]  DWORD        dwMilliSecsTimeout,
  [out] FILTER_STATE *State
);

參數

[in] dwMilliSecsTimeout

逾時間隔,以毫秒為單位。 若要無限期封鎖,請使用 INFINITE值。

[out] State

接收 FILTER_STATE 列舉型別的成員,指出篩選準則的狀態。

傳回值

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

傳回碼 描述
S_OK
成功。
E_POINTER
Null 指標引數。
VFW_S_STATE_INTERMEDIATE
中繼狀態。
VFW_S_CANT_CUE
篩選準則為作用中,但無法傳遞資料。

備註

狀態轉換可以是非同步。 如果篩選準則轉換為新狀態,且方法在轉換完成之前逾時,方法會 傳回VFW_S_STATE_INTERMEDIATE

如果篩選因某些原因而無法傳遞資料,則會傳回 VFW_S_CANT_CUE。 即時擷取篩選會在暫停時傳回此值,因為它們不會傳遞處於暫停狀態的資料。

如需詳細資訊,請參閱 篩選圖形中的資料流程

規格需求

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

另請參閱

錯誤和成功碼

IBaseFilter

IMediaFilter 介面