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

Unified Diff: ui/aura/gestures/gesture_point.cc

Issue 9104021: aura: Update GestureRecognizer to be able to process multi-point gestures. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 11 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: ui/aura/gestures/gesture_point.cc
diff --git a/ui/aura/gestures/gesture_point.cc b/ui/aura/gestures/gesture_point.cc
new file mode 100644
index 0000000000000000000000000000000000000000..1ff1754dc0ea0ef50f0222bafaff0c6d8a61c8d7
--- /dev/null
+++ b/ui/aura/gestures/gesture_point.cc
@@ -0,0 +1,94 @@
+// Copyright (c) 2012 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 "ui/aura/gestures/gesture_point.h"
+
+#include "ui/aura/event.h"
+#include "ui/base/events.h"
+
+namespace {
+
+// TODO(girard): Make these configurable in sync with this CL
+// http://crbug.com/100773
+const double kMaximumTouchDownDurationInSecondsForClick = 0.8;
+const double kMinimumTouchDownDurationInSecondsForClick = 0.01;
+const double kMaximumSecondsBetweenDoubleClick = 0.7;
+const int kMaximumTouchMoveInPixelsForClick = 20;
+const float kMinFlickSpeedSquared = 550.f * 550.f;
+
+} // namespace aura
+
+namespace aura {
+
+GesturePoint::GesturePoint()
+ : first_touch_time_(0.0),
+ last_touch_time_(0.0),
+ last_click_time_(0.0),
+ x_velocity_(0.0),
+ y_velocity_(0.0) {
+}
+
+void GesturePoint::Reset() {
+ first_touch_time_ = last_touch_time_ = 0.0;
+ x_velocity_ = y_velocity_ = 0.0;
+}
+
+void GesturePoint::UpdateValues(const TouchEvent& event, GestureState state) {
+ if (state != GS_NO_GESTURE && event.type() == ui::ET_TOUCH_MOVED) {
+ double interval(event.time_stamp().InSecondsF() - last_touch_time_);
+ x_velocity_ = (event.x() - last_touch_position_.x()) / interval;
+ y_velocity_ = (event.y() - last_touch_position_.y()) / interval;
+ }
+
+ last_touch_time_ = event.time_stamp().InSecondsF();
+ last_touch_position_ = event.location();
+
+ if (state == GS_NO_GESTURE) {
+ first_touch_time_ = last_touch_time_;
+ first_touch_position_ = event.location();
+ x_velocity_ = 0.0;
+ y_velocity_ = 0.0;
+ }
+}
+
+void GesturePoint::UpdateForTap() {
+ last_click_time_ = last_touch_time_;
+ last_click_position_ = last_touch_position_;
+ Reset();
+}
+
+void GesturePoint::UpdateForScroll() {
+ first_touch_position_ = last_touch_position_;
+}
+
+bool GesturePoint::IsInClickTimeWindow() const {
+ double duration(last_touch_time_ - first_touch_time_);
+ return duration >= kMinimumTouchDownDurationInSecondsForClick &&
+ duration < kMaximumTouchDownDurationInSecondsForClick;
+}
+
+bool GesturePoint::IsInSecondClickTimeWindow() const {
+ double duration(last_touch_time_ - last_click_time_);
+ return duration < kMaximumSecondsBetweenDoubleClick;
+}
+
+bool GesturePoint::IsInsideManhattanSquare(const TouchEvent& event) const {
+ int manhattanDistance = abs(event.x() - first_touch_position_.x()) +
+ abs(event.y() - first_touch_position_.y());
+ return manhattanDistance < kMaximumTouchMoveInPixelsForClick;
+}
+
+bool GesturePoint::IsSecondClickInsideManhattanSquare(
+ const TouchEvent& event) const {
+ int manhattanDistance = abs(event.x() - last_click_position_.x()) +
+ abs(event.y() - last_click_position_.y());
+ return manhattanDistance < kMaximumTouchMoveInPixelsForClick;
+}
+
+bool GesturePoint::IsOverMinFlickSpeed() const {
+ return (x_velocity_ * x_velocity_ + y_velocity_ * y_velocity_) >
+ kMinFlickSpeedSquared;
+}
+
+} // namespace aura

Powered by Google App Engine
This is Rietveld 408576698