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

Side by Side Diff: ash/wm/workspace/workspace_event_handler.cc

Issue 222203006: Prevents double-clicks on a tab close button from aslo maximizing the browser (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 8 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
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 "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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698