OLD | NEW |
| (Empty) |
1 /* | |
2 * Copyright (C) 2009 Google Inc. All rights reserved. | |
3 * | |
4 * Redistribution and use in source and binary forms, with or without | |
5 * modification, are permitted provided that the following conditions are | |
6 * met: | |
7 * | |
8 * * Redistributions of source code must retain the above copyright | |
9 * notice, this list of conditions and the following disclaimer. | |
10 * * Redistributions in binary form must reproduce the above | |
11 * copyright notice, this list of conditions and the following disclaimer | |
12 * in the documentation and/or other materials provided with the | |
13 * distribution. | |
14 * * Neither the name of Google Inc. nor the names of its | |
15 * contributors may be used to endorse or promote products derived from | |
16 * this software without specific prior written permission. | |
17 * | |
18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | |
19 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | |
20 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | |
21 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | |
22 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |
23 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | |
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | |
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | |
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
29 */ | |
30 | |
31 #ifndef WebInputEvent_h | |
32 #define WebInputEvent_h | |
33 | |
34 #include "WebCommon.h" | |
35 | |
36 #include <string.h> | |
37 | |
38 namespace WebKit { | |
39 | |
40 // The classes defined in this file are intended to be used with | |
41 // WebWidget's handleInputEvent method. These event types are cross- | |
42 // platform and correspond closely to WebCore's Platform*Event classes. | |
43 // | |
44 // WARNING! These classes must remain PODs (plain old data). They are | |
45 // intended to be "serializable" by copying their raw bytes, so they must | |
46 // not contain any non-bit-copyable member variables! | |
47 | |
48 // WebInputEvent -------------------------------------------------------------- | |
49 | |
50 class WebInputEvent { | |
51 public: | |
52 WebInputEvent(unsigned sizeParam = sizeof(WebInputEvent)) | |
53 : size(sizeParam) | |
54 , type(Undefined) | |
55 , modifiers(0) | |
56 , timeStampSeconds(0.0) { } | |
57 | |
58 // When we use an input method (or an input method editor), we receive | |
59 // two events for a keypress. The former event is a keydown, which | |
60 // provides a keycode, and the latter is a textinput, which provides | |
61 // a character processed by an input method. (The mapping from a | |
62 // keycode to a character code is not trivial for non-English | |
63 // keyboards.) | |
64 // To support input methods, Safari sends keydown events to WebKit for | |
65 // filtering. WebKit sends filtered keydown events back to Safari, | |
66 // which sends them to input methods. | |
67 // Unfortunately, it is hard to apply this design to Chrome because of | |
68 // our multiprocess architecture. An input method is running in a | |
69 // browser process. On the other hand, WebKit is running in a renderer | |
70 // process. So, this design results in increasing IPC messages. | |
71 // To support input methods without increasing IPC messages, Chrome | |
72 // handles keyboard events in a browser process and send asynchronous | |
73 // input events (to be translated to DOM events) to a renderer | |
74 // process. | |
75 // This design is mostly the same as the one of Windows and Mac Carbon. | |
76 // So, for what it's worth, our Linux and Mac front-ends emulate our | |
77 // Windows front-end. To emulate our Windows front-end, we can share | |
78 // our back-end code among Windows, Linux, and Mac. | |
79 // TODO(hbono): Issue 18064: remove the KeyDown type since it isn't | |
80 // used in Chrome any longer. | |
81 | |
82 enum Type { | |
83 Undefined = -1, | |
84 | |
85 // WebMouseEvent | |
86 MouseDown, | |
87 MouseUp, | |
88 MouseMove, | |
89 MouseEnter, | |
90 MouseLeave, | |
91 | |
92 // WebMouseWheelEvent | |
93 MouseWheel, | |
94 | |
95 // WebKeyboardEvent | |
96 RawKeyDown, | |
97 KeyDown, | |
98 KeyUp, | |
99 Char | |
100 }; | |
101 | |
102 enum Modifiers { | |
103 // modifiers for all events: | |
104 ShiftKey = 1 << 0, | |
105 ControlKey = 1 << 1, | |
106 AltKey = 1 << 2, | |
107 MetaKey = 1 << 3, | |
108 | |
109 // modifiers for keyboard events: | |
110 IsKeyPad = 1 << 4, | |
111 IsAutoRepeat = 1 << 5, | |
112 | |
113 // modifiers for mouse events: | |
114 LeftButtonDown = 1 << 6, | |
115 MiddleButtonDown = 1 << 7, | |
116 RightButtonDown = 1 << 8, | |
117 }; | |
118 | |
119 unsigned size; // The size of this structure, for serialization. | |
120 Type type; | |
121 int modifiers; | |
122 double timeStampSeconds; // Seconds since epoch. | |
123 | |
124 // Returns true if the WebInputEvent |type| is a keyboard event. | |
125 static bool isKeyboardEventType(int type) | |
126 { | |
127 return type == RawKeyDown | |
128 || type == KeyDown | |
129 || type == KeyUp | |
130 || type == Char; | |
131 } | |
132 }; | |
133 | |
134 // WebKeyboardEvent ----------------------------------------------------------- | |
135 | |
136 class WebKeyboardEvent : public WebInputEvent { | |
137 public: | |
138 // Caps on string lengths so we can make them static arrays and keep | |
139 // them PODs. | |
140 static const size_t textLengthCap = 4; | |
141 | |
142 // http://www.w3.org/TR/DOM-Level-3-Events/keyset.html lists the | |
143 // identifiers. The longest is 18 characters, so we round up to the | |
144 // next multiple of 4. | |
145 static const size_t keyIdentifierLengthCap = 20; | |
146 | |
147 // |windowsKeyCode| is the Windows key code associated with this key | |
148 // event. Sometimes it's direct from the event (i.e. on Windows), | |
149 // sometimes it's via a mapping function. If you want a list, see | |
150 // WebCore/platform/chromium/KeyboardCodes* . | |
151 int windowsKeyCode; | |
152 | |
153 // The actual key code genenerated by the platform. The DOM spec runs | |
154 // on Windows-equivalent codes (thus |windowsKeyCode| above) but it | |
155 // doesn't hurt to have this one around. | |
156 int nativeKeyCode; | |
157 | |
158 // |text| is the text generated by this keystroke. |unmodifiedText| is | |
159 // |text|, but unmodified by an concurrently-held modifiers (except | |
160 // shift). This is useful for working out shortcut keys. Linux and | |
161 // Windows guarantee one character per event. The Mac does not, but in | |
162 // reality that's all it ever gives. We're generous, and cap it a bit | |
163 // longer. | |
164 WebUChar text[textLengthCap]; | |
165 WebUChar unmodifiedText[textLengthCap]; | |
166 | |
167 // This is a string identifying the key pressed. | |
168 char keyIdentifier[keyIdentifierLengthCap]; | |
169 | |
170 // This identifies whether this event was tagged by the system as being | |
171 // a "system key" event (see | |
172 // http://msdn.microsoft.com/en-us/library/ms646286(VS.85).aspx for | |
173 // details). Other platforms don't have this concept, but it's just | |
174 // easier to leave it always false than ifdef. | |
175 // int is used instead of bool to ensure the size of this structure is | |
176 // strictly aligned to a factor of 4 bytes, otherwise memory check tools | |
177 // like valgrind may complain about uninitialized memory usage when | |
178 // transfering it over the wire. | |
179 int isSystemKey; | |
180 | |
181 WebKeyboardEvent(unsigned sizeParam = sizeof(WebKeyboardEvent)) | |
182 : WebInputEvent(sizeParam) | |
183 , windowsKeyCode(0) | |
184 , nativeKeyCode(0) | |
185 , isSystemKey(false) | |
186 { | |
187 memset(&text, 0, sizeof(text)); | |
188 memset(&unmodifiedText, 0, sizeof(unmodifiedText)); | |
189 memset(&keyIdentifier, 0, sizeof(keyIdentifier)); | |
190 } | |
191 | |
192 // Sets keyIdentifier based on the value of windowsKeyCode. This is | |
193 // handy for generating synthetic keyboard events. | |
194 WEBKIT_API void setKeyIdentifierFromWindowsKeyCode(); | |
195 }; | |
196 | |
197 // WebMouseEvent -------------------------------------------------------------- | |
198 | |
199 class WebMouseEvent : public WebInputEvent { | |
200 public: | |
201 // These values defined for WebCore::MouseButton | |
202 enum Button { | |
203 ButtonNone = -1, | |
204 ButtonLeft, | |
205 ButtonMiddle, | |
206 ButtonRight | |
207 }; | |
208 | |
209 Button button; | |
210 int x; | |
211 int y; | |
212 int windowX; | |
213 int windowY; | |
214 int globalX; | |
215 int globalY; | |
216 int clickCount; | |
217 | |
218 WebMouseEvent(unsigned sizeParam = sizeof(WebMouseEvent)) | |
219 : WebInputEvent(sizeParam) | |
220 , button(ButtonNone) | |
221 , x(0) | |
222 , y(0) | |
223 , windowX(0) | |
224 , windowY(0) | |
225 , globalX(0) | |
226 , globalY(0) | |
227 , clickCount(0) | |
228 { | |
229 } | |
230 }; | |
231 | |
232 // WebMouseWheelEvent --------------------------------------------------------- | |
233 | |
234 class WebMouseWheelEvent : public WebMouseEvent { | |
235 public: | |
236 float deltaX; | |
237 float deltaY; | |
238 float wheelTicksX; | |
239 float wheelTicksY; | |
240 | |
241 // int is used instead of bool to ensure the size of this structure is | |
242 // strictly aligned to a factor of 4 bytes, otherwise memory check tools | |
243 // like valgrind may complain about uninitialized memory usage when | |
244 // transfering it over the wire. | |
245 int scrollByPage; | |
246 | |
247 WebMouseWheelEvent(unsigned sizeParam = sizeof(WebMouseWheelEvent)) | |
248 : WebMouseEvent(sizeParam) | |
249 , deltaX(0.0f) | |
250 , deltaY(0.0f) | |
251 , wheelTicksX(0.0f) | |
252 , wheelTicksY(0.0f) | |
253 , scrollByPage(false) | |
254 { | |
255 } | |
256 }; | |
257 | |
258 } // namespace WebKit | |
259 | |
260 #endif | |
OLD | NEW |