次の方法で共有


CSourceSeeking.ChangeRate メソッド

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayerIMFMediaEngine、および Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/Video Capture を使用することを強くお勧めします。 Microsoft は、従来の API を使用する既存のコードを、可能であれば新しい API を使用するように書き直すよう提案しています。]

メソッドは ChangeRate 、再生レートが変化したときに呼び出されます。

構文

virtual HRESULT ChangeRate() = 0;

パラメーター

このメソッドにはパラメーターはありません。

戻り値

HRESULT 値を返します。

解説

CSourceSeeking::SetRate メソッドは、派生クラスが実装する必要があるこのメソッドを呼び出します。 SetRate メソッドは CSourceSeeking::m_dRateSeeking メンバー変数を更新しますが、新しい値は検証しません。 ゼロのレートは常に拒否する必要があります。 0 未満のレートは、負の再生を示します。 ほとんどのフィルターでは、負のレートはサポートされていません。

次の例は、考えられる実装を示しています。

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 クラス