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

Side by Side Diff: content/browser/renderer_host/render_widget_host_input_event_router.cc

Issue 2592243002: Perform direct routing of mouse events when the pointer is locked. (Closed)
Patch Set: addressing comments Created 3 years, 10 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "content/browser/renderer_host/render_widget_host_input_event_router.h" 5 #include "content/browser/renderer_host/render_widget_host_input_event_router.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/metrics/histogram_macros.h" 9 #include "base/metrics/histogram_macros.h"
10 10
(...skipping 155 matching lines...) Expand 10 before | Expand all | Expand 10 after
166 if (iter == owner_map_.end()) 166 if (iter == owner_map_.end())
167 return root_view; 167 return root_view;
168 168
169 return iter->second; 169 return iter->second;
170 } 170 }
171 171
172 void RenderWidgetHostInputEventRouter::RouteMouseEvent( 172 void RenderWidgetHostInputEventRouter::RouteMouseEvent(
173 RenderWidgetHostViewBase* root_view, 173 RenderWidgetHostViewBase* root_view,
174 blink::WebMouseEvent* event, 174 blink::WebMouseEvent* event,
175 const ui::LatencyInfo& latency) { 175 const ui::LatencyInfo& latency) {
176 RenderWidgetHostViewBase* target; 176 RenderWidgetHostViewBase* target = nullptr;
177 gfx::Point transformed_point; 177 gfx::Point transformed_point;
178
179 // When the mouse is locked, directly route the events to the widget that
180 // holds the lock and return.
181 if (root_view->IsMouseLocked()) {
182 target = RenderWidgetHostImpl::From(root_view->GetRenderWidgetHost())
183 ->delegate()
184 ->GetMouseLockWidget()
185 ->GetView();
186 if (!root_view->TransformPointToCoordSpaceForView(
187 gfx::Point(event->x, event->y), target, &transformed_point))
188 return;
189
190 event->x = transformed_point.x();
191 event->y = transformed_point.y();
192 target->ProcessMouseEvent(*event, latency);
193 return;
194 }
195
178 const int mouse_button_modifiers = blink::WebInputEvent::LeftButtonDown | 196 const int mouse_button_modifiers = blink::WebInputEvent::LeftButtonDown |
179 blink::WebInputEvent::MiddleButtonDown | 197 blink::WebInputEvent::MiddleButtonDown |
180 blink::WebInputEvent::RightButtonDown; 198 blink::WebInputEvent::RightButtonDown;
181 if (mouse_capture_target_.target && 199 if (mouse_capture_target_.target &&
182 event->type() != blink::WebInputEvent::MouseDown && 200 event->type() != blink::WebInputEvent::MouseDown &&
183 (event->type() == blink::WebInputEvent::MouseUp || 201 (event->type() == blink::WebInputEvent::MouseUp ||
184 event->modifiers() & mouse_button_modifiers)) { 202 event->modifiers() & mouse_button_modifiers)) {
185 target = mouse_capture_target_.target; 203 target = mouse_capture_target_.target;
186 if (!root_view->TransformPointToCoordSpaceForView( 204 if (!root_view->TransformPointToCoordSpaceForView(
187 gfx::Point(event->x, event->y), target, &transformed_point)) 205 gfx::Point(event->x, event->y), target, &transformed_point))
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after
240 258
241 event->x = transformed_point.x(); 259 event->x = transformed_point.x();
242 event->y = transformed_point.y(); 260 event->y = transformed_point.y();
243 target->ProcessMouseEvent(*event, latency); 261 target->ProcessMouseEvent(*event, latency);
244 } 262 }
245 263
246 void RenderWidgetHostInputEventRouter::RouteMouseWheelEvent( 264 void RenderWidgetHostInputEventRouter::RouteMouseWheelEvent(
247 RenderWidgetHostViewBase* root_view, 265 RenderWidgetHostViewBase* root_view,
248 blink::WebMouseWheelEvent* event, 266 blink::WebMouseWheelEvent* event,
249 const ui::LatencyInfo& latency) { 267 const ui::LatencyInfo& latency) {
268 if (root_view->IsMouseLocked()) {
269 RenderWidgetHostImpl::From(root_view->GetRenderWidgetHost())
270 ->delegate()
271 ->GetMouseLockWidget()
272 ->GetView()
273 ->ProcessMouseEvent(*event, latency);
274 return;
275 }
276
250 gfx::Point transformed_point; 277 gfx::Point transformed_point;
251 RenderWidgetHostViewBase* target = FindEventTarget( 278 RenderWidgetHostViewBase* target = FindEventTarget(
252 root_view, gfx::Point(event->x, event->y), &transformed_point); 279 root_view, gfx::Point(event->x, event->y), &transformed_point);
253 if (!target) 280 if (!target)
254 return; 281 return;
255 282
256 event->x = transformed_point.x(); 283 event->x = transformed_point.x();
257 event->y = transformed_point.y(); 284 event->y = transformed_point.y();
258 target->ProcessMouseWheelEvent(*event, latency); 285 target->ProcessMouseWheelEvent(*event, latency);
259 } 286 }
(...skipping 519 matching lines...) Expand 10 before | Expand all | Expand 10 after
779 if (!touchpad_gesture_target_.target) 806 if (!touchpad_gesture_target_.target)
780 return; 807 return;
781 808
782 // TODO(mohsen): Add tests to check event location. 809 // TODO(mohsen): Add tests to check event location.
783 event->x += touchpad_gesture_target_.delta.x(); 810 event->x += touchpad_gesture_target_.delta.x();
784 event->y += touchpad_gesture_target_.delta.y(); 811 event->y += touchpad_gesture_target_.delta.y();
785 touchpad_gesture_target_.target->ProcessGestureEvent(*event, latency); 812 touchpad_gesture_target_.target->ProcessGestureEvent(*event, latency);
786 } 813 }
787 814
788 } // namespace content 815 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698