OLD | NEW |
| (Empty) |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "ui/views/controls/menu/menu_event_dispatcher.h" | |
6 | |
7 #include "base/memory/scoped_ptr.h" | |
8 #include "ui/aura/window.h" | |
9 #include "ui/events/event_utils.h" | |
10 #include "ui/events/keycodes/keyboard_code_conversion.h" | |
11 #include "ui/events/keycodes/keyboard_codes.h" | |
12 #include "ui/views/controls/menu/menu_controller.h" | |
13 #include "ui/views/widget/widget.h" | |
14 | |
15 namespace views { | |
16 namespace internal { | |
17 | |
18 MenuEventDispatcher::MenuEventDispatcher(MenuController* controller) | |
19 : menu_controller_(controller) {} | |
20 | |
21 MenuEventDispatcher::~MenuEventDispatcher() {} | |
22 | |
23 bool MenuEventDispatcher::CanDispatchEvent(const ui::PlatformEvent& event) { | |
24 return true; | |
25 } | |
26 | |
27 uint32_t MenuEventDispatcher::DispatchEvent(const ui::PlatformEvent& event) { | |
28 bool should_perform_default = true; | |
29 bool should_process_event = true; | |
30 | |
31 // Check if the event should be handled. | |
32 scoped_ptr<ui::Event> ui_event(ui::EventFromNative(event)); | |
33 if (ui_event && menu_controller_->owner()) { | |
34 aura::Window* menu_window = menu_controller_->owner()->GetNativeWindow(); | |
35 aura::Window* target_window = static_cast<aura::Window*>( | |
36 static_cast<ui::EventTarget*>(menu_window->GetRootWindow())-> | |
37 GetEventTargeter()->FindTargetForEvent(menu_window, | |
38 ui_event.get())); | |
39 // TODO(flackr): The event shouldn't be handled if target_window is not | |
40 // menu_window, however the event targeter does not properly target the | |
41 // open menu. For now, we allow targeters to prevent handling by the menu. | |
42 if (!target_window) | |
43 should_process_event = false; | |
44 } | |
45 | |
46 if (menu_controller_->exit_type() != MenuController::EXIT_ALL && | |
47 menu_controller_->exit_type() != MenuController::EXIT_DESTROYED && | |
48 ui_event && should_process_event) { | |
49 switch (ui_event->type()) { | |
50 case ui::ET_KEY_PRESSED: { | |
51 should_perform_default = false; | |
52 | |
53 ui::KeyEvent* key_event = static_cast<ui::KeyEvent*>(ui_event.get()); | |
54 menu_controller_->OnKeyDown(key_event->key_code()); | |
55 if (menu_controller_->exit_type() != MenuController::EXIT_NONE) | |
56 break; | |
57 | |
58 // Do not check mnemonics if the Alt or Ctrl modifiers are pressed. | |
59 int flags = key_event->flags(); | |
60 if ((flags & (ui::EF_CONTROL_DOWN | ui::EF_ALT_DOWN)) == 0) { | |
61 char c = ui::DomCodeToUsLayoutCharacter(key_event->code(), flags); | |
62 menu_controller_->SelectByChar(c); | |
63 } | |
64 break; | |
65 } | |
66 case ui::ET_KEY_RELEASED: | |
67 should_perform_default = false; | |
68 break; | |
69 case ui::ET_TOUCH_RELEASED: | |
70 case ui::ET_TOUCH_CANCELLED: | |
71 // Don't allow the event copy to clear the native touch id | |
72 // mapping, or we'll lose the mapping before the initial event | |
73 // has finished being dispatched. | |
74 static_cast<ui::TouchEvent*>(ui_event.get()) | |
75 ->set_should_remove_native_touch_id_mapping(false); | |
76 break; | |
77 default: | |
78 break; | |
79 } | |
80 } | |
81 | |
82 menu_controller_->TerminateNestedMessageLoopIfNecessary(); | |
83 | |
84 return should_perform_default ? ui::POST_DISPATCH_PERFORM_DEFAULT | |
85 : ui::POST_DISPATCH_NONE; | |
86 } | |
87 | |
88 } // namespace internal | |
89 } // namespace views | |
OLD | NEW |