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

Side by Side Diff: content/browser/renderer_host/input/synthetic_pointer_action.cc

Issue 2336803003: Make SyntheticPointerAction to flush the pointer action sequence (Closed)
Patch Set: controller Created 4 years, 3 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/input/synthetic_pointer_action.h" 5 #include "content/browser/renderer_host/input/synthetic_pointer_action.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "third_party/WebKit/public/web/WebInputEvent.h" 8 #include "third_party/WebKit/public/web/WebInputEvent.h"
9 #include "ui/events/latency_info.h" 9 #include "ui/events/latency_info.h"
10 10
11 namespace content { 11 namespace content {
12 12
13 SyntheticPointerAction::SyntheticPointerAction( 13 SyntheticPointerAction::SyntheticPointerAction(
14 const SyntheticPointerActionParams& params) 14 const SyntheticPointerActionListParams& params)
15 : params_(params) {} 15 : params_(params) {}
16 16
17 SyntheticPointerAction::SyntheticPointerAction( 17 SyntheticPointerAction::SyntheticPointerAction(
18 std::unique_ptr<std::vector<SyntheticPointerActionParams>> param_list, 18 const SyntheticPointerActionListParams& params,
19 SyntheticPointer* synthetic_pointer, 19 SyntheticPointer* synthetic_pointer,
20 IndexMap* index_map) 20 IndexMap* index_map)
21 : param_list_(std::move(param_list)), 21 : params_(params),
22 synthetic_pointer_(synthetic_pointer), 22 synthetic_pointer_(synthetic_pointer),
23 index_map_(index_map) {} 23 index_map_(index_map) {}
24 24
25 SyntheticPointerAction::~SyntheticPointerAction() {} 25 SyntheticPointerAction::~SyntheticPointerAction() {}
26 26
27 SyntheticGesture::Result SyntheticPointerAction::ForwardInputEvents( 27 SyntheticGesture::Result SyntheticPointerAction::ForwardInputEvents(
28 const base::TimeTicks& timestamp, 28 const base::TimeTicks& timestamp,
29 SyntheticGestureTarget* target) { 29 SyntheticGestureTarget* target) {
30 DCHECK(synthetic_pointer_); 30 DCHECK(synthetic_pointer_);
31 DCHECK_NE(synthetic_pointer_->SourceType(),
32 SyntheticGestureParams::DEFAULT_INPUT);
31 return ForwardTouchOrMouseInputEvents(timestamp, target); 33 return ForwardTouchOrMouseInputEvents(timestamp, target);
32 } 34 }
33 35
34 SyntheticGesture::Result SyntheticPointerAction::ForwardTouchOrMouseInputEvents( 36 SyntheticGesture::Result SyntheticPointerAction::ForwardTouchOrMouseInputEvents(
35 const base::TimeTicks& timestamp, 37 const base::TimeTicks& timestamp,
36 SyntheticGestureTarget* target) { 38 SyntheticGestureTarget* target) {
37 int point_index; 39 int point_index;
38 for (const SyntheticPointerActionParams& params : *param_list_) { 40 for (SyntheticPointerActionParams& params : params_.param_list) {
41 if (params.gesture_source_type == SyntheticGestureParams::DEFAULT_INPUT)
42 params.gesture_source_type = synthetic_pointer_->SourceType();
43
39 if (!UserInputCheck(params)) 44 if (!UserInputCheck(params))
40 return POINTER_ACTION_INPUT_INVALID; 45 return POINTER_ACTION_INPUT_INVALID;
41 46
42 switch (params.pointer_action_type()) { 47 switch (params.pointer_action_type()) {
43 case SyntheticPointerActionParams::PointerActionType::PRESS: 48 case SyntheticPointerActionParams::PointerActionType::PRESS:
44 point_index = synthetic_pointer_->Press( 49 point_index = synthetic_pointer_->Press(
45 params.position().x(), params.position().y(), target, timestamp); 50 params.position().x(), params.position().y(), target, timestamp);
46 SetPointIndex(params.index(), point_index); 51 SetPointIndex(params.index(), point_index);
47 break; 52 break;
48 case SyntheticPointerActionParams::PointerActionType::MOVE: 53 case SyntheticPointerActionParams::PointerActionType::MOVE:
49 point_index = GetPointIndex(params.index()); 54 point_index = GetPointIndex(params.index());
50 synthetic_pointer_->Move(point_index, params.position().x(), 55 synthetic_pointer_->Move(point_index, params.position().x(),
51 params.position().y(), target, timestamp); 56 params.position().y(), target, timestamp);
52 break; 57 break;
53 case SyntheticPointerActionParams::PointerActionType::RELEASE: 58 case SyntheticPointerActionParams::PointerActionType::RELEASE:
54 point_index = GetPointIndex(params.index()); 59 point_index = GetPointIndex(params.index());
55 synthetic_pointer_->Release(point_index, target, timestamp); 60 synthetic_pointer_->Release(point_index, target, timestamp);
56 SetPointIndex(params.index(), -1); 61 SetPointIndex(params.index(), -1);
57 break; 62 break;
63 case SyntheticPointerActionParams::PointerActionType::FINISH:
64 return GESTURE_FINISHED;
58 default: 65 default:
59 return POINTER_ACTION_INPUT_INVALID; 66 return POINTER_ACTION_INPUT_INVALID;
60 } 67 }
61 } 68 }
62 synthetic_pointer_->DispatchEvent(target, timestamp); 69 synthetic_pointer_->DispatchEvent(target, timestamp);
63 return GESTURE_FINISHED; 70 return GESTURE_RUNNING;
64 } 71 }
65 72
66 bool SyntheticPointerAction::UserInputCheck( 73 bool SyntheticPointerAction::UserInputCheck(
67 const SyntheticPointerActionParams& params) { 74 const SyntheticPointerActionParams& params) {
68 if (params.index() < 0 || params.index() >= WebTouchEvent::kTouchesLengthCap) 75 if (params.index() < 0 || params.index() >= WebTouchEvent::kTouchesLengthCap)
69 return false; 76 return false;
70 77
71 if (synthetic_pointer_->SourceType() != params.gesture_source_type) 78 if (synthetic_pointer_->SourceType() != params.gesture_source_type)
72 return false; 79 return false;
73 80
(...skipping 12 matching lines...) Expand all
86 93
87 if (params.pointer_action_type() == 94 if (params.pointer_action_type() ==
88 SyntheticPointerActionParams::PointerActionType::RELEASE && 95 SyntheticPointerActionParams::PointerActionType::RELEASE &&
89 GetPointIndex(params.index()) < 0) { 96 GetPointIndex(params.index()) < 0) {
90 return false; 97 return false;
91 } 98 }
92 return true; 99 return true;
93 } 100 }
94 101
95 } // namespace content 102 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698