mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 01:48:29 -04:00
Plane: move elevon variables into a structure
This commit is contained in:
parent
79c6f32400
commit
8f091e70c8
@ -295,13 +295,22 @@ enum FlightMode control_mode = INITIALISING;
|
|||||||
uint8_t oldSwitchPosition;
|
uint8_t oldSwitchPosition;
|
||||||
// This is used to enable the inverted flight feature
|
// This is used to enable the inverted flight feature
|
||||||
bool inverted_flight = false;
|
bool inverted_flight = false;
|
||||||
// These are trim values used for elevon control
|
|
||||||
// For elevons radio_in[CH_ROLL] and radio_in[CH_PITCH] are equivalent aileron and elevator, not left and right elevon
|
static struct {
|
||||||
static uint16_t elevon1_trim = 1500;
|
// These are trim values used for elevon control
|
||||||
static uint16_t elevon2_trim = 1500;
|
// For elevons radio_in[CH_ROLL] and radio_in[CH_PITCH] are
|
||||||
// These are used in the calculation of elevon1_trim and elevon2_trim
|
// equivalent aileron and elevator, not left and right elevon
|
||||||
static uint16_t ch1_temp = 1500;
|
uint16_t trim1;
|
||||||
static uint16_t ch2_temp = 1500;
|
uint16_t trim2;
|
||||||
|
// These are used in the calculation of elevon1_trim and elevon2_trim
|
||||||
|
uint16_t ch1_temp;
|
||||||
|
uint16_t ch2_temp;
|
||||||
|
} elevon = {
|
||||||
|
.trim1 = 1500,
|
||||||
|
.trim2 = 1500,
|
||||||
|
.ch1_temp = 1500,
|
||||||
|
.ch2_temp = 1500
|
||||||
|
};
|
||||||
|
|
||||||
// A flag if GCS joystick control is in use
|
// A flag if GCS joystick control is in use
|
||||||
static bool rc_override_active = false;
|
static bool rc_override_active = false;
|
||||||
|
@ -610,8 +610,8 @@ static void set_servos(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// directly set the radio_out values for elevon mode
|
// directly set the radio_out values for elevon mode
|
||||||
g.channel_roll.radio_out = elevon1_trim + (BOOL_TO_SIGN(g.reverse_ch1_elevon) * (ch1 * 500.0/ SERVO_MAX));
|
g.channel_roll.radio_out = elevon.trim1 + (BOOL_TO_SIGN(g.reverse_ch1_elevon) * (ch1 * 500.0/ SERVO_MAX));
|
||||||
g.channel_pitch.radio_out = elevon2_trim + (BOOL_TO_SIGN(g.reverse_ch2_elevon) * (ch2 * 500.0/ SERVO_MAX));
|
g.channel_pitch.radio_out = elevon.trim2 + (BOOL_TO_SIGN(g.reverse_ch2_elevon) * (ch2 * 500.0/ SERVO_MAX));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if OBC_FAILSAFE == ENABLED
|
#if OBC_FAILSAFE == ENABLED
|
||||||
|
@ -71,16 +71,16 @@ static void init_rc_out()
|
|||||||
|
|
||||||
static void read_radio()
|
static void read_radio()
|
||||||
{
|
{
|
||||||
ch1_temp = hal.rcin->read(CH_ROLL);
|
elevon.ch1_temp = hal.rcin->read(CH_ROLL);
|
||||||
ch2_temp = hal.rcin->read(CH_PITCH);
|
elevon.ch2_temp = hal.rcin->read(CH_PITCH);
|
||||||
uint16_t pwm_roll, pwm_pitch;
|
uint16_t pwm_roll, pwm_pitch;
|
||||||
|
|
||||||
if (g.mix_mode == 0) {
|
if (g.mix_mode == 0) {
|
||||||
pwm_roll = ch1_temp;
|
pwm_roll = elevon.ch1_temp;
|
||||||
pwm_pitch = ch2_temp;
|
pwm_pitch = elevon.ch2_temp;
|
||||||
}else{
|
}else{
|
||||||
pwm_roll = BOOL_TO_SIGN(g.reverse_elevons) * (BOOL_TO_SIGN(g.reverse_ch2_elevon) * int16_t(ch2_temp - elevon2_trim) - BOOL_TO_SIGN(g.reverse_ch1_elevon) * int16_t(ch1_temp - elevon1_trim)) / 2 + 1500;
|
pwm_roll = BOOL_TO_SIGN(g.reverse_elevons) * (BOOL_TO_SIGN(g.reverse_ch2_elevon) * int16_t(elevon.ch2_temp - elevon.trim2) - BOOL_TO_SIGN(g.reverse_ch1_elevon) * int16_t(elevon.ch1_temp - elevon.trim1)) / 2 + 1500;
|
||||||
pwm_pitch = (BOOL_TO_SIGN(g.reverse_ch2_elevon) * int16_t(ch2_temp - elevon2_trim) + BOOL_TO_SIGN(g.reverse_ch1_elevon) * int16_t(ch1_temp - elevon1_trim)) / 2 + 1500;
|
pwm_pitch = (BOOL_TO_SIGN(g.reverse_ch2_elevon) * int16_t(elevon.ch2_temp - elevon.trim2) + BOOL_TO_SIGN(g.reverse_ch1_elevon) * int16_t(elevon.ch1_temp - elevon.trim1)) / 2 + 1500;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (control_mode == TRAINING) {
|
if (control_mode == TRAINING) {
|
||||||
@ -202,11 +202,11 @@ static void trim_control_surfaces()
|
|||||||
RC_Channel_aux::set_radio_trim(RC_Channel_aux::k_aileron_with_input);
|
RC_Channel_aux::set_radio_trim(RC_Channel_aux::k_aileron_with_input);
|
||||||
RC_Channel_aux::set_radio_trim(RC_Channel_aux::k_elevator_with_input);
|
RC_Channel_aux::set_radio_trim(RC_Channel_aux::k_elevator_with_input);
|
||||||
} else{
|
} else{
|
||||||
if (ch1_temp != 0) {
|
if (elevon.ch1_temp != 0) {
|
||||||
elevon1_trim = ch1_temp;
|
elevon.trim1 = elevon.ch1_temp;
|
||||||
}
|
}
|
||||||
if (ch2_temp != 0) {
|
if (elevon.ch2_temp != 0) {
|
||||||
elevon2_trim = ch2_temp;
|
elevon.trim2 = elevon.ch2_temp;
|
||||||
}
|
}
|
||||||
//Recompute values here using new values for elevon1_trim and elevon2_trim
|
//Recompute values here using new values for elevon1_trim and elevon2_trim
|
||||||
//We cannot use radio_in[CH_ROLL] and radio_in[CH_PITCH] values from read_radio() because the elevon trim values have changed
|
//We cannot use radio_in[CH_ROLL] and radio_in[CH_PITCH] values from read_radio() because the elevon trim values have changed
|
||||||
|
Loading…
Reference in New Issue
Block a user