mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
Use G_RC_AUX macro to simplify accessing the auxiliary servos
This commit is contained in:
parent
46f9d4cec8
commit
77c798abd5
@ -23,46 +23,26 @@ static void init_rc_in()
|
|||||||
g.channel_throttle.dead_zone = 6;
|
g.channel_throttle.dead_zone = 6;
|
||||||
|
|
||||||
//set auxiliary ranges
|
//set auxiliary ranges
|
||||||
if (g_rc_function[RC_Channel_aux::k_flap]) {
|
G_RC_AUX(k_flap)->set_range(0,100);
|
||||||
g_rc_function[RC_Channel_aux::k_flap]->set_range(0,100);
|
G_RC_AUX(k_flap_auto)->set_range(0,100);
|
||||||
}
|
G_RC_AUX(k_aileron)->set_angle(SERVO_MAX);
|
||||||
if (g_rc_function[RC_Channel_aux::k_flap_auto]) {
|
G_RC_AUX(k_flaperon)->set_range(0,100);
|
||||||
g_rc_function[RC_Channel_aux::k_flap_auto]->set_range(0,100);
|
|
||||||
}
|
|
||||||
if (g_rc_function[RC_Channel_aux::k_aileron]) {
|
|
||||||
g_rc_function[RC_Channel_aux::k_aileron]->set_angle(SERVO_MAX);
|
|
||||||
}
|
|
||||||
if (g_rc_function[RC_Channel_aux::k_flaperon]) {
|
|
||||||
g_rc_function[RC_Channel_aux::k_flaperon]->set_range(0,100);
|
|
||||||
}
|
|
||||||
#if CAMERA == ENABLED
|
#if CAMERA == ENABLED
|
||||||
if (g_rc_function[RC_Channel_aux::k_mount_yaw]) {
|
G_RC_AUX(k_mount_yaw)->set_range(
|
||||||
g_rc_function[RC_Channel_aux::k_mount_yaw]->set_range(
|
|
||||||
g_rc_function[RC_Channel_aux::k_mount_yaw]->angle_min / 10,
|
g_rc_function[RC_Channel_aux::k_mount_yaw]->angle_min / 10,
|
||||||
g_rc_function[RC_Channel_aux::k_mount_yaw]->angle_max / 10);
|
g_rc_function[RC_Channel_aux::k_mount_yaw]->angle_max / 10);
|
||||||
}
|
G_RC_AUX(k_mount_pitch)->set_range(
|
||||||
if (g_rc_function[RC_Channel_aux::k_mount_pitch]) {
|
|
||||||
g_rc_function[RC_Channel_aux::k_mount_pitch]->set_range(
|
|
||||||
g_rc_function[RC_Channel_aux::k_mount_pitch]->angle_min / 10,
|
g_rc_function[RC_Channel_aux::k_mount_pitch]->angle_min / 10,
|
||||||
g_rc_function[RC_Channel_aux::k_mount_pitch]->angle_max / 10);
|
g_rc_function[RC_Channel_aux::k_mount_pitch]->angle_max / 10);
|
||||||
}
|
G_RC_AUX(k_mount_roll)->set_range(
|
||||||
if (g_rc_function[RC_Channel_aux::k_mount_roll]) {
|
|
||||||
g_rc_function[RC_Channel_aux::k_mount_roll]->set_range(
|
|
||||||
g_rc_function[RC_Channel_aux::k_mount_roll]->angle_min / 10,
|
g_rc_function[RC_Channel_aux::k_mount_roll]->angle_min / 10,
|
||||||
g_rc_function[RC_Channel_aux::k_mount_roll]->angle_max / 10);
|
g_rc_function[RC_Channel_aux::k_mount_roll]->angle_max / 10);
|
||||||
}
|
G_RC_AUX(k_cam_trigger)->set_range(
|
||||||
if (g_rc_function[RC_Channel_aux::k_cam_trigger]) {
|
|
||||||
g_rc_function[RC_Channel_aux::k_cam_trigger]->set_range(
|
|
||||||
g_rc_function[RC_Channel_aux::k_cam_trigger]->angle_min / 10,
|
g_rc_function[RC_Channel_aux::k_cam_trigger]->angle_min / 10,
|
||||||
g_rc_function[RC_Channel_aux::k_cam_trigger]->angle_max / 10);
|
g_rc_function[RC_Channel_aux::k_cam_trigger]->angle_max / 10);
|
||||||
}
|
G_RC_AUX(k_cam_open)->set_range(0,100);
|
||||||
if (g_rc_function[RC_Channel_aux::k_cam_open]) {
|
|
||||||
g_rc_function[RC_Channel_aux::k_cam_open]->set_range(0,100);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
if (g_rc_function[RC_Channel_aux::k_egg_drop]) {
|
G_RC_AUX(k_egg_drop)->set_range(0,100);
|
||||||
g_rc_function[RC_Channel_aux::k_egg_drop]->set_range(0,100);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void init_rc_out()
|
static void init_rc_out()
|
||||||
@ -195,7 +175,7 @@ static void trim_control_surfaces()
|
|||||||
g.channel_roll.radio_trim = g.channel_roll.radio_in;
|
g.channel_roll.radio_trim = g.channel_roll.radio_in;
|
||||||
g.channel_pitch.radio_trim = g.channel_pitch.radio_in;
|
g.channel_pitch.radio_trim = g.channel_pitch.radio_in;
|
||||||
g.channel_rudder.radio_trim = g.channel_rudder.radio_in;
|
g.channel_rudder.radio_trim = g.channel_rudder.radio_in;
|
||||||
if (g_rc_function[RC_Channel_aux::k_aileron]) g_rc_function[RC_Channel_aux::k_aileron]->radio_trim = g_rc_function[RC_Channel_aux::k_aileron]->radio_in; // Second aileron channel
|
G_RC_AUX(k_aileron)->radio_trim = g_rc_function[RC_Channel_aux::k_aileron]->radio_in; // Second aileron channel
|
||||||
|
|
||||||
}else{
|
}else{
|
||||||
elevon1_trim = ch1_temp;
|
elevon1_trim = ch1_temp;
|
||||||
@ -212,7 +192,7 @@ static void trim_control_surfaces()
|
|||||||
g.channel_pitch.save_eeprom();
|
g.channel_pitch.save_eeprom();
|
||||||
g.channel_throttle.save_eeprom();
|
g.channel_throttle.save_eeprom();
|
||||||
g.channel_rudder.save_eeprom();
|
g.channel_rudder.save_eeprom();
|
||||||
if (g_rc_function[RC_Channel_aux::k_aileron]) g_rc_function[RC_Channel_aux::k_aileron]->save_eeprom();
|
G_RC_AUX(k_aileron)->save_eeprom();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void trim_radio()
|
static void trim_radio()
|
||||||
@ -228,7 +208,7 @@ static void trim_radio()
|
|||||||
g.channel_pitch.radio_trim = g.channel_pitch.radio_in;
|
g.channel_pitch.radio_trim = g.channel_pitch.radio_in;
|
||||||
//g.channel_throttle.radio_trim = g.channel_throttle.radio_in;
|
//g.channel_throttle.radio_trim = g.channel_throttle.radio_in;
|
||||||
g.channel_rudder.radio_trim = g.channel_rudder.radio_in;
|
g.channel_rudder.radio_trim = g.channel_rudder.radio_in;
|
||||||
if (g_rc_function[RC_Channel_aux::k_aileron]) g_rc_function[RC_Channel_aux::k_aileron]->radio_trim = g_rc_function[RC_Channel_aux::k_aileron]->radio_in; // Second aileron channel
|
G_RC_AUX(k_aileron)->radio_trim = g_rc_function[RC_Channel_aux::k_aileron]->radio_in; // Second aileron channel
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
elevon1_trim = ch1_temp;
|
elevon1_trim = ch1_temp;
|
||||||
@ -244,5 +224,5 @@ static void trim_radio()
|
|||||||
g.channel_pitch.save_eeprom();
|
g.channel_pitch.save_eeprom();
|
||||||
//g.channel_throttle.save_eeprom();
|
//g.channel_throttle.save_eeprom();
|
||||||
g.channel_rudder.save_eeprom();
|
g.channel_rudder.save_eeprom();
|
||||||
if (g_rc_function[RC_Channel_aux::k_aileron]) g_rc_function[RC_Channel_aux::k_aileron]->save_eeprom();
|
G_RC_AUX(k_aileron)->save_eeprom();
|
||||||
}
|
}
|
||||||
|
@ -98,10 +98,7 @@ AP_Camera::trigger_pic_cleanup()
|
|||||||
case 0:
|
case 0:
|
||||||
case 2:
|
case 2:
|
||||||
case 3:
|
case 3:
|
||||||
if (g_rc_function[RC_Channel_aux::k_cam_trigger])
|
G_RC_AUX(k_cam_trigger)->radio_out = g_rc_function[RC_Channel_aux::k_cam_trigger]->radio_min;
|
||||||
{
|
|
||||||
g_rc_function[RC_Channel_aux::k_cam_trigger]->radio_out = g_rc_function[RC_Channel_aux::k_cam_trigger]->radio_min;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
// TODO for some strange reason the function call bellow gives a linker error
|
// TODO for some strange reason the function call bellow gives a linker error
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#ifndef AP_DCM_h
|
#ifndef AP_DCM_h
|
||||||
#define AP_DCM_h
|
#define AP_DCM_h
|
||||||
|
|
||||||
// teporarily include all other classes here
|
// temporarily include all other classes here
|
||||||
// since this naming is a bit off from the
|
// since this naming is a bit off from the
|
||||||
// convention and the AP_DCM should be the top
|
// convention and the AP_DCM should be the top
|
||||||
// header file
|
// header file
|
||||||
|
@ -156,12 +156,9 @@ void AP_Mount::update_mount()
|
|||||||
|
|
||||||
// write the results to the servos
|
// write the results to the servos
|
||||||
// Change scaling to 0.1 degrees in order to avoid overflows in the angle arithmetic
|
// Change scaling to 0.1 degrees in order to avoid overflows in the angle arithmetic
|
||||||
if (g_rc_function[RC_Channel_aux::k_mount_roll])
|
G_RC_AUX(k_mount_roll)->closest_limit(roll_angle/10);
|
||||||
g_rc_function[RC_Channel_aux::k_mount_roll]->closest_limit(roll_angle/10);
|
G_RC_AUX(k_mount_pitch)->closest_limit(pitch_angle/10);
|
||||||
if (g_rc_function[RC_Channel_aux::k_mount_pitch])
|
G_RC_AUX(k_mount_yaw)->closest_limit(yaw_angle/10);
|
||||||
g_rc_function[RC_Channel_aux::k_mount_pitch]->closest_limit(pitch_angle/10);
|
|
||||||
if (g_rc_function[RC_Channel_aux::k_mount_yaw])
|
|
||||||
g_rc_function[RC_Channel_aux::k_mount_yaw]->closest_limit(yaw_angle/10);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AP_Mount::set_mode(MountMode mode)
|
void AP_Mount::set_mode(MountMode mode)
|
||||||
|
@ -102,6 +102,7 @@ class RC_Channel{
|
|||||||
int16_t _low;
|
int16_t _low;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// This is ugly, but it fixes compilation on arduino
|
||||||
#include "RC_Channel_aux.h"
|
#include "RC_Channel_aux.h"
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -9,6 +9,9 @@
|
|||||||
|
|
||||||
#include "RC_Channel.h"
|
#include "RC_Channel.h"
|
||||||
|
|
||||||
|
// Macro to simplify accessing the auxiliary servos
|
||||||
|
#define G_RC_AUX(_t) if (g_rc_function[RC_Channel_aux::_t]) g_rc_function[RC_Channel_aux::_t]
|
||||||
|
|
||||||
/// @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
|
||||||
/// Also contains physical min,max angular deflection, to allow calibrating open-loop servo movements
|
/// Also contains physical min,max angular deflection, to allow calibrating open-loop servo movements
|
||||||
|
Loading…
Reference in New Issue
Block a user