次の方法で共有


IMediaEvent::GetEvent メソッド (control.h)

[このページに関連付けられている機能 DirectShow は、従来の機能です。 MediaPlayerIMFMediaEngine、および Media Foundation のオーディオ/ビデオ キャプチャに置き換わりました。 これらの機能は、Windows 10とWindows 11用に最適化されています。 新しいコードでは、可能であれば、DirectShow ではなく Media Foundation で MediaPlayerIMFMediaEngineAudio/Video Capture を使用することを強くお勧めします。 Microsoft は、従来の API を使用する既存のコードを、可能であれば新しい API を使用するように書き直すよう提案しています。]

メソッドは GetEvent 、イベント キューから次のイベント通知を取得します。

構文

HRESULT GetEvent(
  [out] long     *lEventCode,
  [out] LONG_PTR *lParam1,
  [out] LONG_PTR *lParam2,
  [in]  long     msTimeout
);

パラメーター

[out] lEventCode

イベント コードを受け取る変数へのポインター。

[out] lParam1

最初のイベント パラメーターを受け取る変数へのポインター。

[out] lParam2

2 番目のイベント パラメーターを受け取る変数へのポインター。

[in] msTimeout

タイムアウト間隔 (ミリ秒単位)。 INFINITE を使用して、イベントが発生するまでブロックします。

戻り値

HRESULT 値を返します。 次の表に示す値を指定できます。

リターン コード 説明
S_OK
成功しました。
E_ABORT
タイムアウトに達しました。

解説

キューにイベントがない場合、このメソッドはイベントが到着するまで最大 msTimeout ミリ秒待機します。 の待機中にスレッドがメッセージを処理できないため、INFINITE のタイムアウト間隔を GetEvent使用しないでください。 Windows メッセージを処理するのと同じスレッドから を呼び出す GetEvent 場合は、ユーザー入力に対する応答を維持するために、小さな待機時間のみを指定します。

を呼び出 GetEventした後、 IMediaEvent::FreeEventParams メソッドを呼び出して、イベント パラメーターに割り当てられているリソースを解放します。

通知コードとイベント パラメーター値の一覧については、「 イベント通知コード」を参照してください。

このメソッドはフィルター グラフ イベント キューからイベントを削除するため、複数のクライアントが同じグラフからイベントを監視する方法はありません。

要件

   
サポートされている最小のクライアント Windows 2000 Professional [デスクトップ アプリのみ]
サポートされている最小のサーバー Windows 2000 Server [デスクトップ アプリのみ]
対象プラットフォーム Windows
ヘッダー control.h (Dshow.h を含む)
Library Strmiids.lib

関連項目

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

IMediaEvent インターフェイス

IMediaEventEx