OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "views/events/event.h" | 5 #include "views/events/event.h" |
6 | 6 |
7 #include <gdk/gdk.h> | 7 #include <gdk/gdk.h> |
8 #include <gdk/gdkx.h> | 8 #include <gdk/gdkx.h> |
9 #include <X11/extensions/XInput2.h> | 9 #include <X11/extensions/XInput2.h> |
10 #include <X11/Xlib.h> | 10 #include <X11/Xlib.h> |
(...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
117 return ui::ET_TOUCH_RELEASED; | 117 return ui::ET_TOUCH_RELEASED; |
118 } | 118 } |
119 | 119 |
120 return ui::ET_TOUCH_MOVED; | 120 return ui::ET_TOUCH_MOVED; |
121 #endif | 121 #endif |
122 } | 122 } |
123 | 123 |
124 int GetTouchIDFromXEvent(XEvent* xev) { | 124 int GetTouchIDFromXEvent(XEvent* xev) { |
125 float id = 0; | 125 float id = 0; |
126 #if defined(USE_XI2_MT) | 126 #if defined(USE_XI2_MT) |
127 // TODO(ningxin.hu@gmail.com): Make the id always start from 0 for a new | 127 float tracking_id; |
128 // touch-sequence when TRACKING_ID is used to extract the touch id. | 128 TouchFactory* factory = TouchFactory::GetInstance(); |
129 TouchFactory::TouchParam tp = TouchFactory::TP_TRACKING_ID; | 129 if (factory->ExtractTouchParam( |
130 #else | 130 *xev, TouchFactory::TP_TRACKING_ID, &tracking_id)) |
sadrul
2011/09/19 16:13:36
4-space indent here and in line 137
ningxin.hu
2011/09/20 16:08:49
Will fix. Thanks.
| |
131 TouchFactory::TouchParam tp = TouchFactory::TP_SLOT_ID; | 131 id = factory->AllocateSlotIdForTrackingId(tracking_id); |
132 #endif | 132 else |
133 if (!TouchFactory::GetInstance()->ExtractTouchParam( | |
134 *xev, tp, &id)) | |
135 LOG(ERROR) << "Could not get the touch ID for the event. Using 0."; | 133 LOG(ERROR) << "Could not get the touch ID for the event. Using 0."; |
136 return id; | 134 return id; |
135 #else | |
136 if (!TouchFactory::GetInstance()->ExtractTouchParam( | |
137 *xev, TouchFactory::TP_SLOT_ID, &id)) | |
138 LOG(ERROR) << "Could not get the touch ID for the event. Using 0."; | |
139 return id; | |
140 #endif | |
137 } | 141 } |
138 | 142 |
139 ui::EventType EventTypeFromNative(NativeEvent2 native_event) { | 143 ui::EventType EventTypeFromNative(NativeEvent2 native_event) { |
140 switch (native_event->type) { | 144 switch (native_event->type) { |
141 case KeyPress: | 145 case KeyPress: |
142 return ui::ET_KEY_PRESSED; | 146 return ui::ET_KEY_PRESSED; |
143 case KeyRelease: | 147 case KeyRelease: |
144 return ui::ET_KEY_RELEASED; | 148 return ui::ET_KEY_RELEASED; |
145 case ButtonPress: | 149 case ButtonPress: |
146 if (native_event->xbutton.button == 4 || | 150 if (native_event->xbutton.button == 4 || |
(...skipping 270 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
417 radius_x_(GetTouchParamFromXEvent(native_event_2, | 421 radius_x_(GetTouchParamFromXEvent(native_event_2, |
418 TouchFactory::TP_TOUCH_MAJOR, | 422 TouchFactory::TP_TOUCH_MAJOR, |
419 2.0) / 2.0), | 423 2.0) / 2.0), |
420 radius_y_(GetTouchParamFromXEvent(native_event_2, | 424 radius_y_(GetTouchParamFromXEvent(native_event_2, |
421 TouchFactory::TP_TOUCH_MINOR, | 425 TouchFactory::TP_TOUCH_MINOR, |
422 2.0) / 2.0), | 426 2.0) / 2.0), |
423 rotation_angle_(GetTouchParamFromXEvent(native_event_2, | 427 rotation_angle_(GetTouchParamFromXEvent(native_event_2, |
424 TouchFactory::TP_ORIENTATION, | 428 TouchFactory::TP_ORIENTATION, |
425 0.0)), | 429 0.0)), |
426 force_(GetTouchForceFromXEvent(native_event_2)) { | 430 force_(GetTouchForceFromXEvent(native_event_2)) { |
427 #if !defined(USE_XI2_MT) | 431 #if defined(USE_XI2_MT) |
432 if (type() == ui::ET_TOUCH_RELEASED) { | |
433 TouchFactory* factory = TouchFactory::GetInstance(); | |
sadrul
2011/09/19 16:13:36
Please add a NOTE here explaining that for PRESSED
ningxin.hu
2011/09/20 16:08:49
Will do that. Thanks.
| |
434 float tracking_id; | |
435 if (factory->ExtractTouchParam(*native_event_2, | |
436 TouchFactory::TP_TRACKING_ID, | |
437 &tracking_id)) { | |
438 factory->ReleaseSlotIdForTrackingId(tracking_id); | |
439 } | |
440 } | |
441 #else | |
428 if (type() == ui::ET_TOUCH_PRESSED || type() == ui::ET_TOUCH_RELEASED) { | 442 if (type() == ui::ET_TOUCH_PRESSED || type() == ui::ET_TOUCH_RELEASED) { |
429 TouchFactory* factory = TouchFactory::GetInstance(); | 443 TouchFactory* factory = TouchFactory::GetInstance(); |
430 float slot; | 444 float slot; |
431 if (factory->ExtractTouchParam(*native_event_2, | 445 if (factory->ExtractTouchParam(*native_event_2, |
432 TouchFactory::TP_SLOT_ID, &slot)) { | 446 TouchFactory::TP_SLOT_ID, &slot)) { |
433 factory->SetSlotUsed(slot, type() == ui::ET_TOUCH_PRESSED); | 447 factory->SetSlotUsed(slot, type() == ui::ET_TOUCH_PRESSED); |
434 } | 448 } |
435 } | 449 } |
436 #endif | 450 #endif |
437 } | 451 } |
438 | 452 |
439 } // namespace views | 453 } // namespace views |
OLD | NEW |