OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/mouse_wheel_event_queue.h" | 5 #include "content/browser/renderer_host/input/mouse_wheel_event_queue.h" |
6 | 6 |
7 #include "base/metrics/histogram_macros.h" | 7 #include "base/metrics/histogram_macros.h" |
8 #include "base/stl_util.h" | 8 #include "base/stl_util.h" |
9 #include "base/trace_event/trace_event.h" | 9 #include "base/trace_event/trace_event.h" |
10 | 10 |
(...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
78 | 78 |
79 event_sent_for_gesture_ack_->latency.AddNewLatencyFrom(latency_info); | 79 event_sent_for_gesture_ack_->latency.AddNewLatencyFrom(latency_info); |
80 client_->OnMouseWheelEventAck(*event_sent_for_gesture_ack_, ack_result); | 80 client_->OnMouseWheelEventAck(*event_sent_for_gesture_ack_, ack_result); |
81 | 81 |
82 // If event wasn't consumed then generate a gesture scroll for it. | 82 // If event wasn't consumed then generate a gesture scroll for it. |
83 if (send_gestures_ && ack_result != INPUT_EVENT_ACK_STATE_CONSUMED && | 83 if (send_gestures_ && ack_result != INPUT_EVENT_ACK_STATE_CONSUMED && |
84 event_sent_for_gesture_ack_->event.canScroll && | 84 event_sent_for_gesture_ack_->event.canScroll && |
85 (scrolling_device_ == blink::WebGestureDeviceUninitialized || | 85 (scrolling_device_ == blink::WebGestureDeviceUninitialized || |
86 scrolling_device_ == blink::WebGestureDeviceTouchpad)) { | 86 scrolling_device_ == blink::WebGestureDeviceTouchpad)) { |
87 GestureEventWithLatencyInfo scroll_update; | 87 GestureEventWithLatencyInfo scroll_update; |
| 88 scroll_update.event.x = event_sent_for_gesture_ack_->event.x; |
| 89 scroll_update.event.y = event_sent_for_gesture_ack_->event.y; |
| 90 scroll_update.event.globalX = event_sent_for_gesture_ack_->event.globalX; |
| 91 scroll_update.event.globalY = event_sent_for_gesture_ack_->event.globalY; |
88 scroll_update.event.type = WebInputEvent::GestureScrollUpdate; | 92 scroll_update.event.type = WebInputEvent::GestureScrollUpdate; |
89 scroll_update.event.sourceDevice = blink::WebGestureDeviceTouchpad; | 93 scroll_update.event.sourceDevice = blink::WebGestureDeviceTouchpad; |
90 scroll_update.event.resendingPluginId = -1; | 94 scroll_update.event.resendingPluginId = -1; |
91 scroll_update.event.data.scrollUpdate.deltaX = | 95 scroll_update.event.data.scrollUpdate.deltaX = |
92 event_sent_for_gesture_ack_->event.deltaX; | 96 event_sent_for_gesture_ack_->event.deltaX; |
93 scroll_update.event.data.scrollUpdate.deltaY = | 97 scroll_update.event.data.scrollUpdate.deltaY = |
94 event_sent_for_gesture_ack_->event.deltaY; | 98 event_sent_for_gesture_ack_->event.deltaY; |
95 if (event_sent_for_gesture_ack_->event.scrollByPage) { | 99 if (event_sent_for_gesture_ack_->event.scrollByPage) { |
96 scroll_update.event.data.scrollUpdate.deltaUnits = | 100 scroll_update.event.data.scrollUpdate.deltaUnits = |
97 blink::WebGestureEvent::Page; | 101 blink::WebGestureEvent::Page; |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
147 event_sent_for_gesture_ack_.reset(wheel_queue_.front()); | 151 event_sent_for_gesture_ack_.reset(wheel_queue_.front()); |
148 wheel_queue_.pop_front(); | 152 wheel_queue_.pop_front(); |
149 | 153 |
150 MouseWheelEventWithLatencyInfo send_event(*event_sent_for_gesture_ack_); | 154 MouseWheelEventWithLatencyInfo send_event(*event_sent_for_gesture_ack_); |
151 if (send_gestures_) | 155 if (send_gestures_) |
152 send_event.event.canScroll = false; | 156 send_event.event.canScroll = false; |
153 | 157 |
154 client_->SendMouseWheelEventImmediately(send_event); | 158 client_->SendMouseWheelEventImmediately(send_event); |
155 } | 159 } |
156 | 160 |
157 void MouseWheelEventQueue::SendScrollEnd( | 161 void MouseWheelEventQueue::SendScrollEnd(blink::WebGestureEvent update_event) { |
158 blink::WebGestureEvent::ScrollUnits units) { | |
159 GestureEventWithLatencyInfo scroll_end; | 162 GestureEventWithLatencyInfo scroll_end; |
160 scroll_end.event.type = WebInputEvent::GestureScrollEnd; | 163 scroll_end.event.type = WebInputEvent::GestureScrollEnd; |
161 scroll_end.event.sourceDevice = blink::WebGestureDeviceTouchpad; | 164 scroll_end.event.sourceDevice = blink::WebGestureDeviceTouchpad; |
162 scroll_end.event.resendingPluginId = -1; | 165 scroll_end.event.resendingPluginId = -1; |
163 scroll_end.event.data.scrollEnd.deltaUnits = units; | 166 scroll_end.event.data.scrollEnd.deltaUnits = |
| 167 update_event.data.scrollUpdate.deltaUnits; |
| 168 scroll_end.event.x = update_event.x; |
| 169 scroll_end.event.y = update_event.y; |
| 170 scroll_end.event.globalX = update_event.globalX; |
| 171 scroll_end.event.globalY = update_event.globalY; |
| 172 |
164 SendGesture(scroll_end); | 173 SendGesture(scroll_end); |
165 } | 174 } |
166 | 175 |
167 void MouseWheelEventQueue::SendGesture( | 176 void MouseWheelEventQueue::SendGesture( |
168 const GestureEventWithLatencyInfo& gesture) { | 177 const GestureEventWithLatencyInfo& gesture) { |
169 switch (gesture.event.type) { | 178 switch (gesture.event.type) { |
170 case WebInputEvent::GestureScrollUpdate: | 179 case WebInputEvent::GestureScrollUpdate: |
171 if (needs_scroll_begin_) { | 180 if (needs_scroll_begin_) { |
172 GestureEventWithLatencyInfo scroll_begin(gesture); | 181 GestureEventWithLatencyInfo scroll_begin(gesture); |
| 182 scroll_begin.event.x = gesture.event.x; |
| 183 scroll_begin.event.y = gesture.event.y; |
| 184 scroll_begin.event.globalX = gesture.event.globalX; |
| 185 scroll_begin.event.globalY = gesture.event.globalY; |
173 scroll_begin.event.type = WebInputEvent::GestureScrollBegin; | 186 scroll_begin.event.type = WebInputEvent::GestureScrollBegin; |
174 scroll_begin.event.data.scrollBegin.deltaXHint = | 187 scroll_begin.event.data.scrollBegin.deltaXHint = |
175 gesture.event.data.scrollUpdate.deltaX; | 188 gesture.event.data.scrollUpdate.deltaX; |
176 scroll_begin.event.data.scrollBegin.deltaYHint = | 189 scroll_begin.event.data.scrollBegin.deltaYHint = |
177 gesture.event.data.scrollUpdate.deltaY; | 190 gesture.event.data.scrollUpdate.deltaY; |
178 scroll_begin.event.data.scrollBegin.targetViewport = false; | 191 scroll_begin.event.data.scrollBegin.targetViewport = false; |
179 scroll_begin.event.data.scrollBegin.deltaHintUnits = | 192 scroll_begin.event.data.scrollBegin.deltaHintUnits = |
180 gesture.event.data.scrollUpdate.deltaUnits; | 193 gesture.event.data.scrollUpdate.deltaUnits; |
181 | 194 |
182 SendGesture(scroll_begin); | 195 SendGesture(scroll_begin); |
183 } | 196 } |
184 if (scroll_end_timer_.IsRunning()) { | 197 if (scroll_end_timer_.IsRunning()) { |
185 scroll_end_timer_.Reset(); | 198 scroll_end_timer_.Reset(); |
186 } else { | 199 } else { |
187 scroll_end_timer_.Start( | 200 scroll_end_timer_.Start( |
188 FROM_HERE, | 201 FROM_HERE, |
189 base::TimeDelta::FromMilliseconds(scroll_transaction_ms_), | 202 base::TimeDelta::FromMilliseconds(scroll_transaction_ms_), |
190 base::Bind(&MouseWheelEventQueue::SendScrollEnd, | 203 base::Bind(&MouseWheelEventQueue::SendScrollEnd, |
191 base::Unretained(this), | 204 base::Unretained(this), gesture.event)); |
192 gesture.event.data.scrollUpdate.deltaUnits)); | |
193 } | 205 } |
194 break; | 206 break; |
195 case WebInputEvent::GestureScrollEnd: | 207 case WebInputEvent::GestureScrollEnd: |
196 needs_scroll_begin_ = true; | 208 needs_scroll_begin_ = true; |
197 break; | 209 break; |
198 case WebInputEvent::GestureScrollBegin: | 210 case WebInputEvent::GestureScrollBegin: |
199 needs_scroll_begin_ = false; | 211 needs_scroll_begin_ = false; |
200 break; | 212 break; |
201 default: | 213 default: |
202 return; | 214 return; |
203 } | 215 } |
204 client_->SendGestureEvent(gesture); | 216 client_->SendGestureEvent(gesture); |
205 } | 217 } |
206 | 218 |
207 } // namespace content | 219 } // namespace content |
OLD | NEW |