summaryrefslogtreecommitdiffhomepage
path: root/tracker-rift-042/ftnoir_tracker_rift_042.cpp
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2016-10-01 16:49:34 +0200
committerStanislaw Halik <sthalik@misaki.pl>2016-10-01 16:49:34 +0200
commitb5e67864360d98145c67130bfdb3c4c56963c787 (patch)
treebca80d2b41eacf30205ef91ee09d043dba063ca3 /tracker-rift-042/ftnoir_tracker_rift_042.cpp
parent29406db336d00a223fec9035044a5ca46ade1d3f (diff)
tracker/rift-{025,042,080}: fix gimbal lockopentrack-2.3-rc99p13
It was tested only on 080 but the API is almost the same on 042 and 025. Issue: #464 Reported-by: @Jerrow
Diffstat (limited to 'tracker-rift-042/ftnoir_tracker_rift_042.cpp')
-rw-r--r--tracker-rift-042/ftnoir_tracker_rift_042.cpp21
1 files changed, 15 insertions, 6 deletions
diff --git a/tracker-rift-042/ftnoir_tracker_rift_042.cpp b/tracker-rift-042/ftnoir_tracker_rift_042.cpp
index c868eee8..1b819328 100644
--- a/tracker-rift-042/ftnoir_tracker_rift_042.cpp
+++ b/tracker-rift-042/ftnoir_tracker_rift_042.cpp
@@ -53,10 +53,19 @@ void Rift_Tracker::data(double *data)
ovrTrackingState ss = ovrHmd_GetTrackingState(hmd, 0);
if (ss.StatusFlags & ovrStatus_OrientationTracked)
{
- auto pose = ss.HeadPose.ThePose;
- Quatf quat = pose.Orientation;
+ static constexpr float c_mult = 8;
+ static constexpr float c_div = 1/c_mult;
+
+ Vector3f axis;
+ float angle;
+
+ const Posef pose(ss.HeadPose.ThePose);
+ pose.Rotation.GetAxisAngle(&axis, &angle);
+ angle *= c_div;
+
float yaw, pitch, roll;
- quat.GetEulerAngles<Axis_Y, Axis_X, Axis_Z>(&yaw, &pitch, &roll);
+ Quatf(axis, angle).GetEulerAngles<Axis_Y, Axis_X, Axis_Z>(&yaw, &pitch, &roll);
+
double yaw_ = double(yaw);
if (s.useYawSpring)
{
@@ -71,9 +80,9 @@ void Rift_Tracker::data(double *data)
data[Yaw] = yaw_ * -d2r;
data[Pitch] = double(pitch) * d2r;
data[Roll] = double(roll) * d2r;
- data[TX] = double(pose.Position.x) * -1e2;
- data[TY] = double(pose.Position.y) * 1e2;
- data[TZ] = double(pose.Position.z) * 1e2;
+ data[TX] = double(pose.Translation.x) * -1e2;
+ data[TY] = double(pose.Translation.y) * 1e2;
+ data[TZ] = double(pose.Translation.z) * 1e2;
}
}
}