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
|
// 5 december 2014
// TODO handler functions don't work here because you can't have more than one for the mouse ones...
static const handlerfunc keyDownHandlers[] = {
keyDownSelectHandler,
NULL,
};
static const handlerfunc keyUpHandlers[] = {
NULL,
};
static const handlerfunc charHandlers[] = {
NULL,
};
static const handlerfunc mouseMoveHandlers[] = {
checkboxMouseMoveHandler,
NULL,
};
static const handlerfunc mouseLeaveHandlers[] = {
checkboxMouseLeaveHandler,
NULL,
};
static const handlerfunc lbuttonDownHandlers[] = {
mouseDownSelectHandler,
NULL,
};
static const handlerfunc lbuttonUpHandlers[] = {
checkboxMouseUpHandler,
NULL,
};
// TODO remove or something? depends on if we implement combobox and how
static const handlerfunc mouseWheelHandlers[] = {
NULL,
};
// TODO WM_MOUSEHOVER, other mouse buttons
HANDLER(eventHandlers)
{
switch (uMsg) {
#define eventHandler(msg, array) \
case msg: \
return runHandlers(array, t, uMsg, wParam, lParam, lResult);
eventHandler(WM_KEYDOWN, keyDownHandlers)
eventHandler(WM_KEYUP, keyUpHandlers)
eventHandler(WM_CHAR, charHandlers)
eventHandler(WM_MOUSEMOVE, mouseMoveHandlers)
eventHandler(WM_MOUSELEAVE, mouseLeaveHandlers)
eventHandler(WM_LBUTTONDOWN, lbuttonDownHandlers)
eventHandler(WM_LBUTTONUP, lbuttonUpHandlers)
eventHandler(WM_MOUSEWHEEL, mouseWheelHandlers)
#undef eventHandler
}
return FALSE;
}
|