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 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
117 TryForwardNextEventToRenderer(); | 117 TryForwardNextEventToRenderer(); |
118 } | 118 } |
119 | 119 |
120 void MouseWheelEventQueue::OnGestureScrollEvent( | 120 void MouseWheelEventQueue::OnGestureScrollEvent( |
121 const GestureEventWithLatencyInfo& gesture_event) { | 121 const GestureEventWithLatencyInfo& gesture_event) { |
122 if (gesture_event.event.type == blink::WebInputEvent::GestureScrollBegin) { | 122 if (gesture_event.event.type == blink::WebInputEvent::GestureScrollBegin) { |
123 // If there is a current scroll going on and a new scroll that isn't | 123 // If there is a current scroll going on and a new scroll that isn't |
124 // wheel based cancel current one by sending a ScrollEnd. | 124 // wheel based cancel current one by sending a ScrollEnd. |
125 if (scroll_end_timer_.IsRunning() && | 125 if (scroll_end_timer_.IsRunning() && |
126 gesture_event.event.sourceDevice != blink::WebGestureDeviceTouchpad) { | 126 gesture_event.event.sourceDevice != blink::WebGestureDeviceTouchpad) { |
| 127 base::Closure task = scroll_end_timer_.user_task(); |
127 scroll_end_timer_.Reset(); | 128 scroll_end_timer_.Reset(); |
128 SendScrollEnd(); | 129 task.Run(); |
129 } | 130 } |
130 scrolling_device_ = gesture_event.event.sourceDevice; | 131 scrolling_device_ = gesture_event.event.sourceDevice; |
131 } else if (scrolling_device_ == gesture_event.event.sourceDevice && | 132 } else if (scrolling_device_ == gesture_event.event.sourceDevice && |
132 (gesture_event.event.type == | 133 (gesture_event.event.type == |
133 blink::WebInputEvent::GestureScrollEnd || | 134 blink::WebInputEvent::GestureScrollEnd || |
134 gesture_event.event.type == | 135 gesture_event.event.type == |
135 blink::WebInputEvent::GestureFlingStart)) { | 136 blink::WebInputEvent::GestureFlingStart)) { |
136 scrolling_device_ = blink::WebGestureDeviceUninitialized; | 137 scrolling_device_ = blink::WebGestureDeviceUninitialized; |
137 } | 138 } |
138 } | 139 } |
139 | 140 |
140 void MouseWheelEventQueue::TryForwardNextEventToRenderer() { | 141 void MouseWheelEventQueue::TryForwardNextEventToRenderer() { |
141 TRACE_EVENT0("input", "MouseWheelEventQueue::TryForwardNextEventToRenderer"); | 142 TRACE_EVENT0("input", "MouseWheelEventQueue::TryForwardNextEventToRenderer"); |
142 | 143 |
143 if (wheel_queue_.empty() || event_sent_for_gesture_ack_) | 144 if (wheel_queue_.empty() || event_sent_for_gesture_ack_) |
144 return; | 145 return; |
145 | 146 |
146 event_sent_for_gesture_ack_.reset(wheel_queue_.front()); | 147 event_sent_for_gesture_ack_.reset(wheel_queue_.front()); |
147 wheel_queue_.pop_front(); | 148 wheel_queue_.pop_front(); |
148 | 149 |
149 MouseWheelEventWithLatencyInfo send_event(*event_sent_for_gesture_ack_); | 150 MouseWheelEventWithLatencyInfo send_event(*event_sent_for_gesture_ack_); |
150 if (send_gestures_) | 151 if (send_gestures_) |
151 send_event.event.canScroll = false; | 152 send_event.event.canScroll = false; |
152 | 153 |
153 client_->SendMouseWheelEventImmediately(send_event); | 154 client_->SendMouseWheelEventImmediately(send_event); |
154 } | 155 } |
155 | 156 |
156 void MouseWheelEventQueue::SendScrollEnd() { | 157 void MouseWheelEventQueue::SendScrollEnd( |
| 158 blink::WebGestureEvent::ScrollUnits units) { |
157 GestureEventWithLatencyInfo scroll_end; | 159 GestureEventWithLatencyInfo scroll_end; |
158 scroll_end.event.type = WebInputEvent::GestureScrollEnd; | 160 scroll_end.event.type = WebInputEvent::GestureScrollEnd; |
159 scroll_end.event.sourceDevice = blink::WebGestureDeviceTouchpad; | 161 scroll_end.event.sourceDevice = blink::WebGestureDeviceTouchpad; |
160 scroll_end.event.resendingPluginId = -1; | 162 scroll_end.event.resendingPluginId = -1; |
| 163 scroll_end.event.data.scrollEnd.deltaUnits = units; |
161 SendGesture(scroll_end); | 164 SendGesture(scroll_end); |
162 } | 165 } |
163 | 166 |
164 void MouseWheelEventQueue::SendGesture( | 167 void MouseWheelEventQueue::SendGesture( |
165 const GestureEventWithLatencyInfo& gesture) { | 168 const GestureEventWithLatencyInfo& gesture) { |
166 switch (gesture.event.type) { | 169 switch (gesture.event.type) { |
167 case WebInputEvent::GestureScrollUpdate: | 170 case WebInputEvent::GestureScrollUpdate: |
168 if (needs_scroll_begin_) { | 171 if (needs_scroll_begin_) { |
169 GestureEventWithLatencyInfo scroll_begin(gesture); | 172 GestureEventWithLatencyInfo scroll_begin(gesture); |
170 scroll_begin.event.type = WebInputEvent::GestureScrollBegin; | 173 scroll_begin.event.type = WebInputEvent::GestureScrollBegin; |
171 scroll_begin.event.data.scrollBegin.deltaXHint = | 174 scroll_begin.event.data.scrollBegin.deltaXHint = |
172 gesture.event.data.scrollUpdate.deltaX; | 175 gesture.event.data.scrollUpdate.deltaX; |
173 scroll_begin.event.data.scrollBegin.deltaYHint = | 176 scroll_begin.event.data.scrollBegin.deltaYHint = |
174 gesture.event.data.scrollUpdate.deltaY; | 177 gesture.event.data.scrollUpdate.deltaY; |
175 scroll_begin.event.data.scrollBegin.targetViewport = false; | 178 scroll_begin.event.data.scrollBegin.targetViewport = false; |
176 scroll_begin.event.data.scrollBegin.deltaHintUnits = | 179 scroll_begin.event.data.scrollBegin.deltaHintUnits = |
177 gesture.event.data.scrollUpdate.deltaUnits; | 180 gesture.event.data.scrollUpdate.deltaUnits; |
178 | 181 |
179 SendGesture(scroll_begin); | 182 SendGesture(scroll_begin); |
180 } | 183 } |
181 if (scroll_end_timer_.IsRunning()) { | 184 if (scroll_end_timer_.IsRunning()) { |
182 scroll_end_timer_.Reset(); | 185 scroll_end_timer_.Reset(); |
183 } else { | 186 } else { |
184 scroll_end_timer_.Start(FROM_HERE, base::TimeDelta::FromMilliseconds( | 187 scroll_end_timer_.Start( |
185 scroll_transaction_ms_), | 188 FROM_HERE, |
186 this, &MouseWheelEventQueue::SendScrollEnd); | 189 base::TimeDelta::FromMilliseconds(scroll_transaction_ms_), |
| 190 base::Bind(&MouseWheelEventQueue::SendScrollEnd, |
| 191 base::Unretained(this), |
| 192 gesture.event.data.scrollUpdate.deltaUnits)); |
187 } | 193 } |
188 break; | 194 break; |
189 case WebInputEvent::GestureScrollEnd: | 195 case WebInputEvent::GestureScrollEnd: |
190 needs_scroll_begin_ = true; | 196 needs_scroll_begin_ = true; |
191 break; | 197 break; |
192 case WebInputEvent::GestureScrollBegin: | 198 case WebInputEvent::GestureScrollBegin: |
193 needs_scroll_begin_ = false; | 199 needs_scroll_begin_ = false; |
194 break; | 200 break; |
195 default: | 201 default: |
196 return; | 202 return; |
197 } | 203 } |
198 client_->SendGestureEvent(gesture); | 204 client_->SendGestureEvent(gesture); |
199 } | 205 } |
200 | 206 |
201 } // namespace content | 207 } // namespace content |
OLD | NEW |