mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 14:48:28 -04:00
AP_Motors: Break out servo init and reset in AP_MotorsHeli.
This commit is contained in:
parent
ae9a16dc27
commit
feb32f40ed
@ -472,12 +472,7 @@ void AP_MotorsHeli::output_disarmed()
|
|||||||
void AP_MotorsHeli::reset_swash()
|
void AP_MotorsHeli::reset_swash()
|
||||||
{
|
{
|
||||||
// free up servo ranges
|
// free up servo ranges
|
||||||
_servo_1.radio_min = 1000;
|
reset_servos();
|
||||||
_servo_1.radio_max = 2000;
|
|
||||||
_servo_2.radio_min = 1000;
|
|
||||||
_servo_2.radio_max = 2000;
|
|
||||||
_servo_3.radio_min = 1000;
|
|
||||||
_servo_3.radio_max = 2000;
|
|
||||||
|
|
||||||
// calculate factors based on swash type and servo position
|
// calculate factors based on swash type and servo position
|
||||||
calculate_roll_pitch_collective_factors();
|
calculate_roll_pitch_collective_factors();
|
||||||
@ -492,15 +487,27 @@ void AP_MotorsHeli::reset_swash()
|
|||||||
_heliflags.swash_initialised = false;
|
_heliflags.swash_initialised = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// reset_servos
|
||||||
|
void AP_MotorsHeli::reset_servos()
|
||||||
|
{
|
||||||
|
reset_swash_servo (_servo_1);
|
||||||
|
reset_swash_servo (_servo_2);
|
||||||
|
reset_swash_servo (_servo_3);
|
||||||
|
}
|
||||||
|
|
||||||
|
// reset_swash_servo
|
||||||
|
void AP_MotorsHeli::reset_swash_servo(RC_Channel& servo)
|
||||||
|
{
|
||||||
|
servo.radio_min = 1000;
|
||||||
|
servo.radio_max = 2000;
|
||||||
|
}
|
||||||
|
|
||||||
// init_swash - initialise the swash plate
|
// init_swash - initialise the swash plate
|
||||||
void AP_MotorsHeli::init_swash()
|
void AP_MotorsHeli::init_swash()
|
||||||
{
|
{
|
||||||
|
|
||||||
// swash servo initialisation
|
// swash servo initialisation
|
||||||
_servo_1.set_range(0,1000);
|
init_servos();
|
||||||
_servo_2.set_range(0,1000);
|
|
||||||
_servo_3.set_range(0,1000);
|
|
||||||
_servo_4.set_angle(4500);
|
|
||||||
|
|
||||||
// range check collective min, max and mid
|
// range check collective min, max and mid
|
||||||
if( _collective_min >= _collective_max ) {
|
if( _collective_min >= _collective_max ) {
|
||||||
@ -520,18 +527,29 @@ void AP_MotorsHeli::init_swash()
|
|||||||
// calculate factors based on swash type and servo position
|
// calculate factors based on swash type and servo position
|
||||||
calculate_roll_pitch_collective_factors();
|
calculate_roll_pitch_collective_factors();
|
||||||
|
|
||||||
// servo min/max values
|
|
||||||
_servo_1.radio_min = 1000;
|
|
||||||
_servo_1.radio_max = 2000;
|
|
||||||
_servo_2.radio_min = 1000;
|
|
||||||
_servo_2.radio_max = 2000;
|
|
||||||
_servo_3.radio_min = 1000;
|
|
||||||
_servo_3.radio_max = 2000;
|
|
||||||
|
|
||||||
// mark swash as initialised
|
// mark swash as initialised
|
||||||
_heliflags.swash_initialised = true;
|
_heliflags.swash_initialised = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// init_servos
|
||||||
|
void AP_MotorsHeli::init_servos()
|
||||||
|
{
|
||||||
|
init_swash_servo (_servo_1);
|
||||||
|
init_swash_servo (_servo_2);
|
||||||
|
init_swash_servo (_servo_3);
|
||||||
|
|
||||||
|
_servo_4.set_angle(4500);
|
||||||
|
}
|
||||||
|
|
||||||
|
// init_swash_servo
|
||||||
|
void AP_MotorsHeli::init_swash_servo(RC_Channel& servo)
|
||||||
|
{
|
||||||
|
servo.set_range(0, 1000);
|
||||||
|
|
||||||
|
servo.radio_min = 1000;
|
||||||
|
servo.radio_max = 2000;
|
||||||
|
}
|
||||||
|
|
||||||
// calculate_roll_pitch_collective_factors - calculate factors based on swash type and servo position
|
// calculate_roll_pitch_collective_factors - calculate factors based on swash type and servo position
|
||||||
void AP_MotorsHeli::calculate_roll_pitch_collective_factors()
|
void AP_MotorsHeli::calculate_roll_pitch_collective_factors()
|
||||||
{
|
{
|
||||||
|
@ -232,9 +232,21 @@ private:
|
|||||||
// reset_swash - free up swash for maximum movements. Used for set-up
|
// reset_swash - free up swash for maximum movements. Used for set-up
|
||||||
void reset_swash();
|
void reset_swash();
|
||||||
|
|
||||||
|
// reset_servos - free up the swash servos for maximum movement
|
||||||
|
void reset_servos();
|
||||||
|
|
||||||
|
// reset_swash_servo - free up swash servo for maximum movement
|
||||||
|
static void reset_swash_servo(RC_Channel& servo);
|
||||||
|
|
||||||
// init_swash - initialise the swash plate
|
// init_swash - initialise the swash plate
|
||||||
void init_swash();
|
void init_swash();
|
||||||
|
|
||||||
|
// init_servos - initialize the servos
|
||||||
|
void init_servos();
|
||||||
|
|
||||||
|
// init_swash_servo - initialize a swash servo
|
||||||
|
static void init_swash_servo(RC_Channel& servo);
|
||||||
|
|
||||||
// calculate_roll_pitch_collective_factors - calculate factors based on swash type and servo position
|
// calculate_roll_pitch_collective_factors - calculate factors based on swash type and servo position
|
||||||
void calculate_roll_pitch_collective_factors();
|
void calculate_roll_pitch_collective_factors();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user