CSourceSeeking.ChangeRate 方法
[与此页面关联的功能 DirectShow 是旧版功能。 它已被 MediaPlayer、 IMFMediaEngine 和 Media Foundation 中的音频/视频捕获所取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能在 Media Foundation 中使用 MediaPlayer、 IMFMediaEngine 和 音频/视频捕获 ,而不是 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;
}
要求
要求 | 值 |
---|---|
标头 |
|
库 |
|