From 279d560f792ccf5175c9bc25ae82314a12a1ddeb Mon Sep 17 00:00:00 2001 From: nanthony21 Date: Sat, 25 Mar 2017 18:28:00 -0500 Subject: [PATCH] Revert "Removed code that cut off the last 25% of joystick motion in either direction. I'm not sure what the original purpose of this code was." This reverts commit 4c34fb38f22e1b405b2b32cb760b442b86ca401b. --- src/Joystick/Joystick.cc | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/Joystick/Joystick.cc b/src/Joystick/Joystick.cc index 19f97a29d6..27869d09c9 100644 --- a/src/Joystick/Joystick.cc +++ b/src/Joystick/Joystick.cc @@ -438,6 +438,18 @@ void Joystick::run(void) throttle_accu = std::max(static_cast(-1.f), std::min(throttle_accu, static_cast(1.f))); throttle = throttle_accu; } + + float roll_limited = std::max(static_cast(-M_PI_4), std::min(roll, static_cast(M_PI_4))); + float pitch_limited = std::max(static_cast(-M_PI_4), std::min(pitch, static_cast(M_PI_4))); + float yaw_limited = std::max(static_cast(-M_PI_4), std::min(yaw, static_cast(M_PI_4))); + float throttle_limited = std::max(static_cast(-M_PI_4), std::min(throttle, static_cast(M_PI_4))); + + // Map from unit circle to linear range and limit + roll = std::max(-1.0f, std::min(tanf(asinf(roll_limited)), 1.0f)); + pitch = std::max(-1.0f, std::min(tanf(asinf(pitch_limited)), 1.0f)); + yaw = std::max(-1.0f, std::min(tanf(asinf(yaw_limited)), 1.0f)); + throttle = std::max(-1.0f, std::min(tanf(asinf(throttle_limited)), 1.0f)); + if ( _exponential ) { // Exponential (0% to -50% range like most RC radios) // 0 for no exponential -- GitLab