다음을 통해 공유


CSourceSeeking.ChangeRate 메서드

[이 페이지와 연결된 기능인 DirectShow는 레거시 기능입니다. MediaPlayer, IMFMediaEngine 및 Media Foundation의 오디오/비디오 캡처로 대체되었습니다. 이러한 기능은 Windows 10 및 Windows 11 최적화되었습니다. 가능한 경우 새 코드가 DirectShow 대신 Media Foundation에서 MediaPlayer, IMFMediaEngine오디오/비디오 캡처를 사용하는 것이 좋습니다. 가능한 경우 레거시 API를 사용하는 기존 코드를 다시 작성하여 새 API를 사용하도록 제안합니다.]

ChangeRate 재생 속도가 변경되면 메서드가 호출됩니다.

구문

virtual HRESULT ChangeRate() = 0;

매개 변수

이 메서드에는 매개 변수가 없습니다.

반환 값

HRESULT 값을 반환합니다.

설명

CSourceSeeking::SetRate 메서드는 파생 클래스가 구현해야 하는 이 메서드를 호출합니다. SetRate 메서드는 CSourceSeeking::m_dRateSeeking 멤버 변수를 업데이트하지만 새 값의 유효성을 검사하지는 않습니다. 0의 속도는 항상 거부되어야 합니다. 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 클래스