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

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

Issue 2973963003: Release mouse pointer capture when it starts drag (Closed)
Patch Set: 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 PointerEventTypeForMouseEventType(WebInputEvent::Type type,
14 bool is_cancel) {
15 if (is_cancel)
16 return WebInputEvent::Type::kPointerCancel;
17 switch (type) {
18 case WebInputEvent::Type::kMouseDown:
19 return WebInputEvent::Type::kPointerDown;
20 case WebInputEvent::Type::kMouseUp:
21 return WebInputEvent::Type::kPointerUp;
22 case WebInputEvent::Type::kMouseMove:
23 return WebInputEvent::Type::kPointerMove;
24 default:
25 NOTREACHED();
26 return WebInputEvent::Type::kUndefined;
27 }
28 }
29
13 WebInputEvent::Type PointerEventTypeForTouchPointState( 30 WebInputEvent::Type PointerEventTypeForTouchPointState(
14 WebTouchPoint::State state) { 31 WebTouchPoint::State state) {
15 switch (state) { 32 switch (state) {
16 case WebTouchPoint::kStateReleased: 33 case WebTouchPoint::kStateReleased:
17 return WebInputEvent::Type::kPointerUp; 34 return WebInputEvent::Type::kPointerUp;
18 case WebTouchPoint::kStateCancelled: 35 case WebTouchPoint::kStateCancelled:
19 return WebInputEvent::Type::kPointerCancel; 36 return WebInputEvent::Type::kPointerCancel;
20 case WebTouchPoint::kStatePressed: 37 case WebTouchPoint::kStatePressed:
21 return WebInputEvent::Type::kPointerDown; 38 return WebInputEvent::Type::kPointerDown;
22 case WebTouchPoint::kStateMoved: 39 case WebTouchPoint::kStateMoved:
23 return WebInputEvent::Type::kPointerMove; 40 return WebInputEvent::Type::kPointerMove;
24 case WebTouchPoint::kStateStationary: 41 case WebTouchPoint::kStateStationary:
25 default: 42 default:
26 NOTREACHED(); 43 NOTREACHED();
27 return WebInputEvent::Type::kUndefined; 44 return WebInputEvent::Type::kUndefined;
28 } 45 }
29 } 46 }
47
30 } // namespace 48 } // namespace
31 49
32 WebPointerEvent::WebPointerEvent(const WebTouchEvent& touch_event, 50 WebPointerEvent::WebPointerEvent(const WebTouchEvent& touch_event,
33 const WebTouchPoint& touch_point) 51 const WebTouchPoint& touch_point)
34 : WebInputEvent(sizeof(WebPointerEvent)), 52 : WebInputEvent(sizeof(WebPointerEvent)),
35 WebPointerProperties(touch_point), 53 WebPointerProperties(touch_point),
36 // TODO(crbug.com/731725): This mapping needs a times by 2. 54 // TODO(crbug.com/731725): This mapping needs a times by 2.
37 width(touch_point.radius_x), 55 width(touch_point.radius_x),
38 height(touch_point.radius_y) { 56 height(touch_point.radius_y) {
39 // WebInutEvent attributes 57 // WebInutEvent attributes
40 SetFrameScale(touch_event.FrameScale()); 58 SetFrameScale(touch_event.FrameScale());
41 SetFrameTranslate(touch_event.FrameTranslate()); 59 SetFrameTranslate(touch_event.FrameTranslate());
42 SetTimeStampSeconds(touch_event.TimeStampSeconds()); 60 SetTimeStampSeconds(touch_event.TimeStampSeconds());
43 SetType(PointerEventTypeForTouchPointState(touch_point.state)); 61 SetType(PointerEventTypeForTouchPointState(touch_point.state));
44 SetModifiers(touch_event.GetModifiers()); 62 SetModifiers(touch_event.GetModifiers());
45 // WebTouchEvent attributes 63 // WebTouchEvent attributes
46 dispatch_type = touch_event.dispatch_type; 64 dispatch_type = touch_event.dispatch_type;
47 moved_beyond_slop_region = touch_event.moved_beyond_slop_region; 65 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; 66 touch_start_or_first_touch_move = touch_event.touch_start_or_first_touch_move;
49 // WebTouchPoint attributes 67 // WebTouchPoint attributes
50 rotation_angle = touch_point.rotation_angle; 68 rotation_angle = touch_point.rotation_angle;
51 } 69 }
52 70
71 WebPointerEvent::WebPointerEvent(const WebMouseEvent& mouse_event,
72 bool is_cancel)
73 : WebInputEvent(sizeof(WebPointerEvent)),
74 WebPointerProperties(mouse_event),
75 width(1),
76 height(1) {
77 SetFrameScale(mouse_event.FrameScale());
78 SetFrameTranslate(mouse_event.FrameTranslate());
79 SetTimeStampSeconds(mouse_event.TimeStampSeconds());
80 SetType(PointerEventTypeForMouseEventType(mouse_event.GetType(), is_cancel));
81 SetModifiers(mouse_event.GetModifiers());
82 }
83
53 WebPointerEvent WebPointerEvent::WebPointerEventInRootFrame() const { 84 WebPointerEvent WebPointerEvent::WebPointerEventInRootFrame() const {
54 WebPointerEvent transformed_event = *this; 85 WebPointerEvent transformed_event = *this;
55 transformed_event.width /= frame_scale_; 86 transformed_event.width /= frame_scale_;
56 transformed_event.height /= frame_scale_; 87 transformed_event.height /= frame_scale_;
57 transformed_event.movement_x /= frame_scale_; 88 transformed_event.movement_x /= frame_scale_;
58 transformed_event.movement_y /= frame_scale_; 89 transformed_event.movement_y /= frame_scale_;
59 transformed_event.position_in_widget_ = 90 transformed_event.position_in_widget_ =
60 WebFloatPoint((transformed_event.PositionInWidget().x / frame_scale_) + 91 WebFloatPoint((transformed_event.PositionInWidget().x / frame_scale_) +
61 frame_translate_.x, 92 frame_translate_.x,
62 (transformed_event.PositionInWidget().y / frame_scale_) + 93 (transformed_event.PositionInWidget().y / frame_scale_) +
63 frame_translate_.y); 94 frame_translate_.y);
64 return transformed_event; 95 return transformed_event;
65 } 96 }
66 97
67 } // namespace blink 98 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698