CSourceSeeking.ChangeRate 方法

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

當播放速率變更時,會 ChangeRate 呼叫 方法。

語法

virtual HRESULT ChangeRate() = 0;

參數

這個方法沒有任何參數。

傳回值

傳回 HRESULT 值。

備註

CSourceSeeking::SetRate方法會呼叫這個方法,衍生類別必須實作這個方法。 SetRate方法會更新CSourceSeeking::m_dRateSeeking成員變數,但不會驗證新的值。 應該一律拒絕零的速率。 速率小於零表示負播放。 大部分篩選都不支援負率。

下列範例示範可能的實作:

HRESULT CMyStream::ChangeRate( )
{
    {   // Scope for critical section lock.
        CAutoLock cAutoLockSeeking(CSourceSeeking::m_pLock);
        if( m_dRateSeeking <= 0 ) {
            m_dRateSeeking = 1.0;  // Reset to a reasonable value.
            return E_FAIL;
        }
    }
    UpdateFromSeek();
    return S_OK;
}

規格需求

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

另請參閱

CSourceSeeking 類別