-
Notifications
You must be signed in to change notification settings - Fork 72
/
Copy pathclass_On_WM_Command.ahk
119 lines (119 loc) · 7.11 KB
/
class_On_WM_Command.ahk
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
; ======================================================================================================================
; AHK 1.1 +
; ======================================================================================================================
; Namespace: On_WM_COMMAND
; Function: Helper object to handle notification messages sent through WM_COMMAND
; AHK version: 1.1.05.06 (U32)
; Language: English
; Tested on: WinXPSP3, WinVistaSP2 (32 bit)
; Version: 0.1.00.00/2012-02-07/just me
; Remarks: To register a function to be called on notification call On_WM_COMMAND.Attach()
; passing three parameters:
; Hwnd - HWND of the GUI control (Integer)
; Message - Notification message number (Integer)
; Function - Name of the function which handles the message (String)
;
; To unregister notification handling call On_WM_COMMAND.Detach()
; passing two parameters:
; Hwnd - see above
; Message - see above
;
; To get a control's HWND use either the option "hwndOutputVar" with "Gui, Add" or the command
; "GuiControlGet" with sub-command "Hwnd".
;
; The function to be called on notification has to accept exactly four parameters:
; Hwnd - Hwnd of the GUI control sending the WM_COMMAND message
; Message - Notification message number
; wParam - wParam passed to On_WM_COMMAND_Handler
; lParam - lParam passed to On_WM_COMMAND_Handler
;
; For notifications through WM_COMMAND the contents of wParam and lParam is described at
; http://msdn.microsoft.com/en-us/library/ms647591%28VS.85%29.aspx,
; Look at the documentation for OnMessage(), too.
;
; To get the sort of notification please look at
; http://msdn.microsoft.com/en-us/library/bb773173%28VS.85%29.aspx
; in particular at "Control Library".
;
; The class registers On_WM_COMMAND_Handler as message handler for WM_COMMAND notfications
; per OnMessage() as long as controls are attached. You cannot use own handlers for this message
; at the same time.
; ======================================================================================================================
; This software is provided 'as-is', without any express or implied warranty.
; In no event will the authors be held liable for any damages arising from the use of this software.
; ======================================================================================================================
Class On_WM_COMMAND {
; +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; PRIVATE Properties and Methods ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Static Attached := 0
Static Controls := {}
Static MessageHandler := "On_WM_COMMAND_Handler"
Static WM_COMMAND := 0x0111
; ===================================================================================================================
; META FUNCTIONS
; ===================================================================================================================
__New() {
Return False ; there is no reason to instantiate this class
}
; +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; PUBLIC INTERFACE ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; ===================================================================================================================
; METHOD Attach Register control for WM_COMMAND messages
; Parameters: Hwnd - HWND of the GUI control (Integer)
; Message - message number (Integer)
; Function - name of the function to be called (String)
; Return values: On success - True
; On failure - False
; ===================================================================================================================
Attach(Hwnd, Message, Function) {
If Message Is Not Integer
Return False
If !IsFunc(Function)
Or (Func(Function).MaxParams <> 4)
Or !DllCall("User32.dll\IsWindow", "UPtr", Hwnd)
Return False
If This.Controls.HasKey(Hwnd) {
This.Controls[Hwnd][Message] := Func(Function)
Return True
}
If (This.Attached = 0)
OnMessage(This.WM_COMMAND, This.MessageHandler)
This.Attached += 1
This.Controls[Hwnd, Message] := Func(Function)
Return True
}
; ===================================================================================================================
; METHOD Detach Unregister control for WM_COMMAND messages
; Parameters: Hwnd - HWND of the GUI control (Integer)
; Message - message number (Integer)
; Return values: On success - True
; On failure - False
; ===================================================================================================================
Detach(Hwnd, Message) {
If This.Controls[Hwnd].HasKey(Message) {
This.Controls[Hwnd].Remove(Message, "")
If !This.Controls[Hwnd].MaxIndex() {
This.Controls.Remove(Hwnd, "")
This.Attached -= 1
If (This.Attached = 0) {
OnMessage(This.WM_COMMAND, "")
}
}
Return True
}
Return False
}
}
; ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; PRIVATE FUNCTIONS ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
; ======================================================================================================================
On_WM_COMMAND_Handler(W, L) { ; wParam, lParam
Global On_WM_COMMAND
Critical 1000
If IsObject(F := On_WM_COMMAND.Controls[L][M := (W >> 16)])
Return F.(L, M, W, L)
}
; ======================================================================================================================