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

Side by Side Diff: third_party/WebKit/Source/platform/WebPointerEvent.cpp

Issue 2973963003: Release mouse pointer capture when it starts drag (Closed)
Patch Set: Remove is_cancel from parameters Created 3 years, 5 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 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 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 "public/platform/WebPointerEvent.h" 5 #include "public/platform/WebPointerEvent.h"
6 6
7 #include "public/platform/WebFloatPoint.h" 7 #include "public/platform/WebFloatPoint.h"
8 8
9 namespace blink { 9 namespace blink {
10 10
11 namespace { 11 namespace {
12 12
13 WebInputEvent::Type PointerEventTypeForTouchPointState( 13 WebInputEvent::Type PointerEventTypeForTouchPointState(
14 WebTouchPoint::State state) { 14 WebTouchPoint::State state) {
15 switch (state) { 15 switch (state) {
16 case WebTouchPoint::kStateReleased: 16 case WebTouchPoint::kStateReleased:
17 return WebInputEvent::Type::kPointerUp; 17 return WebInputEvent::Type::kPointerUp;
18 case WebTouchPoint::kStateCancelled: 18 case WebTouchPoint::kStateCancelled:
19 return WebInputEvent::Type::kPointerCancel; 19 return WebInputEvent::Type::kPointerCancel;
20 case WebTouchPoint::kStatePressed: 20 case WebTouchPoint::kStatePressed:
21 return WebInputEvent::Type::kPointerDown; 21 return WebInputEvent::Type::kPointerDown;
22 case WebTouchPoint::kStateMoved: 22 case WebTouchPoint::kStateMoved:
23 return WebInputEvent::Type::kPointerMove; 23 return WebInputEvent::Type::kPointerMove;
24 case WebTouchPoint::kStateStationary: 24 case WebTouchPoint::kStateStationary:
25 default: 25 default:
26 NOTREACHED(); 26 NOTREACHED();
27 return WebInputEvent::Type::kUndefined; 27 return WebInputEvent::Type::kUndefined;
28 } 28 }
29 } 29 }
30
30 } // namespace 31 } // namespace
31 32
32 WebPointerEvent::WebPointerEvent(const WebTouchEvent& touch_event, 33 WebPointerEvent::WebPointerEvent(const WebTouchEvent& touch_event,
33 const WebTouchPoint& touch_point) 34 const WebTouchPoint& touch_point)
34 : WebInputEvent(sizeof(WebPointerEvent)), 35 : WebInputEvent(sizeof(WebPointerEvent)),
35 WebPointerProperties(touch_point), 36 WebPointerProperties(touch_point),
36 // TODO(crbug.com/731725): This mapping needs a times by 2. 37 // TODO(crbug.com/731725): This mapping needs a times by 2.
37 width(touch_point.radius_x), 38 width(touch_point.radius_x),
38 height(touch_point.radius_y) { 39 height(touch_point.radius_y) {
39 // WebInutEvent attributes 40 // WebInutEvent attributes
40 SetFrameScale(touch_event.FrameScale()); 41 SetFrameScale(touch_event.FrameScale());
41 SetFrameTranslate(touch_event.FrameTranslate()); 42 SetFrameTranslate(touch_event.FrameTranslate());
42 SetTimeStampSeconds(touch_event.TimeStampSeconds()); 43 SetTimeStampSeconds(touch_event.TimeStampSeconds());
43 SetType(PointerEventTypeForTouchPointState(touch_point.state)); 44 SetType(PointerEventTypeForTouchPointState(touch_point.state));
44 SetModifiers(touch_event.GetModifiers()); 45 SetModifiers(touch_event.GetModifiers());
45 // WebTouchEvent attributes 46 // WebTouchEvent attributes
46 dispatch_type = touch_event.dispatch_type; 47 dispatch_type = touch_event.dispatch_type;
47 moved_beyond_slop_region = touch_event.moved_beyond_slop_region; 48 moved_beyond_slop_region = touch_event.moved_beyond_slop_region;
48 touch_start_or_first_touch_move = touch_event.touch_start_or_first_touch_move; 49 touch_start_or_first_touch_move = touch_event.touch_start_or_first_touch_move;
49 // WebTouchPoint attributes 50 // WebTouchPoint attributes
50 rotation_angle = touch_point.rotation_angle; 51 rotation_angle = touch_point.rotation_angle;
51 } 52 }
52 53
54 WebPointerEvent::WebPointerEvent(WebInputEvent::Type type,
55 const WebMouseEvent& mouse_event)
56 : WebInputEvent(sizeof(WebPointerEvent)),
57 WebPointerProperties(mouse_event),
58 width(1),
59 height(1) {
60 DCHECK_GE(type, WebInputEvent::kPointerTypeFirst);
61 DCHECK_LE(type, WebInputEvent::kPointerTypeLast);
62 SetFrameScale(mouse_event.FrameScale());
63 SetFrameTranslate(mouse_event.FrameTranslate());
64 SetTimeStampSeconds(mouse_event.TimeStampSeconds());
65 SetType(type);
66 SetModifiers(mouse_event.GetModifiers());
67 }
68
53 WebPointerEvent WebPointerEvent::WebPointerEventInRootFrame() const { 69 WebPointerEvent WebPointerEvent::WebPointerEventInRootFrame() const {
54 WebPointerEvent transformed_event = *this; 70 WebPointerEvent transformed_event = *this;
55 transformed_event.width /= frame_scale_; 71 transformed_event.width /= frame_scale_;
56 transformed_event.height /= frame_scale_; 72 transformed_event.height /= frame_scale_;
57 transformed_event.movement_x /= frame_scale_; 73 transformed_event.movement_x /= frame_scale_;
58 transformed_event.movement_y /= frame_scale_; 74 transformed_event.movement_y /= frame_scale_;
59 transformed_event.position_in_widget_ = 75 transformed_event.position_in_widget_ =
60 WebFloatPoint((transformed_event.PositionInWidget().x / frame_scale_) + 76 WebFloatPoint((transformed_event.PositionInWidget().x / frame_scale_) +
61 frame_translate_.x, 77 frame_translate_.x,
62 (transformed_event.PositionInWidget().y / frame_scale_) + 78 (transformed_event.PositionInWidget().y / frame_scale_) +
63 frame_translate_.y); 79 frame_translate_.y);
64 return transformed_event; 80 return transformed_event;
65 } 81 }
66 82
67 } // namespace blink 83 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698