From fb2e87032d3a5a99ed2a4dda3c5ebcafbfa4af11 Mon Sep 17 00:00:00 2001 From: Jacob Walser Date: Thu, 26 Oct 2017 14:24:15 -0400 Subject: [PATCH] Sub: use configured rc input range for lights input instead of hard coded values --- ArduSub/joystick.cpp | 41 +++++++++++++++++++++++++++++++---------- ArduSub/radio.cpp | 11 +++++++++-- 2 files changed, 40 insertions(+), 12 deletions(-) diff --git a/ArduSub/joystick.cpp b/ArduSub/joystick.cpp index 1a2d648cf6..682913f131 100644 --- a/ArduSub/joystick.cpp +++ b/ArduSub/joystick.cpp @@ -30,6 +30,9 @@ void Sub::init_joystick() { default_js_buttons(); + lights1 = RC_Channels::rc_channel(8)->get_radio_min(); + lights2 = RC_Channels::rc_channel(9)->get_radio_min(); + set_mode(MANUAL, MODE_REASON_TX_COMMAND); // Initialize flight mode if (g.numGainSettings < 1) { @@ -195,47 +198,65 @@ void Sub::handle_jsbutton_press(uint8_t button, bool shift, bool held) case JSButton::button_function_t::k_lights1_cycle: if (!held) { static bool increasing = true; + RC_Channel* chan = RC_Channels::rc_channel(8); + uint16_t min = chan->get_radio_min(); + uint16_t max = chan->get_radio_max(); if (increasing) { - lights1 = constrain_float(lights1+g.lights_step,1100,1900); + lights1 = constrain_float(lights1+g.lights_step, min, max); } else { - lights1 = constrain_float(lights1-g.lights_step,1100,1900); + lights1 = constrain_float(lights1-g.lights_step, min, max); } - if (lights1 >= 1900 || lights1 <= 1100) { + if (lights1 >= max || lights1 <= min) { increasing = !increasing; } } break; case JSButton::button_function_t::k_lights1_brighter: if (!held) { - lights1 = constrain_float(lights1+g.lights_step,1100,1900); + RC_Channel* chan = RC_Channels::rc_channel(8); + uint16_t min = chan->get_radio_min(); + uint16_t max = chan->get_radio_max(); + lights1 = constrain_float(lights1+g.lights_step, min, max); } break; case JSButton::button_function_t::k_lights1_dimmer: if (!held) { - lights1 = constrain_float(lights1-g.lights_step,1100,1900); + RC_Channel* chan = RC_Channels::rc_channel(8); + uint16_t min = chan->get_radio_min(); + uint16_t max = chan->get_radio_max(); + lights1 = constrain_float(lights1-g.lights_step, min, max); } break; case JSButton::button_function_t::k_lights2_cycle: if (!held) { static bool increasing = true; + RC_Channel* chan = RC_Channels::rc_channel(9); + uint16_t min = chan->get_radio_min(); + uint16_t max = chan->get_radio_max(); if (increasing) { - lights2 = constrain_float(lights2+g.lights_step,1100,1900); + lights2 = constrain_float(lights2+g.lights_step, min, max); } else { - lights2 = constrain_float(lights2-g.lights_step,1100,1900); + lights2 = constrain_float(lights2-g.lights_step, min, max); } - if (lights2 >= 1900 || lights2 <= 1100) { + if (lights2 >= max || lights2 <= min) { increasing = !increasing; } } break; case JSButton::button_function_t::k_lights2_brighter: if (!held) { - lights2 = constrain_float(lights2+g.lights_step,1100,1900); + RC_Channel* chan = RC_Channels::rc_channel(9); + uint16_t min = chan->get_radio_min(); + uint16_t max = chan->get_radio_max(); + lights2 = constrain_float(lights2+g.lights_step, min, max); } break; case JSButton::button_function_t::k_lights2_dimmer: if (!held) { - lights2 = constrain_float(lights2-g.lights_step,1100,1900); + RC_Channel* chan = RC_Channels::rc_channel(9); + uint16_t min = chan->get_radio_min(); + uint16_t max = chan->get_radio_max(); + lights2 = constrain_float(lights2-g.lights_step, min, max); } break; case JSButton::button_function_t::k_gain_toggle: diff --git a/ArduSub/radio.cpp b/ArduSub/radio.cpp index 4f17cfba5d..88220604af 100644 --- a/ArduSub/radio.cpp +++ b/ArduSub/radio.cpp @@ -32,8 +32,15 @@ void Sub::init_rc_in() } hal.rcin->set_override(7, 1500); // camera tilt channel - hal.rcin->set_override(8, 1100); // lights 1 channel - hal.rcin->set_override(9, 1100); // lights 2 channel + + RC_Channel* chan = RC_Channels::rc_channel(8); + uint16_t min = chan->get_radio_min(); + hal.rcin->set_override(8, min); // lights 1 channel + + chan = RC_Channels::rc_channel(9); + min = chan->get_radio_min(); + hal.rcin->set_override(9, min); // lights 2 channel + hal.rcin->set_override(10, 1100); // video switch #endif }