OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 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 "ash/accelerators/accelerator_delegate.h" | 5 #include "ash/accelerators/accelerator_delegate.h" |
6 | 6 |
7 #include "ash/common/accelerators/accelerator_controller.h" | 7 #include "ash/common/accelerators/accelerator_controller.h" |
8 #include "ash/common/wm/window_state.h" | 8 #include "ash/common/wm/window_state.h" |
9 #include "ash/common/wm_shell.h" | 9 #include "ash/common/wm_shell.h" |
10 #include "ash/shell.h" | 10 #include "ash/shell.h" |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
47 bool AcceleratorDelegate::ProcessAccelerator( | 47 bool AcceleratorDelegate::ProcessAccelerator( |
48 const ui::KeyEvent& key_event, | 48 const ui::KeyEvent& key_event, |
49 const ui::Accelerator& accelerator) { | 49 const ui::Accelerator& accelerator) { |
50 // Special hardware keys like brightness and volume are handled in | 50 // Special hardware keys like brightness and volume are handled in |
51 // special way. However, some windows can override this behavior | 51 // special way. However, some windows can override this behavior |
52 // (e.g. Chrome v1 apps by default and Chrome v2 apps with | 52 // (e.g. Chrome v1 apps by default and Chrome v2 apps with |
53 // permission) by setting a window property. | 53 // permission) by setting a window property. |
54 if (IsSystemKey(key_event.key_code()) && !CanConsumeSystemKeys(key_event)) { | 54 if (IsSystemKey(key_event.key_code()) && !CanConsumeSystemKeys(key_event)) { |
55 // System keys are always consumed regardless of whether they trigger an | 55 // System keys are always consumed regardless of whether they trigger an |
56 // accelerator to prevent windows from seeing unexpected key up events. | 56 // accelerator to prevent windows from seeing unexpected key up events. |
57 Shell::GetInstance()->accelerator_controller()->Process(accelerator); | 57 WmShell::Get()->accelerator_controller()->Process(accelerator); |
58 return true; | 58 return true; |
59 } | 59 } |
60 if (!ShouldProcessAcceleratorNow(key_event, accelerator)) | 60 if (!ShouldProcessAcceleratorNow(key_event, accelerator)) |
61 return false; | 61 return false; |
62 return Shell::GetInstance()->accelerator_controller()->Process(accelerator); | 62 return WmShell::Get()->accelerator_controller()->Process(accelerator); |
63 } | 63 } |
64 | 64 |
65 // Uses the top level window so if the target is a web contents window the | 65 // Uses the top level window so if the target is a web contents window the |
66 // containing parent window will be checked for the property. | 66 // containing parent window will be checked for the property. |
67 bool AcceleratorDelegate::CanConsumeSystemKeys(const ui::KeyEvent& event) { | 67 bool AcceleratorDelegate::CanConsumeSystemKeys(const ui::KeyEvent& event) { |
68 aura::Window* target = static_cast<aura::Window*>(event.target()); | 68 aura::Window* target = static_cast<aura::Window*>(event.target()); |
69 DCHECK(target); | 69 DCHECK(target); |
70 aura::Window* top_level = ::wm::GetToplevelWindow(target); | 70 aura::Window* top_level = ::wm::GetToplevelWindow(target); |
71 return top_level && wm::GetWindowState(top_level)->can_consume_system_keys(); | 71 return top_level && wm::GetWindowState(top_level)->can_consume_system_keys(); |
72 } | 72 } |
(...skipping 10 matching lines...) Expand all Loading... |
83 | 83 |
84 aura::Window* target = static_cast<aura::Window*>(event.target()); | 84 aura::Window* target = static_cast<aura::Window*>(event.target()); |
85 DCHECK(target); | 85 DCHECK(target); |
86 | 86 |
87 aura::Window::Windows root_windows = Shell::GetAllRootWindows(); | 87 aura::Window::Windows root_windows = Shell::GetAllRootWindows(); |
88 if (std::find(root_windows.begin(), root_windows.end(), target) != | 88 if (std::find(root_windows.begin(), root_windows.end(), target) != |
89 root_windows.end()) | 89 root_windows.end()) |
90 return true; | 90 return true; |
91 | 91 |
92 aura::Window* top_level = ::wm::GetToplevelWindow(target); | 92 aura::Window* top_level = ::wm::GetToplevelWindow(target); |
93 Shell* shell = Shell::GetInstance(); | 93 AcceleratorController* accelerator_controller = |
| 94 WmShell::Get()->accelerator_controller(); |
94 | 95 |
95 // Reserved accelerators (such as Power button) always have a prority. | 96 // Reserved accelerators (such as Power button) always have a prority. |
96 if (shell->accelerator_controller()->IsReserved(accelerator)) | 97 if (accelerator_controller->IsReserved(accelerator)) |
97 return true; | 98 return true; |
98 | 99 |
99 // A full screen window has a right to handle all key events including the | 100 // A full screen window has a right to handle all key events including the |
100 // reserved ones. | 101 // reserved ones. |
101 if (top_level && wm::GetWindowState(top_level)->IsFullscreen()) { | 102 if (top_level && wm::GetWindowState(top_level)->IsFullscreen()) { |
102 // On ChromeOS, fullscreen windows are either browser or apps, which | 103 // On ChromeOS, fullscreen windows are either browser or apps, which |
103 // send key events to a web content first, then will process keys | 104 // send key events to a web content first, then will process keys |
104 // if the web content didn't consume them. | 105 // if the web content didn't consume them. |
105 return false; | 106 return false; |
106 } | 107 } |
107 | 108 |
108 // Handle preferred accelerators (such as ALT-TAB) before sending | 109 // Handle preferred accelerators (such as ALT-TAB) before sending |
109 // to the target. | 110 // to the target. |
110 if (shell->accelerator_controller()->IsPreferred(accelerator)) | 111 if (accelerator_controller->IsPreferred(accelerator)) |
111 return true; | 112 return true; |
112 | 113 |
113 return WmShell::Get()->GetAppListTargetVisibility(); | 114 return WmShell::Get()->GetAppListTargetVisibility(); |
114 } | 115 } |
115 | 116 |
116 } // namespace ash | 117 } // namespace ash |
OLD | NEW |