다음을 통해 공유


CBaseReferenceClock.AdviseTime 메서드

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

메서드는 AdviseTime 원샷 조언 요청을 만듭니다. 이 메서드는 IReferenceClock::AdviseTime 메서드를 구현합니다.

구문

HRESULT AdviseTime(
   REFERENCE_TIME baseTime,
   REFERENCE_TIME streamTime,
   HEVENT         hEvent,
   DWORD_PTR      *pdwAdviseToken
);

매개 변수

baseTime

기본 참조 시간(100나노초 단위)입니다.

streamTime

스트림 오프셋 시간(100나노초 단위)입니다.

hEvent

호출자가 만든 이벤트에 대한 핸들입니다.

pdwAdviseToken

조언 요청에 대한 식별자를 받는 변수에 대한 포인터입니다.

반환 값

다음 표에 표시된 HRESULT 값 중 하나를 반환합니다.

반환 코드 Description
S_OK
Success
E_INVALIDARG
잘못된 시간 값
E_OUTOFMEMORY
실패
E_POINTER
NULL 포인터 인수

설명

이 메서드는 참조 시간 baseTime + streamTime에 대한 원샷 조언 요청을 만듭니다. 합계가 0보다 크고 MAX_TIME 미만이거나 메서드가 E_INVALIDARG 반환해야 합니다. 요청된 시간에 클록은 hEvent 매개 변수에 지정된 이벤트에 신호를 보냅니다.

시간에 도달하기 전에 알림을 취소하려면 CBaseReferenceClock::Unadvise 메서드를 호출하고 이 호출에서 반환 된 pdwAdviseToken 값을 전달합니다. 알림이 발생한 후 클록이 자동으로 지워지므로 Unadvise를 호출할 필요가 없습니다. 그러나 이렇게 하는 것은 오류가 아닙니다.

요구 사항

요구 사항
헤더
Refclock.h(Streams.h 포함)
라이브러리
Strmbase.lib(소매 빌드);
Strmbasd.lib(디버그 빌드)

추가 정보

CBaseReferenceClock 클래스