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

Unified Diff: content/renderer/input/main_thread_event_queue.cc

Issue 2788203002: Adjust cancelabilty of touchmoves that are queued when scroll start occurs (Closed)
Patch Set: Fix nits Created 3 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | content/renderer/input/main_thread_event_queue_task.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/renderer/input/main_thread_event_queue.cc
diff --git a/content/renderer/input/main_thread_event_queue.cc b/content/renderer/input/main_thread_event_queue.cc
index 7e179487ceced850f7a532607a3ca1532cb7bb8e..241c0bcb0b11b38f91044f4e0ac50f1c2d949b2e 100644
--- a/content/renderer/input/main_thread_event_queue.cc
+++ b/content/renderer/input/main_thread_event_queue.cc
@@ -22,10 +22,10 @@ class QueuedClosure : public MainThreadEventQueueTask {
~QueuedClosure() override {}
- CoalesceResult CoalesceWith(
+ FilterResult FilterNewEvent(
const MainThreadEventQueueTask& other_task) override {
- return other_task.IsWebInputEvent() ? CoalesceResult::KeepSearching
- : CoalesceResult::CannotCoalesce;
+ return other_task.IsWebInputEvent() ? FilterResult::KeepIterating
+ : FilterResult::StopIterating;
}
bool IsWebInputEvent() const override { return false; }
@@ -61,18 +61,23 @@ class QueuedWebInputEvent : public ScopedWebInputEventWithLatencyInfo,
~QueuedWebInputEvent() override {}
- CoalesceResult CoalesceWith(
- const MainThreadEventQueueTask& other_item) override {
- if (!other_item.IsWebInputEvent())
- return CoalesceResult::CannotCoalesce;
+ FilterResult FilterNewEvent(
+ const MainThreadEventQueueTask& other_task) override {
+ if (!other_task.IsWebInputEvent())
+ return FilterResult::StopIterating;
const QueuedWebInputEvent& other_event =
- static_cast<const QueuedWebInputEvent&>(other_item);
+ static_cast<const QueuedWebInputEvent&>(other_task);
+ if (other_event.event().type() ==
+ blink::WebInputEvent::TouchScrollStarted) {
+ return HandleTouchScrollStartQueued();
+ }
+
if (!event().isSameEventClass(other_event.event()))
- return CoalesceResult::KeepSearching;
+ return FilterResult::KeepIterating;
if (!ScopedWebInputEventWithLatencyInfo::CanCoalesceWith(other_event))
- return CoalesceResult::CannotCoalesce;
+ return FilterResult::StopIterating;
// If this event was blocking push the event id to the blocking
// list before updating the dispatch_type of this event.
@@ -89,7 +94,7 @@ class QueuedWebInputEvent : public ScopedWebInputEventWithLatencyInfo,
dispatch_type_ = other_event.dispatch_type_;
originally_cancelable_ = other_event.originally_cancelable_;
- return CoalesceResult::Coalesced;
+ return FilterResult::CoalescedEvent;
}
bool IsWebInputEvent() const override { return true; }
@@ -150,6 +155,28 @@ class QueuedWebInputEvent : public ScopedWebInputEventWithLatencyInfo,
bool originallyCancelable() const { return originally_cancelable_; }
private:
+ FilterResult HandleTouchScrollStartQueued() {
+ // A TouchScrollStart will queued after this touch move which will make all
+ // previous touch moves that are queued uncancelable.
+ switch (event().type()) {
+ case blink::WebInputEvent::TouchMove: {
+ blink::WebTouchEvent& touch_event =
+ static_cast<blink::WebTouchEvent&>(event());
+ if (touch_event.dispatchType ==
+ blink::WebInputEvent::DispatchType::Blocking) {
+ touch_event.dispatchType =
+ blink::WebInputEvent::DispatchType::EventNonBlocking;
+ }
+ return FilterResult::KeepIterating;
+ }
+ case blink::WebInputEvent::TouchStart:
+ case blink::WebInputEvent::TouchEnd:
+ return FilterResult::StopIterating;
+ default:
+ return FilterResult::KeepIterating;
+ }
+ }
+
const std::deque<uint32_t>& blockingCoalescedEventIds() const {
return blocking_coalesced_event_ids_;
}
« no previous file with comments | « no previous file | content/renderer/input/main_thread_event_queue_task.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698