다음을 통해 공유


IReferenceClock::AdvisePeriodic 메서드(strmif.h)

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

메서드는 AdvisePeriodic 주기적인 조언 요청을 만듭니다.

구문

HRESULT AdvisePeriodic(
  [in]  REFERENCE_TIME startTime,
  [in]  REFERENCE_TIME periodTime,
  [in]  HSEMAPHORE     hSemaphore,
  [out] DWORD_PTR      *pdwAdviseCookie
);

매개 변수

[in] startTime

첫 번째 알림 시간(100나노초 단위)입니다. 0보다 크고 MAX_TIME 미만이어야 합니다.

[in] periodTime

알림 사이의 시간(100나노초 단위)입니다. 0보다 커야 합니다.

[in] hSemaphore

호출자가 만든 세마포에 대한 핸들입니다.

[out] pdwAdviseCookie

advise 요청에 대한 식별자를 수신하는 변수에 대한 포인터입니다.

반환 값

HRESULT 값을 반환합니다. 가능한 값은 다음과 같습니다.

반환 코드 Description
S_OK
성공.
E_INVALIDARG
잘못된 시간 값입니다.
E_OUTOFMEMORY
실패.
E_POINTER
NULL 포인터 인수입니다.

설명

각 알림 시간에 클록은 hSemaphore 매개 변수에 지정된 세마포를 해제합니다. 추가 알림이 필요하지 않은 경우 IReferenceClock::Unadvise 를 호출하고 이 호출에서 반환 된 pdwAdviseToken 값을 전달합니다.

다음 코드 예제에서는 생성된 시간으로부터 5초 후, 그 이후에는 1초마다 다시 신호를 전송하는 advise 요청을 만듭니다.

C++
IReferenceClock *pRefClock = NULL; IReferenceClock 포인터를 가져옵니다(표시되지 않음).

DWORD dwAdviseToken; HANDLE hSemaphore = CreateSemaphore(NULL, 0, 0x7FFFFFFF, NULL); REFERENCE_TIME rtPeriodTime = 10000000; rtNow를 REFERENCE_TIME 1초 간격입니다.

pRefClock-GetTime>(&rtNow); pRefClock-AdvisePeriodic>(rtNow + (5 * rtPeriodTime), rtPeriodTime, hSemaphore, &dwAdviseToken); ...

pRefClock->Unadvise(dwAdviseToken);

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows 2000 Professional[데스크톱 앱만]
지원되는 최소 서버 Windows 2000 Server[데스크톱 앱만]
대상 플랫폼 Windows
헤더 strmif.h(Dshow.h 포함)
라이브러리 Strmiids.lib

추가 정보

오류 및 성공 코드

IReferenceClock 인터페이스