summaryrefslogtreecommitdiffhomepage
path: root/tracker-rift-140/rift-140.hpp
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2016-11-02 11:55:41 +0100
committerStanislaw Halik <sthalik@misaki.pl>2016-11-02 11:55:41 +0100
commit47c4dbe1fef2af9eaa7d38845e83544320bd0631 (patch)
treeffad8d6e349cea890776bc70104466d9061b97c6 /tracker-rift-140/rift-140.hpp
parentf7e622e4f1fea8a49fc1555d446cc76f78d5592c (diff)
tracker/rift-140: add
Diffstat (limited to 'tracker-rift-140/rift-140.hpp')
-rw-r--r--tracker-rift-140/rift-140.hpp60
1 files changed, 60 insertions, 0 deletions
diff --git a/tracker-rift-140/rift-140.hpp b/tracker-rift-140/rift-140.hpp
new file mode 100644
index 00000000..912f8587
--- /dev/null
+++ b/tracker-rift-140/rift-140.hpp
@@ -0,0 +1,60 @@
+#pragma once
+#include "ui_dialog.h"
+#include "api/plugin-api.hpp"
+#include "options/options.hpp"
+#include <OVR_CAPI.h>
+#include <cmath>
+#include <QMessageBox>
+#include <QWaitCondition>
+using namespace options;
+
+struct settings : opts {
+ value<bool> useYawSpring;
+ value<double> constant_drift, persistence, deadzone;
+ settings() :
+ opts("Rift-140"),
+ useYawSpring(b, "yaw-spring", false),
+ constant_drift(b, "constant-drift", 0.000005),
+ persistence(b, "persistence", 0.99999),
+ deadzone(b, "deadzone", 0.02)
+ {}
+};
+
+class Rift_Tracker : public ITracker
+{
+public:
+ Rift_Tracker();
+ ~Rift_Tracker() override;
+ void start_tracker(QFrame *) override;
+ void data(double *data) override;
+private:
+ double old_yaw;
+ ovrSession hmd;
+ ovrGraphicsLuid luid;
+ settings s;
+};
+
+class TrackerControls: public ITrackerDialog
+{
+ Q_OBJECT
+public:
+ TrackerControls();
+
+ void register_tracker(ITracker *) {}
+ void unregister_tracker() {}
+
+private:
+ Ui::UIRiftControls ui;
+ settings s;
+private slots:
+ void doOK();
+ void doCancel();
+};
+
+class FTNoIR_TrackerDll : public Metadata
+{
+public:
+ QString name() { return QString("Oculus Rift runtime 1.4.0 -- HMD"); }
+ QIcon icon() { return QIcon(":/images/rift_tiny.png"); }
+};
+