IMediaEventEx::SetNotifyWindow 方法 (control.h)
[與此頁面相關的功能 DirectShow是舊版功能。 它已被 MediaPlayer、 IMFMediaEngine和 Media Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayer、 IMFMediaEngine 和 音訊/視訊擷取 ,而不是 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 |