diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2016-11-03 23:42:02 +0100 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2016-11-06 12:28:26 +0100 |
commit | 049044f181414991a103ace961214c78171c284d (patch) | |
tree | 1806ff05675c62df05d9e16623ea8c7a87395ec3 /tracker-steamvr/steamvr.hpp | |
parent | ad1e96c576425a4daba20073e99ec0337f193882 (diff) |
tracker/steamvr: TO REBASE
Diffstat (limited to 'tracker-steamvr/steamvr.hpp')
-rw-r--r-- | tracker-steamvr/steamvr.hpp | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/tracker-steamvr/steamvr.hpp b/tracker-steamvr/steamvr.hpp new file mode 100644 index 00000000..2947f3f1 --- /dev/null +++ b/tracker-steamvr/steamvr.hpp @@ -0,0 +1,66 @@ +#pragma once +#include "api/plugin-api.hpp" +#include "ui_dialog.h" +#include "compat/util.hpp" +#include "options/options.hpp" + +#include <openvr.h> + +#include <atomic> +#include <cmath> +#include <memory> + +#include <QString> +#include <QMutex> +#include <QMutexLocker> + +using namespace options; + +struct settings : opts +{ + settings() : opts("valve-steamvr") {} +}; + +class steamvr : public ITracker +{ +public: + steamvr(); + ~steamvr() override; + void start_tracker(QFrame *) override; + void data(double *data) override; +private: + using error_t = vr::EVRInitError; + using vr_t = vr::IVRSystem*; + + vr_t vr; + + settings s; + static void vr_deleter(); + static vr_t vr_init(error_t& error); + static QString strerror(error_t error); +}; + +class dialog : public ITrackerDialog +{ + Q_OBJECT +public: + dialog(); + + void register_tracker(ITracker *) override; + void unregister_tracker() override; +private: + Ui::dialog ui; + settings s; + vr::IVRSystem* vr; +private slots: + void doOK(); + void doCancel(); +}; + +class metadata : public Metadata +{ +public: + QString name() { return QString(QCoreApplication::translate("metadata", "Valve SteamVR")); } + QIcon icon() { return QIcon(":/images/rift_tiny.png"); } +}; + |