OLD | NEW |
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "config.h" | 5 #include "config.h" |
6 | 6 |
7 #include "webkit/glue/webinputevent.h" | 7 #include "webkit/glue/webinputevent.h" |
8 | 8 |
9 #include "KeyboardCodes.h" | 9 #include "KeyboardCodes.h" |
10 #include "KeyCodeConversion.h" | 10 #include "KeyCodeConversion.h" |
11 | 11 |
| 12 #include "webkit/glue/event_conversion.h" |
| 13 |
| 14 // This header is out of alphabetical order, but event_conversion.h pulls |
| 15 // in more webkit headers that redefine LOG so I need to undef afterwards. |
| 16 #undef LOG |
12 #include "base/logging.h" | 17 #include "base/logging.h" |
13 #include "base/string_util.h" | |
14 #include "webkit/glue/webinputevent_utils.h" | |
15 | 18 |
16 #include <gdk/gdk.h> | 19 #include <gdk/gdk.h> |
17 #include <gdk/gdkkeysyms.h> | 20 #include <gdk/gdkkeysyms.h> |
18 #include <gtk/gtkversion.h> | 21 #include <gtk/gtkversion.h> |
19 | 22 |
20 namespace { | 23 namespace { |
21 | 24 |
22 double GdkEventTimeToWebEventTime(guint32 time) { | 25 double GdkEventTimeToWebEventTime(guint32 time) { |
23 // Convert from time in ms to time in sec. | 26 // Convert from time in ms to time in sec. |
24 return time / 1000.0; | 27 return time / 1000.0; |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
56 break; | 59 break; |
57 case GDK_2BUTTON_PRESS: | 60 case GDK_2BUTTON_PRESS: |
58 case GDK_3BUTTON_PRESS: | 61 case GDK_3BUTTON_PRESS: |
59 type = MOUSE_DOUBLE_CLICK; | 62 type = MOUSE_DOUBLE_CLICK; |
60 break; | 63 break; |
61 case GDK_BUTTON_RELEASE: | 64 case GDK_BUTTON_RELEASE: |
62 type = MOUSE_UP; | 65 type = MOUSE_UP; |
63 break; | 66 break; |
64 | 67 |
65 default: | 68 default: |
66 NOTREACHED(); | 69 ASSERT_NOT_REACHED(); |
67 }; | 70 }; |
68 | 71 |
69 button = BUTTON_NONE; | 72 button = BUTTON_NONE; |
70 if (event->button == 1) { | 73 if (event->button == 1) { |
71 button = BUTTON_LEFT; | 74 button = BUTTON_LEFT; |
72 } else if (event->button == 2) { | 75 } else if (event->button == 2) { |
73 button = BUTTON_MIDDLE; | 76 button = BUTTON_MIDDLE; |
74 } else if (event->button == 3) { | 77 } else if (event->button == 3) { |
75 button = BUTTON_RIGHT; | 78 button = BUTTON_RIGHT; |
76 } | 79 } |
77 } | 80 } |
78 | 81 |
79 WebMouseEvent::WebMouseEvent(const GdkEventMotion* event) { | 82 WebMouseEvent::WebMouseEvent(const GdkEventMotion* event) { |
80 timestamp_sec = GdkEventTimeToWebEventTime(event->time); | 83 timestamp_sec = GdkEventTimeToWebEventTime(event->time); |
81 modifiers = GdkStateToWebEventModifiers(event->state); | 84 modifiers = GdkStateToWebEventModifiers(event->state); |
82 x = static_cast<int>(event->x); | 85 x = static_cast<int>(event->x); |
83 y = static_cast<int>(event->y); | 86 y = static_cast<int>(event->y); |
84 global_x = static_cast<int>(event->x_root); | 87 global_x = static_cast<int>(event->x_root); |
85 global_y = static_cast<int>(event->y_root); | 88 global_y = static_cast<int>(event->y_root); |
86 | 89 |
87 switch (event->type) { | 90 switch (event->type) { |
88 case GDK_MOTION_NOTIFY: | 91 case GDK_MOTION_NOTIFY: |
89 type = MOUSE_MOVE; | 92 type = MOUSE_MOVE; |
90 break; | 93 break; |
91 default: | 94 default: |
92 NOTREACHED(); | 95 ASSERT_NOT_REACHED(); |
93 } | 96 } |
94 | 97 |
95 button = BUTTON_NONE; | 98 button = BUTTON_NONE; |
96 if (event->state & GDK_BUTTON1_MASK) { | 99 if (event->state & GDK_BUTTON1_MASK) { |
97 button = BUTTON_LEFT; | 100 button = BUTTON_LEFT; |
98 } else if (event->state & GDK_BUTTON2_MASK) { | 101 } else if (event->state & GDK_BUTTON2_MASK) { |
99 button = BUTTON_MIDDLE; | 102 button = BUTTON_MIDDLE; |
100 } else if (event->state & GDK_BUTTON3_MASK) { | 103 } else if (event->state & GDK_BUTTON3_MASK) { |
101 button = BUTTON_RIGHT; | 104 button = BUTTON_RIGHT; |
102 } | 105 } |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
139 break; | 142 break; |
140 case GDK_SCROLL_RIGHT: | 143 case GDK_SCROLL_RIGHT: |
141 delta_x = kWheelDelta; | 144 delta_x = kWheelDelta; |
142 break; | 145 break; |
143 default: | 146 default: |
144 break; | 147 break; |
145 } | 148 } |
146 } | 149 } |
147 | 150 |
148 WebKeyboardEvent::WebKeyboardEvent(const GdkEventKey* event) { | 151 WebKeyboardEvent::WebKeyboardEvent(const GdkEventKey* event) { |
149 system_key = false; | |
150 modifiers = GdkStateToWebEventModifiers(event->state); | 152 modifiers = GdkStateToWebEventModifiers(event->state); |
151 | 153 |
| 154 // GDK only exposes key press and release events. By contrast, |
| 155 // WebKeyboardEvent matches Windows and wants key down/up events along with a |
| 156 // separate CHAR event. |
| 157 // We require the caller to simulate the CHAR event manually. See |
| 158 // test_shell's webwidget_host for an example. |
152 switch (event->type) { | 159 switch (event->type) { |
153 case GDK_KEY_RELEASE: | 160 case GDK_KEY_RELEASE: |
154 type = KEY_UP; | 161 type = KEY_UP; |
155 break; | 162 break; |
156 case GDK_KEY_PRESS: | 163 case GDK_KEY_PRESS: |
157 type = KEY_DOWN; | 164 type = KEY_DOWN; |
158 break; | 165 break; |
159 default: | 166 default: |
160 NOTREACHED(); | 167 NOTREACHED(); |
161 break; | 168 break; |
162 } | 169 } |
163 | 170 |
164 // The key code tells us which physical key was pressed (for example, the | 171 // The key code tells us which physical key was pressed (for example, the |
165 // A key went down or up). It does not determine whether A should be lower | 172 // A key went down or up). It does not determine whether A should be lower |
166 // or upper case. This is what text does, which should be the keyval. | 173 // or upper case. This is what text does, which should be the keyval. |
167 windows_key_code = WebCore::windowsKeyCodeForKeyEvent(event->keyval); | 174 key_code = WebCore::windowsKeyCodeForKeyEvent(event->keyval); |
168 native_key_code = event->hardware_keycode; | |
169 | |
170 memset(&text, 0, sizeof(text)); | |
171 memset(&unmodified_text, 0, sizeof(unmodified_text)); | |
172 memset(&key_identifier, 0, sizeof(key_identifier)); | |
173 | 175 |
174 switch (event->keyval) { | 176 switch (event->keyval) { |
175 // We need to treat the enter key as a key press of character \r. This | 177 // We need to treat the enter key as a key press of character \r. This |
176 // is apparently just how webkit handles it and what it expects. | 178 // is apparently just how webkit handles it and what it expects. |
177 case GDK_ISO_Enter: | 179 case GDK_ISO_Enter: |
178 case GDK_KP_Enter: | 180 case GDK_KP_Enter: |
179 case GDK_Return: | 181 case GDK_Return: |
180 unmodified_text[0] = text[0] = static_cast<char16>('\r'); | 182 text = '\r'; |
181 break; | 183 break; |
182 default: | 184 default: |
183 // This should set text to 0 when it's not a real character. | 185 // This should set text to 0 when it's not a real character. |
184 // TODO(avi): fix for non BMP chars | 186 text = gdk_keyval_to_unicode(event->keyval); |
185 unmodified_text[0] = text[0] = | |
186 static_cast<char16>(gdk_keyval_to_unicode(event->keyval)); | |
187 break; | 187 break; |
188 } | 188 } |
189 | 189 |
190 std::string key_identifier_str = | |
191 GetKeyIdentifierForWindowsKeyCode(windows_key_code); | |
192 base::strlcpy(key_identifier, key_identifier_str.c_str(), | |
193 kIdentifierLengthCap); | |
194 | |
195 // TODO(tc): Do we need to set IS_AUTO_REPEAT or IS_KEYPAD? | 190 // TODO(tc): Do we need to set IS_AUTO_REPEAT or IS_KEYPAD? |
196 } | 191 } |
OLD | NEW |