Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(56)

Side by Side Diff: ui/events/event_utils.cc

Issue 284903002: Only dispatch menu events if they have a valid target. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Add test MenuControllerTest.EventTargeter Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "ui/events/event_utils.h" 5 #include "ui/events/event_utils.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "ui/events/event.h" 9 #include "ui/events/event.h"
10 #include "ui/gfx/display.h" 10 #include "ui/gfx/display.h"
11 #include "ui/gfx/screen.h" 11 #include "ui/gfx/screen.h"
12 12
13 namespace ui { 13 namespace ui {
14 14
15 namespace { 15 namespace {
16 int g_custom_event_types = ET_LAST; 16 int g_custom_event_types = ET_LAST;
17 } // namespace 17 } // namespace
18 18
19 scoped_ptr<Event> EventFromNative(const base::NativeEvent& native_event) {
20 scoped_ptr<Event> event;
21 EventType type = EventTypeFromNative(native_event);
22 switch(type) {
23 case ET_KEY_PRESSED:
24 case ET_KEY_RELEASED:
25 event.reset(new KeyEvent(native_event, false));
26 break;
27
28 case ET_TRANSLATED_KEY_PRESS:
29 case ET_TRANSLATED_KEY_RELEASE:
30 event.reset(new TranslatedKeyEvent(native_event, false));
sadrul 2014/05/15 21:53:01 I think this should be a NOTREACHED() (the transla
flackr 2014/05/15 22:13:01 Done.
31 break;
32
33 case ET_MOUSE_PRESSED:
34 case ET_MOUSE_DRAGGED:
35 case ET_MOUSE_RELEASED:
36 case ET_MOUSE_MOVED:
37 case ET_MOUSE_ENTERED:
38 case ET_MOUSE_EXITED:
39 event.reset(new MouseEvent(native_event));
40 break;
41
42 case ET_MOUSEWHEEL:
43 event.reset(new MouseWheelEvent(native_event));
44 break;
45
46 case ET_SCROLL_FLING_START:
47 case ET_SCROLL_FLING_CANCEL:
48 case ET_SCROLL:
49 event.reset(new ScrollEvent(native_event));
50 break;
51
52 case ET_TOUCH_RELEASED:
53 case ET_TOUCH_PRESSED:
54 case ET_TOUCH_MOVED:
55 case ET_TOUCH_CANCELLED:
56 event.reset(new TouchEvent(native_event));
57 break;
58
59 default:
60 break;
61 }
62 return event.Pass();
63 }
64
19 int RegisterCustomEventType() { 65 int RegisterCustomEventType() {
20 return ++g_custom_event_types; 66 return ++g_custom_event_types;
21 } 67 }
22 68
23 base::TimeDelta EventTimeForNow() { 69 base::TimeDelta EventTimeForNow() {
24 return base::TimeDelta::FromInternalValue( 70 return base::TimeDelta::FromInternalValue(
25 base::TimeTicks::Now().ToInternalValue()); 71 base::TimeTicks::Now().ToInternalValue());
26 } 72 }
27 73
28 bool ShouldDefaultToNaturalScroll() { 74 bool ShouldDefaultToNaturalScroll() {
29 return GetInternalDisplayTouchSupport() == 75 return GetInternalDisplayTouchSupport() ==
30 gfx::Display::TOUCH_SUPPORT_AVAILABLE; 76 gfx::Display::TOUCH_SUPPORT_AVAILABLE;
31 } 77 }
32 78
33 gfx::Display::TouchSupport GetInternalDisplayTouchSupport() { 79 gfx::Display::TouchSupport GetInternalDisplayTouchSupport() {
34 gfx::Screen* screen = gfx::Screen::GetScreenByType(gfx::SCREEN_TYPE_NATIVE); 80 gfx::Screen* screen = gfx::Screen::GetScreenByType(gfx::SCREEN_TYPE_NATIVE);
35 // No screen in some unit tests. 81 // No screen in some unit tests.
36 if (!screen) 82 if (!screen)
37 return gfx::Display::TOUCH_SUPPORT_UNKNOWN; 83 return gfx::Display::TOUCH_SUPPORT_UNKNOWN;
38 const std::vector<gfx::Display>& displays = screen->GetAllDisplays(); 84 const std::vector<gfx::Display>& displays = screen->GetAllDisplays();
39 for (std::vector<gfx::Display>::const_iterator it = displays.begin(); 85 for (std::vector<gfx::Display>::const_iterator it = displays.begin();
40 it != displays.end(); ++it) { 86 it != displays.end(); ++it) {
41 if (it->IsInternal()) 87 if (it->IsInternal())
42 return it->touch_support(); 88 return it->touch_support();
43 } 89 }
44 return gfx::Display::TOUCH_SUPPORT_UNAVAILABLE; 90 return gfx::Display::TOUCH_SUPPORT_UNAVAILABLE;
45 } 91 }
46 92
47 } // namespace ui 93 } // namespace ui
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698