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

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

Issue 2860793003: Pass through tilt_x and tilt_y to blink (Closed)
Patch Set: Pass through tilt_x and tilt_y to blink Created 3 years, 7 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/motion_event_web_unittest.cc
diff --git a/content/browser/renderer_host/input/motion_event_web_unittest.cc b/content/browser/renderer_host/input/motion_event_web_unittest.cc
index df2f2305f510c8e0e034d504f7f355b0521b0188..a6facadcd3673628f168eccaed7f0dd24dabe216 100644
--- a/content/browser/renderer_host/input/motion_event_web_unittest.cc
+++ b/content/browser/renderer_host/input/motion_event_web_unittest.cc
@@ -23,9 +23,9 @@ namespace content {
TEST(MotionEventWebTest, Constructor) {
const float pi = static_cast<float>(M_PI);
- const float orientations[] = {
- -pi, -2.f * pi / 3, -pi / 2, -pi / 3, 0.f, pi / 3, pi / 2, 2.f * pi / 3};
- const float tilts[] = {0.f, pi / 4, pi / 3};
+ const float orientations[] = {-pi, -2.f * pi / 3, -pi / 2};
+ const float tilts_x[] = {0.f, -180 / 4, -180 / 3};
+ const float tilts_y[] = {0.5f, 180 / 2, 180 / 3};
const MotionEvent::ToolType tool_types[] = {MotionEvent::TOOL_TYPE_FINGER,
MotionEvent::TOOL_TYPE_STYLUS,
MotionEvent::TOOL_TYPE_MOUSE};
@@ -33,48 +33,52 @@ TEST(MotionEventWebTest, Constructor) {
base::TimeTicks event_time = base::TimeTicks::Now();
PointerProperties pp;
MotionEventGeneric generic_event(MotionEvent::ACTION_MOVE, event_time, pp);
-
for (MotionEvent::ToolType tool_type : tool_types) {
- for (float orientation : orientations) {
- for (float tilt : tilts) {
- PointerProperties pp2;
- pp2.orientation = orientation;
- pp2.tilt = tilt;
- pp2.tool_type = tool_type;
- size_t pointer_index = generic_event.PushPointer(pp2);
- EXPECT_GT(pointer_index, 0u);
-
- blink::WebTouchEvent web_touch_event =
- CreateWebTouchEventFromMotionEvent(generic_event, true);
+ for (size_t i = 0; i < arraysize(tilts_x); ++i) {
+ const float tilt_x = tilts_x[i];
+ const float tilt_y = tilts_y[i];
+ const float orientation = orientations[i];
+ PointerProperties pp2;
+ pp2.orientation = orientation;
+ pp2.tilt_x = tilt_x;
+ pp2.tilt_y = tilt_y;
+ pp2.tool_type = tool_type;
+ size_t pointer_index = generic_event.PushPointer(pp2);
+ EXPECT_GT(pointer_index, 0u);
- MotionEventWeb event(web_touch_event);
- EXPECT_EQ(tool_type, event.GetToolType(pointer_index));
- if (tool_type == MotionEvent::TOOL_TYPE_STYLUS) {
- // Web touch event touch point tilt plane angles are stored as ints,
- // thus the tilt precision is 1 degree and the error should not be
- // greater than 0.5 degrees.
- EXPECT_NEAR(tilt, event.GetTilt(pointer_index), 0.5f * M_PI / 180.f)
- << " orientation=" << orientation;
- } else {
- EXPECT_EQ(0.f, event.GetTilt(pointer_index));
- }
- if (tool_type == MotionEvent::TOOL_TYPE_STYLUS && tilt > 0.f) {
- // Full stylus tilt orientation information survives above event
- // conversions only if there is a non-zero stylus tilt angle.
- // See: http://crbug.com/251330
- EXPECT_NEAR(orientation, event.GetOrientation(pointer_index), 1e-4)
- << " tilt=" << tilt;
- } else {
- // For non-stylus pointers and for styluses with a zero tilt angle,
- // orientation quadrant information is lost.
- EXPECT_NEAR(fmod(orientation + M_PI + 1e-4, M_PI_2) - 1e-4,
- event.GetOrientation(pointer_index), 1e-4);
- }
+ blink::WebTouchEvent web_touch_event =
+ CreateWebTouchEventFromMotionEvent(generic_event, true);
- generic_event.RemovePointerAt(pointer_index);
+ MotionEventWeb event(web_touch_event);
+ EXPECT_EQ(tool_type, event.GetToolType(pointer_index));
+ if (tool_type == MotionEvent::TOOL_TYPE_STYLUS) {
+ // Web touch event touch point tilt plane angles are stored as ints,
+ // thus the tilt precision is 1 degree and the error should not be
+ // greater than 0.5 degrees.
+ EXPECT_NEAR(tilt_x, event.GetTiltX(pointer_index), 0.5)
+ << " orientation=" << orientation;
+ EXPECT_NEAR(tilt_y, event.GetTiltY(pointer_index), 0.5)
+ << " orientation=" << orientation;
+ } else {
+ EXPECT_EQ(0.f, event.GetTiltX(pointer_index));
+ EXPECT_EQ(0.f, event.GetTiltY(pointer_index));
+ }
+ if (tool_type == MotionEvent::TOOL_TYPE_STYLUS && tilt_x > 0.f) {
+ // Full stylus tilt orientation information survives above event
+ // conversions only if there is a non-zero stylus tilt angle.
+ // See: http://crbug.com/251330
+ EXPECT_NEAR(orientation, event.GetOrientation(pointer_index), 1e-4)
+ << " tilt_x=" << tilt_x << " tilt_y=" << tilt_y;
+ } else {
+ // For non-stylus pointers and for styluses with a zero tilt angle,
+ // orientation quadrant information is lost.
+ EXPECT_NEAR(fmod(orientation + M_PI + 1e-4, M_PI_2) - 1e-4,
+ event.GetOrientation(pointer_index), 1e-4);
}
- }
+
+ generic_event.RemovePointerAt(pointer_index);
}
}
+}
} // namespace content

Powered by Google App Engine
This is Rietveld 408576698