Browse Source

RC_Channel: simplify the setup of aux channels

avoid the nasty mess of #if lines, as the info is in the constructor
anyway
mission-4.1.18
Andrew Tridgell 11 years ago
parent
commit
698736b66d
  1. 89
      libraries/RC_Channel/RC_Channel_aux.cpp
  2. 22
      libraries/RC_Channel/RC_Channel_aux.h

89
libraries/RC_Channel/RC_Channel_aux.cpp

@ -19,7 +19,8 @@ const AP_Param::GroupInfo RC_Channel_aux::var_info[] PROGMEM = {
AP_GROUPEND AP_GROUPEND
}; };
static RC_Channel_aux *_aux_channels[8]; RC_Channel_aux *RC_Channel_aux::_aux_channels[8];
uint32_t RC_Channel_aux::_function_mask;
/// map a function to a servo channel and output it /// map a function to a servo channel and output it
void void
@ -44,26 +45,10 @@ RC_Channel_aux::output_ch(unsigned char ch_nr)
/// Supports up to eight aux servo outputs (typically CH5 ... CH11) /// Supports up to eight aux servo outputs (typically CH5 ... CH11)
/// All servos must be configured with a single call to this function /// All servos must be configured with a single call to this function
/// (do not call this twice with different parameters, the second call will reset the effect of the first call) /// (do not call this twice with different parameters, the second call will reset the effect of the first call)
void update_aux_servo_function( RC_Channel_aux* rc_a, void RC_Channel_aux::update_aux_servo_function(void)
RC_Channel_aux* rc_b,
RC_Channel_aux* rc_c,
RC_Channel_aux* rc_d,
RC_Channel_aux* rc_e,
RC_Channel_aux* rc_f,
RC_Channel_aux* rc_g,
RC_Channel_aux* rc_h)
{ {
_aux_channels[0] = rc_a;
_aux_channels[1] = rc_b;
_aux_channels[2] = rc_c;
_aux_channels[3] = rc_d;
_aux_channels[4] = rc_e;
_aux_channels[5] = rc_f;
_aux_channels[6] = rc_g;
_aux_channels[7] = rc_h;
// set auxiliary ranges // set auxiliary ranges
for (uint8_t i = 0; i < 8; i++) { for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] == NULL) continue; if (_aux_channels[i] == NULL) continue;
RC_Channel_aux::Aux_servo_function_t function = (RC_Channel_aux::Aux_servo_function_t)_aux_channels[i]->function.get(); RC_Channel_aux::Aux_servo_function_t function = (RC_Channel_aux::Aux_servo_function_t)_aux_channels[i]->function.get();
switch (function) { switch (function) {
@ -86,14 +71,26 @@ void update_aux_servo_function( RC_Channel_aux* rc_a,
break; break;
} }
} }
// create a function mask to make updates master
_function_mask = 0;
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i]) {
RC_Channel_aux::Aux_servo_function_t function = (RC_Channel_aux::Aux_servo_function_t)_aux_channels[i]->function.get();
if (function < k_nr_aux_servo_functions) {
_function_mask |= (1UL<<(uint8_t)function);
}
}
}
} }
/// Should be called after the the servo functions have been initialized /// Should be called after the the servo functions have been initialized
void void RC_Channel_aux::enable_aux_servos()
enable_aux_servos()
{ {
update_aux_servo_function();
// enable all channels that are not set to k_none or k_nr_aux_servo_functions // enable all channels that are not set to k_none or k_nr_aux_servo_functions
for (uint8_t i = 0; i < 8; i++) { for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i]) { if (_aux_channels[i]) {
RC_Channel_aux::Aux_servo_function_t function = (RC_Channel_aux::Aux_servo_function_t)_aux_channels[i]->function.get(); RC_Channel_aux::Aux_servo_function_t function = (RC_Channel_aux::Aux_servo_function_t)_aux_channels[i]->function.get();
// see if it is a valid function // see if it is a valid function
@ -110,7 +107,10 @@ enable_aux_servos()
void void
RC_Channel_aux::set_radio(RC_Channel_aux::Aux_servo_function_t function, int16_t value) RC_Channel_aux::set_radio(RC_Channel_aux::Aux_servo_function_t function, int16_t value)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
_aux_channels[i]->radio_out = constrain_int16(value,_aux_channels[i]->radio_min,_aux_channels[i]->radio_max); _aux_channels[i]->radio_out = constrain_int16(value,_aux_channels[i]->radio_min,_aux_channels[i]->radio_max);
_aux_channels[i]->output(); _aux_channels[i]->output();
@ -125,7 +125,10 @@ RC_Channel_aux::set_radio(RC_Channel_aux::Aux_servo_function_t function, int16_t
void void
RC_Channel_aux::set_radio_trim(RC_Channel_aux::Aux_servo_function_t function) RC_Channel_aux::set_radio_trim(RC_Channel_aux::Aux_servo_function_t function)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
if (_aux_channels[i]->radio_in != 0) { if (_aux_channels[i]->radio_in != 0) {
_aux_channels[i]->radio_trim = _aux_channels[i]->radio_in; _aux_channels[i]->radio_trim = _aux_channels[i]->radio_in;
@ -141,7 +144,10 @@ RC_Channel_aux::set_radio_trim(RC_Channel_aux::Aux_servo_function_t function)
void void
RC_Channel_aux::set_radio_to_min(RC_Channel_aux::Aux_servo_function_t function) RC_Channel_aux::set_radio_to_min(RC_Channel_aux::Aux_servo_function_t function)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
_aux_channels[i]->radio_out = _aux_channels[i]->radio_min; _aux_channels[i]->radio_out = _aux_channels[i]->radio_min;
_aux_channels[i]->output(); _aux_channels[i]->output();
@ -155,7 +161,10 @@ RC_Channel_aux::set_radio_to_min(RC_Channel_aux::Aux_servo_function_t function)
void void
RC_Channel_aux::set_radio_to_max(RC_Channel_aux::Aux_servo_function_t function) RC_Channel_aux::set_radio_to_max(RC_Channel_aux::Aux_servo_function_t function)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
_aux_channels[i]->radio_out = _aux_channels[i]->radio_max; _aux_channels[i]->radio_out = _aux_channels[i]->radio_max;
_aux_channels[i]->output(); _aux_channels[i]->output();
@ -169,7 +178,10 @@ RC_Channel_aux::set_radio_to_max(RC_Channel_aux::Aux_servo_function_t function)
void void
RC_Channel_aux::set_radio_to_trim(RC_Channel_aux::Aux_servo_function_t function) RC_Channel_aux::set_radio_to_trim(RC_Channel_aux::Aux_servo_function_t function)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
_aux_channels[i]->radio_out = _aux_channels[i]->radio_trim; _aux_channels[i]->radio_out = _aux_channels[i]->radio_trim;
_aux_channels[i]->output(); _aux_channels[i]->output();
@ -183,7 +195,10 @@ RC_Channel_aux::set_radio_to_trim(RC_Channel_aux::Aux_servo_function_t function)
void void
RC_Channel_aux::copy_radio_in_out(RC_Channel_aux::Aux_servo_function_t function, bool do_input_output) RC_Channel_aux::copy_radio_in_out(RC_Channel_aux::Aux_servo_function_t function, bool do_input_output)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
if (do_input_output) { if (do_input_output) {
_aux_channels[i]->input(); _aux_channels[i]->input();
@ -202,7 +217,10 @@ RC_Channel_aux::copy_radio_in_out(RC_Channel_aux::Aux_servo_function_t function,
void void
RC_Channel_aux::set_servo_out(RC_Channel_aux::Aux_servo_function_t function, int16_t value) RC_Channel_aux::set_servo_out(RC_Channel_aux::Aux_servo_function_t function, int16_t value)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
_aux_channels[i]->servo_out = value; _aux_channels[i]->servo_out = value;
_aux_channels[i]->calc_pwm(); _aux_channels[i]->calc_pwm();
@ -217,11 +235,9 @@ RC_Channel_aux::set_servo_out(RC_Channel_aux::Aux_servo_function_t function, int
bool bool
RC_Channel_aux::function_assigned(RC_Channel_aux::Aux_servo_function_t function) RC_Channel_aux::function_assigned(RC_Channel_aux::Aux_servo_function_t function)
{ {
for (uint8_t i = 0; i < 8; i++) { if (function < k_nr_aux_servo_functions) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { return (_function_mask & (1UL<<function)) != 0;
return true; }
}
}
return false; return false;
} }
@ -233,7 +249,10 @@ void
RC_Channel_aux::move_servo(RC_Channel_aux::Aux_servo_function_t function, RC_Channel_aux::move_servo(RC_Channel_aux::Aux_servo_function_t function,
int16_t value, int16_t angle_min, int16_t angle_max) int16_t value, int16_t angle_min, int16_t angle_max)
{ {
for (uint8_t i = 0; i < 8; i++) { if (!function_assigned(function)) {
return;
}
for (uint8_t i = 0; i < RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] && _aux_channels[i]->function.get() == function) { if (_aux_channels[i] && _aux_channels[i]->function.get() == function) {
_aux_channels[i]->servo_out = value; _aux_channels[i]->servo_out = value;
_aux_channels[i]->set_range(angle_min, angle_max); _aux_channels[i]->set_range(angle_min, angle_max);

22
libraries/RC_Channel/RC_Channel_aux.h

@ -9,6 +9,8 @@
#include "RC_Channel.h" #include "RC_Channel.h"
#define RC_AUX_MAX_CHANNELS 8
/// @class RC_Channel_aux /// @class RC_Channel_aux
/// @brief Object managing one aux. RC channel (CH5-8), with information about its function /// @brief Object managing one aux. RC channel (CH5-8), with information about its function
class RC_Channel_aux : public RC_Channel { class RC_Channel_aux : public RC_Channel {
@ -21,6 +23,12 @@ public:
RC_Channel_aux(uint8_t ch_out) : RC_Channel_aux(uint8_t ch_out) :
RC_Channel(ch_out) RC_Channel(ch_out)
{ {
for (uint8_t i=0; i<RC_AUX_MAX_CHANNELS; i++) {
if (_aux_channels[i] == NULL) {
_aux_channels[i] = this;
break;
}
}
AP_Param::setup_object_defaults(this, var_info); AP_Param::setup_object_defaults(this, var_info);
} }
@ -86,12 +94,14 @@ public:
int16_t value, int16_t angle_min, int16_t angle_max); int16_t value, int16_t angle_min, int16_t angle_max);
static const struct AP_Param::GroupInfo var_info[]; static const struct AP_Param::GroupInfo var_info[];
};
void update_aux_servo_function(RC_Channel_aux* rc_a = NULL, RC_Channel_aux* rc_b = NULL, // assigned and enable auxillary channels
RC_Channel_aux* rc_c = NULL, RC_Channel_aux* rc_d = NULL, static void enable_aux_servos(void);
RC_Channel_aux* rc_e = NULL, RC_Channel_aux* rc_f = NULL,
RC_Channel_aux* rc_g = NULL, RC_Channel_aux* rc_h = NULL); private:
void enable_aux_servos(); static uint32_t _function_mask;
static RC_Channel_aux *_aux_channels[RC_AUX_MAX_CHANNELS];
static void update_aux_servo_function(void);
};
#endif /* RC_CHANNEL_AUX_H_ */ #endif /* RC_CHANNEL_AUX_H_ */

Loading…
Cancel
Save