/* Copyright (c) 2013 Stanislaw Halik * * 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_tracker_joystick.h" #include "api/plugin-api.hpp" #include "compat/math.hpp" #include joystick::joystick() { if (s.guid->isEmpty()) { std::vector info = joy_ctx.get_joy_info(); if (!info.empty()) { s.guid = info[0].guid; s.b->save(); } } } joystick::~joystick() = default; void joystick::data(double *data) { int map[6] = { s.joy_1 - 1, s.joy_2 - 1, s.joy_3 - 1, s.joy_4 - 1, s.joy_5 - 1, s.joy_6 - 1, }; const double limits[] = { 100, 100, 100, 180, 180, 180 }; const QString guid = s.guid; int axes[8]; const bool ret = joy_ctx.poll_axis(guid, axes); if (ret) { for (int i = 0; i < 6; i++) { int k = map[i] - 1; if (k < 0 || k >= 8) data[i] = 0; else data[i] = std::clamp(axes[k] * limits[i] / AXIS_MAX, -limits[i], limits[i]); } } } OPENTRACK_DECLARE_TRACKER(joystick, dialog_joystick, joystickDll)