共用方式為


IMediaEventEx::SetNotifyWindow 方法 (control.h)

[與此頁面相關的功能 DirectShow是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 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參數的值。

傳回值

如果成功或E_INVALIDARG hwnd 參數不是視窗的有效控制碼,則傳回S_OK。

備註

這個方法會指定將處理事件通知的視窗。 每當 Filter Graph Manager 將事件放在事件佇列中時,它也會將訊息張貼至指定的視窗。 hwnd參數會指定視窗,而 lMsg參數會指定訊息。 應用程式應該為此目的定義私人視窗訊息。 訊息的 lParam 參數會設定為 lInstanceData的值, 而 wParam 參數會設定為零。

當視窗收到訊息時,它應該呼叫 IMediaEvent::GetEvent 方法來擷取事件。 事件是非同步,因此佇列可能包含數個事件 (或無) 。 重複呼叫 GetEvent ,直到傳回錯誤碼為止。

規格需求

   
最低支援的用戶端 Windows 2000 專業版 [僅限傳統型應用程式]
最低支援的伺服器 Windows 2000 Server [僅限傳統型應用程式]
目標平台 Windows
標頭 control.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

錯誤和成功碼

IMediaEventEx 介面