次の方法で共有


IReferenceClock::AdvisePeriodic メソッド (strmif.h)

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayer、IMFMediaEngine、Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/Video Capture を使用することを強くお勧めします。 Microsoft は、レガシ 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

アドバイス要求の識別子を受け取る変数へのポインター。

戻り値

HRESULT 値を返します。 使用可能な値は次のとおりです。

リターン コード 説明
S_OK
正常終了しました。
E_INVALIDARG
無効な時刻値です。
E_OUTOFMEMORY
失敗しました。
E_POINTER
NULL ポインター引数。

注釈

通知のたびに、クロックは hSemaphore パラメーターで指定されたセマフォを解放します。 それ以上の通知が必要ない場合は、 IReferenceClock::Unadvise を呼び出し、この呼び出しから返された pdwAdviseToken 値を 渡します。

次のコード例では、作成時刻から 5 秒後、その後も 1 秒ごとに通知するアドバイズ要求を作成します。

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 を含む)
Library Strmiids.lib

こちらもご覧ください

エラーコードと成功コード

IReferenceClock インターフェイス