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

Unified Diff: content/browser/renderer_host/input/content_gesture_provider.cc

Issue 182383007: Make the ContentGestureProvider a ui::FilteredGestureProvider (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Lower similarity Created 6 years, 10 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
Index: content/browser/renderer_host/input/content_gesture_provider.cc
diff --git a/content/browser/renderer_host/input/content_gesture_provider.cc b/content/browser/renderer_host/input/content_gesture_provider.cc
deleted file mode 100644
index fddd125a194547e2145e9cc4357376ed95e71311..0000000000000000000000000000000000000000
--- a/content/browser/renderer_host/input/content_gesture_provider.cc
+++ /dev/null
@@ -1,217 +0,0 @@
-// Copyright 2014 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "content/browser/renderer_host/input/content_gesture_provider.h"
-
-#include "base/auto_reset.h"
-#include "base/command_line.h"
-#include "base/logging.h"
-#include "content/public/common/content_switches.h"
-#include "third_party/WebKit/public/web/WebInputEvent.h"
-#include "ui/events/gesture_detection/gesture_config_helper.h"
-#include "ui/events/gesture_detection/motion_event.h"
-
-using blink::WebGestureEvent;
-using blink::WebInputEvent;
-
-namespace content {
-namespace {
-
-WebGestureEvent CreateGesture(const ui::GestureEventData& data,
- float scale) {
- WebGestureEvent gesture;
- gesture.x = data.x * scale;
- gesture.y = data.y * scale;
- gesture.timeStampSeconds = (data.time - base::TimeTicks()).InSecondsF();
- gesture.sourceDevice = WebGestureEvent::Touchscreen;
-
- switch (data.type) {
- case ui::ET_GESTURE_SHOW_PRESS:
- gesture.type = WebInputEvent::GestureShowPress;
- gesture.data.showPress.width = data.details.show_press.width * scale;
- gesture.data.showPress.width = data.details.show_press.width * scale;
- break;
- case ui::ET_GESTURE_DOUBLE_TAP:
- gesture.type = WebInputEvent::GestureDoubleTap;
- break;
- case ui::ET_GESTURE_TAP:
- gesture.type = WebInputEvent::GestureTap;
- gesture.data.tap.tapCount = data.details.tap.tap_count;
- gesture.data.tap.width = data.details.tap.width * scale;
- gesture.data.tap.height = data.details.tap.height * scale;
- break;
- case ui::ET_GESTURE_TAP_UNCONFIRMED:
- gesture.type = WebInputEvent::GestureTapUnconfirmed;
- gesture.data.tap.tapCount = data.details.tap.tap_count;
- gesture.data.tap.width = data.details.tap.width * scale;
- gesture.data.tap.height = data.details.tap.height * scale;
- break;
- case ui::ET_GESTURE_LONG_PRESS:
- gesture.type = WebInputEvent::GestureLongPress;
- gesture.data.longPress.width = data.details.long_press.width * scale;
- gesture.data.longPress.height = data.details.long_press.height * scale;
- break;
- case ui::ET_GESTURE_LONG_TAP:
- gesture.type = WebInputEvent::GestureLongTap;
- gesture.data.longPress.width = data.details.long_press.width * scale;
- gesture.data.longPress.height = data.details.long_press.height * scale;
- break;
- case ui::ET_GESTURE_SCROLL_BEGIN:
- gesture.type = WebInputEvent::GestureScrollBegin;
- gesture.data.scrollBegin.deltaXHint =
- data.details.scroll_begin.delta_x_hint * scale;
- gesture.data.scrollBegin.deltaYHint =
- data.details.scroll_begin.delta_y_hint * scale;
- break;
- case ui::ET_GESTURE_SCROLL_UPDATE:
- gesture.type = WebInputEvent::GestureScrollUpdate;
- gesture.data.scrollUpdate.deltaX =
- data.details.scroll_update.delta_x * scale;
- gesture.data.scrollUpdate.deltaY =
- data.details.scroll_update.delta_y * scale;
- gesture.data.scrollUpdate.velocityX =
- data.details.scroll_update.velocity_x * scale;
- gesture.data.scrollUpdate.velocityY =
- data.details.scroll_update.velocity_y * scale;
- break;
- case ui::ET_GESTURE_SCROLL_END:
- gesture.type = WebInputEvent::GestureScrollEnd;
- break;
- case ui::ET_SCROLL_FLING_START:
- gesture.type = WebInputEvent::GestureFlingStart;
- gesture.data.flingStart.velocityX =
- data.details.fling_start.velocity_x * scale;
- gesture.data.flingStart.velocityY =
- data.details.fling_start.velocity_y * scale;
- break;
- case ui::ET_SCROLL_FLING_CANCEL:
- gesture.type = WebInputEvent::GestureFlingCancel;
- break;
- case ui::ET_GESTURE_PINCH_BEGIN:
- gesture.type = WebInputEvent::GesturePinchBegin;
- break;
- case ui::ET_GESTURE_PINCH_UPDATE:
- gesture.type = WebInputEvent::GesturePinchUpdate;
- gesture.data.pinchUpdate.scale = data.details.pinch_update.scale;
- break;
- case ui::ET_GESTURE_PINCH_END:
- gesture.type = WebInputEvent::GesturePinchEnd;
- break;
- case ui::ET_GESTURE_TAP_CANCEL:
- gesture.type = WebInputEvent::GestureTapCancel;
- break;
- case ui::ET_GESTURE_TAP_DOWN:
- gesture.type = WebInputEvent::GestureTapDown;
- gesture.data.tapDown.width = data.details.tap_down.width * scale;
- gesture.data.tapDown.height = data.details.tap_down.height * scale;
- break;
- default:
- NOTREACHED() << "ui::EventType provided wasn't a gesture event.";
- break;
- }
-
- return gesture;
-}
-
-ui::TouchDispositionGestureFilter::TouchEventAck
-ToTouchDispositionGestureFilterAck(InputEventAckState ack_state) {
- switch (ack_state) {
- case INPUT_EVENT_ACK_STATE_CONSUMED:
- return ui::TouchDispositionGestureFilter::CONSUMED;
- case INPUT_EVENT_ACK_STATE_NOT_CONSUMED:
- return ui::TouchDispositionGestureFilter::NOT_CONSUMED;
- case INPUT_EVENT_ACK_STATE_NO_CONSUMER_EXISTS:
- return ui::TouchDispositionGestureFilter::NO_CONSUMER_EXISTS;
- case INPUT_EVENT_ACK_STATE_IGNORED:
- return ui::TouchDispositionGestureFilter::CONSUMED;
- case INPUT_EVENT_ACK_STATE_UNKNOWN:
- break;
- };
- NOTREACHED() << "Invalid ack state: " << ack_state;
- return ui::TouchDispositionGestureFilter::NO_CONSUMER_EXISTS;
-}
-
-ui::GestureProvider::Config GetGestureProviderConfig() {
- ui::GestureProvider::Config config = ui::DefaultGestureProviderConfig();
-#if defined(OS_ANDROID)
- config.disable_click_delay =
- CommandLine::ForCurrentProcess()->HasSwitch(switches::kDisableClickDelay);
-#endif
- return config;
-}
-
-} // namespace
-
-ContentGestureProvider::ContentGestureProvider(
- ContentGestureProviderClient* client,
- float touch_to_gesture_scale)
- : client_(client),
- touch_to_gesture_scale_(touch_to_gesture_scale),
- gesture_provider_(GetGestureProviderConfig(), this),
- gesture_filter_(this),
- handling_event_(false) {}
-
-bool ContentGestureProvider::OnTouchEvent(const ui::MotionEvent& event) {
- DCHECK(!handling_event_);
- base::AutoReset<bool> handling_event(&handling_event_, true);
-
- pending_gesture_packet_ = ui::GestureEventDataPacket::FromTouch(event);
-
- if (!gesture_provider_.OnTouchEvent(event))
- return false;
-
- ui::TouchDispositionGestureFilter::PacketResult result =
- gesture_filter_.OnGesturePacket(pending_gesture_packet_);
- if (result != ui::TouchDispositionGestureFilter::SUCCESS) {
- NOTREACHED() << "Invalid touch gesture sequence detected.";
- return false;
- }
-
- return true;
-}
-
-void ContentGestureProvider::OnTouchEventAck(InputEventAckState ack_state) {
- DCHECK_NE(INPUT_EVENT_ACK_STATE_UNKNOWN, ack_state);
- gesture_filter_.OnTouchEventAck(
- ToTouchDispositionGestureFilterAck(ack_state));
-}
-
-void ContentGestureProvider::ResetGestureDetectors() {
- gesture_provider_.ResetGestureDetectors();
-}
-
-void ContentGestureProvider::SetMultiTouchSupportEnabled(bool enabled) {
- gesture_provider_.SetMultiTouchSupportEnabled(enabled);
-}
-
-void ContentGestureProvider::SetDoubleTapSupportForPlatformEnabled(
- bool enabled) {
- gesture_provider_.SetDoubleTapSupportForPlatformEnabled(enabled);
-}
-
-void ContentGestureProvider::SetDoubleTapSupportForPageEnabled(bool enabled) {
- gesture_provider_.SetDoubleTapSupportForPageEnabled(enabled);
-}
-
-const ui::MotionEvent* ContentGestureProvider::GetCurrentDownEvent() const {
- return gesture_provider_.current_down_event();
-}
-
-void ContentGestureProvider::OnGestureEvent(
- const ui::GestureEventData& event) {
- if (handling_event_) {
- pending_gesture_packet_.Push(event);
- return;
- }
-
- gesture_filter_.OnGesturePacket(
- ui::GestureEventDataPacket::FromTouchTimeout(event));
-}
-
-void ContentGestureProvider::ForwardGestureEvent(
- const ui::GestureEventData& event) {
- client_->OnGestureEvent(CreateGesture(event, touch_to_gesture_scale_));
-}
-
-} // namespace content

Powered by Google App Engine
This is Rietveld 408576698