Index: ui/events/event_utils.cc |
diff --git a/ui/events/event_utils.cc b/ui/events/event_utils.cc |
index db6215f4654a56ae3da013c96f672002fff8b812..1b3d7a9301db28bef028a3d0e0a00cbf6ba431f7 100644 |
--- a/ui/events/event_utils.cc |
+++ b/ui/events/event_utils.cc |
@@ -8,52 +8,57 @@ |
#include "ui/events/event.h" |
#include "ui/gfx/display.h" |
+#include "ui/gfx/screen.h" |
namespace ui { |
-// From third_party/WebKit/Source/web/gtk/WebInputEventFactory.cpp: |
-base::char16 GetControlCharacterForKeycode(int windows_key_code, bool shift) { |
- if (windows_key_code >= ui::VKEY_A && |
- windows_key_code <= ui::VKEY_Z) { |
- // ctrl-A ~ ctrl-Z map to \x01 ~ \x1A |
- return windows_key_code - ui::VKEY_A + 1; |
- } |
- if (shift) { |
- // following graphics chars require shift key to input. |
- switch (windows_key_code) { |
- // ctrl-@ maps to \x00 (Null byte) |
- case ui::VKEY_2: |
- return 0; |
- // ctrl-^ maps to \x1E (Record separator, Information separator two) |
- case ui::VKEY_6: |
- return 0x1E; |
- // ctrl-_ maps to \x1F (Unit separator, Information separator one) |
- case ui::VKEY_OEM_MINUS: |
- return 0x1F; |
- // Returns 0 for all other keys to avoid inputting unexpected chars. |
- default: |
- break; |
- } |
- } else { |
- switch (windows_key_code) { |
- // ctrl-[ maps to \x1B (Escape) |
- case ui::VKEY_OEM_4: |
- return 0x1B; |
- // ctrl-\ maps to \x1C (File separator, Information separator four) |
- case ui::VKEY_OEM_5: |
- return 0x1C; |
- // ctrl-] maps to \x1D (Group separator, Information separator three) |
- case ui::VKEY_OEM_6: |
- return 0x1D; |
- // ctrl-Enter maps to \x0A (Line feed) |
- case ui::VKEY_RETURN: |
- return 0x0A; |
- // Returns 0 for all other keys to avoid inputting unexpected chars. |
- default: |
- break; |
- } |
+namespace { |
+int g_custom_event_types = ET_LAST; |
+} // namespace |
+ |
+scoped_ptr<Event> EventFromNative(const base::NativeEvent& native_event) { |
+ scoped_ptr<Event> event; |
+ EventType type = EventTypeFromNative(native_event); |
+ switch(type) { |
+ case ET_KEY_PRESSED: |
+ case ET_KEY_RELEASED: |
+ event.reset(new KeyEvent(native_event)); |
+ break; |
+ |
+ case ET_MOUSE_PRESSED: |
+ case ET_MOUSE_DRAGGED: |
+ case ET_MOUSE_RELEASED: |
+ case ET_MOUSE_MOVED: |
+ case ET_MOUSE_ENTERED: |
+ case ET_MOUSE_EXITED: |
+ event.reset(new MouseEvent(native_event)); |
+ break; |
+ |
+ case ET_MOUSEWHEEL: |
+ event.reset(new MouseWheelEvent(native_event)); |
+ break; |
+ |
+ case ET_SCROLL_FLING_START: |
+ case ET_SCROLL_FLING_CANCEL: |
+ case ET_SCROLL: |
+ event.reset(new ScrollEvent(native_event)); |
+ break; |
+ |
+ case ET_TOUCH_RELEASED: |
+ case ET_TOUCH_PRESSED: |
+ case ET_TOUCH_MOVED: |
+ case ET_TOUCH_CANCELLED: |
+ event.reset(new TouchEvent(native_event)); |
+ break; |
+ |
+ default: |
+ break; |
} |
- return 0; |
+ return event.Pass(); |
+} |
+ |
+int RegisterCustomEventType() { |
+ return ++g_custom_event_types; |
} |
base::TimeDelta EventTimeForNow() { |
@@ -61,4 +66,23 @@ base::TimeDelta EventTimeForNow() { |
base::TimeTicks::Now().ToInternalValue()); |
} |
+bool ShouldDefaultToNaturalScroll() { |
+ return GetInternalDisplayTouchSupport() == |
+ gfx::Display::TOUCH_SUPPORT_AVAILABLE; |
+} |
+ |
+gfx::Display::TouchSupport GetInternalDisplayTouchSupport() { |
+ gfx::Screen* screen = gfx::Screen::GetScreenByType(gfx::SCREEN_TYPE_NATIVE); |
+ // No screen in some unit tests. |
+ if (!screen) |
+ return gfx::Display::TOUCH_SUPPORT_UNKNOWN; |
+ const std::vector<gfx::Display>& displays = screen->GetAllDisplays(); |
+ for (std::vector<gfx::Display>::const_iterator it = displays.begin(); |
+ it != displays.end(); ++it) { |
+ if (it->IsInternal()) |
+ return it->touch_support(); |
+ } |
+ return gfx::Display::TOUCH_SUPPORT_UNAVAILABLE; |
+} |
+ |
} // namespace ui |