CallWindowProcW

メッセージ情報を指定したウィンドウプロシージャに渡す。(Unicode)

CallWindowProcW lpPrevWndFunc, hWnd, Msg, wParam, lParam

lpPrevWndFunc : [int] 型: WNDPROC 直前のウィンドウプロシージャ。GetWindowLong 関数の nIndex を GWL_WNDPROC または DWL_DLGPROC に設定して取得した場合、これは実際にはウィンドウまたはダイアログプロシージャのアドレスか、CallWindowProc にのみ意味のある特殊な内部値である。
hWnd : [intptr] 型: HWND メッセージを受け取るウィンドウプロシージャへのハンドル。
Msg : [int] 型: UINT メッセージ。
wParam : [intptr] 型: WPARAM 追加のメッセージ固有情報。このパラメータの内容は Msg パラメータの値による。
lParam : [intptr] 型: LPARAM 追加のメッセージ固有情報。このパラメータの内容は Msg パラメータの値による。

(プラグイン / モジュール : user32.dll)

解説

メッセージ情報を指定したウィンドウプロシージャに渡す。(Unicode)

[戻り値]
型: LRESULT 戻り値はメッセージ処理の結果を表し、送信されたメッセージに依存する。

[備考]
ウィンドウのサブクラス化には CallWindowProc 関数を使用する。通常、同じクラスを持つすべてのウィンドウは 1
つのウィンドウプロシージャを共有する。サブクラスとは、同じクラスを持つウィンドウまたはウィンドウ群で、そのメッセージがクラスのウィンドウプロシージャに渡される前に別のウィンドウプロシージャによってインターセプトされ処理されるものである。SetWindowLong
関数は、特定のウィンドウに関連付けられたウィンドウプロシージャを変更してサブクラスを作成し、システムが以前のものではなく新しいウィンドウプロシージャを呼ぶようにする。アプリケーションは新しいウィンドウプロシージャで処理しなかったメッセージを
CallWindowProc
を呼んで以前のウィンドウプロシージャに渡す必要がある。これによりアプリケーションはウィンドウプロシージャのチェーンを作成できる。STRICT
が定義されている場合、lpPrevWndFunc パラメータの型は WNDPROC である。WNDPROC 型は次のように宣言されている:
(以下省略)

情報

プラグイン / モジュールuser32.dll
バージョン1.0
作成日2026/04/16
著作者IronHSP / CsWin32 bridge
URLhttps://github.com/inovia/IronHSP
備考Win32 API の user32.dll 関数群。CsWin32 + win32metadata から自動生成。
hsp3net 専用 (intptr / NSTRUCT / wstr を使用)。
タイプ拡張命令
グループWin32API
対応環境
  • Windows 版 HSP
hs ファイルhsphelp\win32_user32_gen2.hs