次の方法で共有


IMediaEventEx::SetNotifyWindow メソッド (control.h)

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

メソッドは SetNotifyWindow 、イベント通知を処理するウィンドウを登録します。

構文

HRESULT SetNotifyWindow(
  [in] OAHWND   hwnd,
  [in] long     lMsg,
  [in] LONG_PTR lInstanceData
);

パラメーター

[in] hwnd

ウィンドウを処理するか、イベント メッセージの受信を停止する 場合は NULL

[in] lMsg

通知として渡されるウィンドウ メッセージ。

[in] lInstanceData

lMsg メッセージの lParam パラメーターとして渡される値。

戻り値

成功した場合はS_OKを返し、 hwnd パラメーターがウィンドウへの有効なハンドルでない場合はE_INVALIDARGを返します。

解説

このメソッドは、イベント通知を処理するウィンドウを指定します。 Filter Graph Manager がイベント キューにイベントを配置するたびに、指定されたウィンドウにもメッセージが投稿されます。 hwnd パラメーターはウィンドウを指定し、lMsg パラメーターはメッセージを指定します。 アプリケーションでは、この目的のためにプライベート ウィンドウ メッセージを定義する必要があります。 メッセージの lParam パラメーターは lInstanceData の値に設定され、 wParam パラメーターは 0 に設定されます。

ウィンドウがメッセージを受信すると、 IMediaEvent::GetEvent メソッドを呼び出してイベントを取得する必要があります。 イベントは非同期であるため、キューには複数のイベントが含まれる場合があります (または含まれていない場合)。 エラー コードが返されるまで、 GetEvent を繰り返し呼び出します。

要件

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

関連項目

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

IMediaEventEx インターフェイス