CBaseFilter.GetState 方法

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

方法 GetState 會擷取篩選準則的狀態, (執行、停止或暫停) 。 這個方法會實作 IMediaFilter::GetState 方法。

語法

HRESULT GetState(
   DWORD        dwMilliSecsTimeout,
   FILTER_STATE *State
);

參數

dwMilliSecsTimeout

逾時間隔,以毫秒為單位。

State

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

傳回值

傳回S_OK或E_POINTER。

備註

在基類中,所有狀態轉換都是同步的,而且 會忽略 dwMilliSecsTimeout 參數。 如果衍生類別執行非同步狀態轉換,它應該覆寫此方法以在狀態轉換期間等候,並逾時 dwMilliSecsTimeout 毫秒。

如果您的篩選在暫停時未傳遞資料,請覆寫 GetState 方法,以在篩選暫停時傳回值VFW_S_CANT_CUE (請參閱 傳遞範例) 。 例如:

CMyFilter::GetState(DWORD dw, FILTER_STATE *pState)
{
    CheckPointer(pState, E_POINTER);
    *pState = m_State;
    if (m_State == State_Paused)
        return VFW_S_CANT_CUE;
    else
        return S_OK;
}

規格需求

需求
標頭
Amfilter.h (包含 Streams.h)
程式庫
Strmbase.lib (零售組建) ;
Strmbasd.lib (偵錯組建)

另請參閱

CBaseFilter 類別