Chromium Code Reviews| Index: content/browser/renderer_host/input/motion_event_web.cc |
| diff --git a/content/browser/renderer_host/input/motion_event_web.cc b/content/browser/renderer_host/input/motion_event_web.cc |
| index 82b6ed7861b6cd2c5c3fbe0fe8cc853b8d7c7772..eeb2124901acd3de0185911b4f57b1f089731767 100644 |
| --- a/content/browser/renderer_host/input/motion_event_web.cc |
| +++ b/content/browser/renderer_host/input/motion_event_web.cc |
| @@ -130,26 +130,58 @@ float MotionEventWeb::GetTouchMinor(size_t pointer_index) const { |
| float MotionEventWeb::GetOrientation(size_t pointer_index) const { |
| DCHECK_LT(pointer_index, GetPointerCount()); |
| - float rotation_angle_rad = event_.touches[pointer_index].rotationAngle |
| + float orientation_rad = event_.touches[pointer_index].rotationAngle |
| * M_PI / 180.f; |
| - DCHECK(0 <= rotation_angle_rad && rotation_angle_rad <= M_PI_2) |
| + DCHECK(0 <= orientation_rad && orientation_rad <= M_PI_2) |
| << "Unexpected touch rotation angle"; |
| - if (event_.touches[pointer_index].radiusX |
| - > event_.touches[pointer_index].radiusY) { |
| + if (GetToolType(pointer_index) == TOOL_TYPE_STYLUS) { |
| + const WebPointerProperties& pointer = event_.touches[pointer_index]; |
| + |
|
jdduke (slow)
2015/08/12 17:00:12
I think we'll want some basic test coverage for th
|
| + if (pointer.tiltY < 0) { |
| + if (pointer.tiltX < 0) |
| + orientation_rad += M_PI_2; |
| + else |
| + orientation_rad -= M_PI; |
| + } else { |
| + if (pointer.tiltX > 0) |
| + orientation_rad -= M_PI_2; |
| + } |
| + } else if (event_.touches[pointer_index].radiusX |
| + > event_.touches[pointer_index].radiusY) { |
| // The case radiusX == radiusY is omitted from here on purpose: for circles, |
| // we want to pass the angle (which could be any value in such cases but |
| // always seem to be set to zero) unchanged. |
| - rotation_angle_rad -= (float) M_PI_2; |
| + orientation_rad -= (float) M_PI_2; |
| } |
| - return rotation_angle_rad; |
| + return orientation_rad; |
| } |
| float MotionEventWeb::GetPressure(size_t pointer_index) const { |
| return 0.f; |
| } |
| +float MotionEventWeb::GetTilt(size_t pointer_index) const { |
| + DCHECK_LT(pointer_index, GetPointerCount()); |
| + |
| + if (GetToolType(pointer_index) != TOOL_TYPE_STYLUS) |
| + return 0.f; |
| + |
|
jdduke (slow)
2015/08/12 17:00:13
Same here, a few basic test cases would be nice. W
|
| + const WebPointerProperties& pointer = event_.touches[pointer_index]; |
| + |
| + float tilt_x_r = sin(pointer.tiltX * M_PI / 180.f); |
| + float tilt_x_z = cos(pointer.tiltX * M_PI / 180.f); |
| + float tilt_y_r = sin(pointer.tiltY * M_PI / 180.f); |
| + float tilt_y_z = cos(pointer.tiltY * M_PI / 180.f); |
| + float r_x = tilt_x_r * tilt_y_z; |
| + float r_y = tilt_y_r * tilt_x_z; |
| + float r = sqrt(r_x * r_x + r_y * r_y); |
| + float z = tilt_x_z * tilt_y_z; |
| + |
| + return atan2(r, z); |
| +} |
| + |
| base::TimeTicks MotionEventWeb::GetEventTime() const { |
| return base::TimeTicks() + |
| base::TimeDelta::FromMicroseconds(event_.timeStampSeconds * |