summaryrefslogtreecommitdiffhomepage
path: root/protocol-mouse/ftnoir_protocol_mouse.cpp
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2015-10-30 09:01:32 +0100
committerStanislaw Halik <sthalik@misaki.pl>2015-10-30 09:01:32 +0100
commitd785d3616500d5846ac8c5f5a6347da832a593b4 (patch)
treeac670a125c5b880ad7e4b4f24a8635da4e66f0da /protocol-mouse/ftnoir_protocol_mouse.cpp
parent232c2ba8aca7900eaa950c48813ddfaca8a749a8 (diff)
parent9b736d361bcde7a2ddaf3fe54b471c0e658e94f4 (diff)
Merge branch 'unstable' into trackhat
* unstable: cmake: cleanup hydra rename gui directory move to subdirectory-based build system cmake: switch to GNU CC 5.2.0 in mingw-w64 toolchain file rift-080: forgot ovr_Initialize() rift 025: fix name
Diffstat (limited to 'protocol-mouse/ftnoir_protocol_mouse.cpp')
-rw-r--r--protocol-mouse/ftnoir_protocol_mouse.cpp54
1 files changed, 54 insertions, 0 deletions
diff --git a/protocol-mouse/ftnoir_protocol_mouse.cpp b/protocol-mouse/ftnoir_protocol_mouse.cpp
new file mode 100644
index 00000000..c0a0a868
--- /dev/null
+++ b/protocol-mouse/ftnoir_protocol_mouse.cpp
@@ -0,0 +1,54 @@
+/* Copyright (c) 2015 Stanislaw Halik <sthalik@misaki.pl>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ */
+#include "ftnoir_protocol_mouse.h"
+#include "opentrack/plugin-api.hpp"
+#include <windows.h>
+
+#ifndef MOUSEEVENTF_MOVE_NOCOALESCE
+# define MOUSEEVENTF_MOVE_NOCOALESCE 0x2000
+#endif
+
+void FTNoIR_Protocol::pose(const double *headpose ) {
+ RECT desktop;
+ const HWND hDesktop = GetDesktopWindow();
+ if (hDesktop != NULL && GetWindowRect(hDesktop, &desktop)) {
+ // XXX TODO remove axis selector, use mapping window's
+ // axis selection. Mention in UI axis used. -sh 20140920
+ int axis_x = s.Mouse_X;
+ int axis_y = s.Mouse_Y;
+
+ int mouse_x = 0, mouse_y = 0;
+
+ if (axis_x > 0 && axis_x <= 6)
+ mouse_x = headpose[axis_x-1] / (axis_x <= 3 ? 100 : 180) * 10 * desktop.right/2;
+
+ if (axis_y > 0 && axis_y <= 6)
+ mouse_y = headpose[axis_y-1] / (axis_y <= 3 ? 100 : 180) * 10 * desktop.bottom/2;
+
+ MOUSEINPUT mi;
+ mi.dx = mouse_x - last_x;
+ mi.dy = mouse_y - last_y;
+ mi.mouseData = 0;
+ mi.dwFlags = MOUSEEVENTF_MOVE | MOUSEEVENTF_MOVE_NOCOALESCE;
+ mi.time = 0;
+ mi.dwExtraInfo = 0;
+ INPUT input;
+ input.type = INPUT_MOUSE;
+ input.mi = mi;
+ (void) SendInput(1, &input, sizeof(INPUT));
+
+ last_x = mouse_x;
+ last_y = mouse_y;
+ }
+}
+
+bool FTNoIR_Protocol::correct()
+{
+ return true;
+}
+
+OPENTRACK_DECLARE_PROTOCOL(FTNoIR_Protocol, MOUSEControls, FTNoIR_ProtocolDll)