Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "ash/wm/workspace/workspace_event_handler.h" | 5 #include "ash/wm/workspace/workspace_event_handler.h" |
| 6 | 6 |
| 7 #include "ash/metrics/user_metrics_recorder.h" | 7 #include "ash/metrics/user_metrics_recorder.h" |
| 8 #include "ash/shell.h" | 8 #include "ash/shell.h" |
| 9 #include "ash/touch/touch_uma.h" | 9 #include "ash/touch/touch_uma.h" |
| 10 #include "ash/wm/window_state.h" | 10 #include "ash/wm/window_state.h" |
| 11 #include "ash/wm/wm_event.h" | 11 #include "ash/wm/wm_event.h" |
| 12 #include "ui/aura/window.h" | 12 #include "ui/aura/window.h" |
| 13 #include "ui/aura/window_delegate.h" | 13 #include "ui/aura/window_delegate.h" |
| 14 #include "ui/base/hit_test.h" | 14 #include "ui/base/hit_test.h" |
| 15 | 15 |
| 16 namespace ash { | 16 namespace ash { |
| 17 namespace internal { | 17 namespace internal { |
| 18 | 18 |
| 19 WorkspaceEventHandler::WorkspaceEventHandler() { | 19 WorkspaceEventHandler::WorkspaceEventHandler() |
| 20 : event_target_component_(HTNOWHERE) { | |
| 20 } | 21 } |
| 21 | 22 |
| 22 WorkspaceEventHandler::~WorkspaceEventHandler() { | 23 WorkspaceEventHandler::~WorkspaceEventHandler() { |
| 23 } | 24 } |
| 24 | 25 |
| 25 void WorkspaceEventHandler::OnMouseEvent(ui::MouseEvent* event) { | 26 void WorkspaceEventHandler::OnMouseEvent(ui::MouseEvent* event) { |
| 26 if (event->handled()) | 27 if (event->handled()) |
| 27 return; | 28 return; |
| 28 aura::Window* target = static_cast<aura::Window*>(event->target()); | 29 aura::Window* target = static_cast<aura::Window*>(event->target()); |
| 29 switch (event->type()) { | 30 switch (event->type()) { |
| 30 case ui::ET_MOUSE_MOVED: { | 31 case ui::ET_MOUSE_MOVED: { |
| 31 int component = | 32 int component = |
| 32 target->delegate()->GetNonClientComponent(event->location()); | 33 target->delegate()->GetNonClientComponent(event->location()); |
| 33 multi_window_resize_controller_.Show(target, component, | 34 multi_window_resize_controller_.Show(target, component, |
| 34 event->location()); | 35 event->location()); |
| 35 break; | 36 break; |
| 36 } | 37 } |
| 37 case ui::ET_MOUSE_ENTERED: | 38 case ui::ET_MOUSE_ENTERED: |
| 38 break; | 39 break; |
| 39 case ui::ET_MOUSE_CAPTURE_CHANGED: | 40 case ui::ET_MOUSE_CAPTURE_CHANGED: |
| 40 case ui::ET_MOUSE_EXITED: | 41 case ui::ET_MOUSE_EXITED: |
| 41 break; | 42 break; |
| 42 case ui::ET_MOUSE_PRESSED: { | 43 case ui::ET_MOUSE_PRESSED: { |
| 43 wm::WindowState* target_state = wm::GetWindowState(target); | 44 wm::WindowState* target_state = wm::GetWindowState(target); |
| 45 int previous_target_component = event_target_component_; | |
| 46 event_target_component_ = target->delegate()-> | |
| 47 GetNonClientComponent(event->location()); | |
|
varkha
2014/04/03 04:13:21
Does this logic allow a right-click to "pollute" t
flackr
2014/04/04 18:51:45
As long as we're consistent with the use of the va
jonross
2014/04/07 15:49:30
Using a mouse for input I wasn't able to get a sta
jonross
2014/04/07 15:49:30
Done.
jonross
2014/04/07 15:49:30
Done.
| |
| 44 if (event->flags() & ui::EF_IS_DOUBLE_CLICK && | 48 if (event->flags() & ui::EF_IS_DOUBLE_CLICK && |
| 45 event->IsOnlyLeftMouseButton() && | 49 event->IsOnlyLeftMouseButton() && |
| 46 target->delegate()->GetNonClientComponent(event->location()) == | 50 event_target_component_ == HTCAPTION && |
| 47 HTCAPTION) { | 51 event_target_component_ == previous_target_component) { |
|
varkha
2014/04/03 04:13:21
Once here you probably want to reset the event_tar
jonross
2014/04/07 15:49:30
Since WindowEventHandler can receive each event up
| |
| 48 ash::Shell::GetInstance()->metrics()->RecordUserMetricsAction( | 52 ash::Shell::GetInstance()->metrics()->RecordUserMetricsAction( |
| 49 ash::UMA_TOGGLE_MAXIMIZE_CAPTION_CLICK); | 53 ash::UMA_TOGGLE_MAXIMIZE_CAPTION_CLICK); |
| 50 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_MAXIMIZE_CAPTION); | 54 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_MAXIMIZE_CAPTION); |
| 51 target_state->OnWMEvent(&wm_event); | 55 target_state->OnWMEvent(&wm_event); |
| 52 event->StopPropagation(); | 56 event->StopPropagation(); |
| 53 } | 57 } |
| 54 multi_window_resize_controller_.Hide(); | 58 multi_window_resize_controller_.Hide(); |
| 55 HandleVerticalResizeDoubleClick(target_state, event); | 59 HandleVerticalResizeDoubleClick(target_state, event); |
| 56 break; | 60 break; |
| 57 } | 61 } |
| 58 default: | 62 default: |
| 59 break; | 63 break; |
| 60 } | 64 } |
| 61 } | 65 } |
| 62 | 66 |
| 63 void WorkspaceEventHandler::OnGestureEvent(ui::GestureEvent* event) { | 67 void WorkspaceEventHandler::OnGestureEvent(ui::GestureEvent* event) { |
| 64 if (event->handled()) | 68 if (event->handled()) |
| 65 return; | 69 return; |
| 66 aura::Window* target = static_cast<aura::Window*>(event->target()); | 70 aura::Window* target = static_cast<aura::Window*>(event->target()); |
| 67 if (event->type() == ui::ET_GESTURE_TAP && | 71 if (event->type() == ui::ET_GESTURE_TAP) { |
|
varkha
2014/04/03 04:13:21
I think this method would benefit from early exits
jonross
2014/04/07 15:49:30
Done.
| |
| 68 target->delegate()->GetNonClientComponent(event->location()) == | 72 int previous_target_component = event_target_component_; |
| 69 HTCAPTION) { | 73 event_target_component_ = target->delegate()-> |
| 70 if (event->details().tap_count() == 2) { | 74 GetNonClientComponent(event->location()); |
| 71 ash::Shell::GetInstance()->metrics()->RecordUserMetricsAction( | 75 if (event_target_component_ == HTCAPTION) { |
| 72 ash::UMA_TOGGLE_MAXIMIZE_CAPTION_GESTURE); | 76 if (event->details().tap_count() == 2 && |
| 73 // Note: TouchUMA::GESTURE_FRAMEVIEW_TAP is counted twice each time | 77 event_target_component_ == previous_target_component) { |
| 74 // TouchUMA::GESTURE_MAXIMIZE_DOUBLETAP is counted once. | 78 ash::Shell::GetInstance()->metrics()->RecordUserMetricsAction( |
| 75 TouchUMA::GetInstance()->RecordGestureAction( | 79 ash::UMA_TOGGLE_MAXIMIZE_CAPTION_GESTURE); |
| 76 TouchUMA::GESTURE_MAXIMIZE_DOUBLETAP); | 80 // Note: TouchUMA::GESTURE_FRAMEVIEW_TAP is counted twice each time |
| 77 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_MAXIMIZE_CAPTION); | 81 // TouchUMA::GESTURE_MAXIMIZE_DOUBLETAP is counted once. |
| 78 wm::GetWindowState(target)->OnWMEvent(&wm_event); | 82 TouchUMA::GetInstance()->RecordGestureAction( |
| 79 event->StopPropagation(); | 83 TouchUMA::GESTURE_MAXIMIZE_DOUBLETAP); |
| 80 return; | 84 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_MAXIMIZE_CAPTION); |
| 81 } else { | 85 wm::GetWindowState(target)->OnWMEvent(&wm_event); |
| 82 // Note: TouchUMA::GESTURE_FRAMEVIEW_TAP is counted twice for each tap. | 86 event->StopPropagation(); |
| 83 TouchUMA::GetInstance()->RecordGestureAction( | 87 return; |
| 84 TouchUMA::GESTURE_FRAMEVIEW_TAP); | 88 } else { |
|
varkha
2014/04/03 04:13:21
Should be no need for else after return.
flackr
2014/04/04 18:51:45
In fact, explicitly forbidden by style guide: http
jonross
2014/04/07 15:49:30
Done.
| |
| 89 // Note: TouchUMA::GESTURE_FRAMEVIEW_TAP is counted twice for each tap. | |
| 90 TouchUMA::GetInstance()->RecordGestureAction( | |
| 91 TouchUMA::GESTURE_FRAMEVIEW_TAP); | |
| 92 } | |
| 85 } | 93 } |
| 86 } | 94 } |
| 87 } | 95 } |
| 88 | 96 |
| 89 void WorkspaceEventHandler::HandleVerticalResizeDoubleClick( | 97 void WorkspaceEventHandler::HandleVerticalResizeDoubleClick( |
| 90 wm::WindowState* target_state, | 98 wm::WindowState* target_state, |
| 91 ui::MouseEvent* event) { | 99 ui::MouseEvent* event) { |
| 92 aura::Window* target = target_state->window(); | 100 aura::Window* target = target_state->window(); |
| 93 if (event->flags() & ui::EF_IS_DOUBLE_CLICK) { | 101 if (event->flags() & ui::EF_IS_DOUBLE_CLICK) { |
| 94 int component = | 102 int component = |
| 95 target->delegate()->GetNonClientComponent(event->location()); | 103 target->delegate()->GetNonClientComponent(event->location()); |
| 96 if (component == HTBOTTOM || component == HTTOP) { | 104 if (component == HTBOTTOM || component == HTTOP) { |
| 97 Shell::GetInstance()->metrics()->RecordUserMetricsAction( | 105 Shell::GetInstance()->metrics()->RecordUserMetricsAction( |
| 98 UMA_TOGGLE_SINGLE_AXIS_MAXIMIZE_BORDER_CLICK); | 106 UMA_TOGGLE_SINGLE_AXIS_MAXIMIZE_BORDER_CLICK); |
| 99 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_VERTICAL_MAXIMIZE); | 107 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_VERTICAL_MAXIMIZE); |
| 100 target_state->OnWMEvent(&wm_event); | 108 target_state->OnWMEvent(&wm_event); |
| 101 event->StopPropagation(); | 109 event->StopPropagation(); |
| 102 } else if (component == HTLEFT || component == HTRIGHT) { | 110 } else if (component == HTLEFT || component == HTRIGHT) { |
| 103 Shell::GetInstance()->metrics()->RecordUserMetricsAction( | 111 Shell::GetInstance()->metrics()->RecordUserMetricsAction( |
| 104 UMA_TOGGLE_SINGLE_AXIS_MAXIMIZE_BORDER_CLICK); | 112 UMA_TOGGLE_SINGLE_AXIS_MAXIMIZE_BORDER_CLICK); |
| 105 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_HORIZONTAL_MAXIMIZE); | 113 const wm::WMEvent wm_event(wm::WM_EVENT_TOGGLE_HORIZONTAL_MAXIMIZE); |
| 106 target_state->OnWMEvent(&wm_event); | 114 target_state->OnWMEvent(&wm_event); |
| 107 event->StopPropagation(); | 115 event->StopPropagation(); |
| 108 } | 116 } |
| 109 } | 117 } |
| 110 } | 118 } |
| 111 | 119 |
| 112 } // namespace internal | 120 } // namespace internal |
| 113 } // namespace ash | 121 } // namespace ash |
| OLD | NEW |