diff --git a/ArduCopterMega/config.h b/ArduCopterMega/config.h index d669500c6e..f308697808 100644 --- a/ArduCopterMega/config.h +++ b/ArduCopterMega/config.h @@ -558,3 +558,16 @@ #ifndef ALLOW_RC_OVERRIDE # define ALLOW_RC_OVERRIDE DISABLED #endif + +////////////////////////////////////////////////////////////////////////////// +// Motor arming +// +// The default is for MODE2 setups. We wait for throttle to reach +// zero, and rudder to be at maximum extent. +#ifndef MOTOR_ARM_CONDITION +# define MOTOR_ARM_CONDITION (g.rc_3.control_in == 0 && g.rc_4.control_in > 2700) +#endif + +#ifndef MOTOR_DISARM_CONDITION +# define MOTOR_DISARM_CONDITION (g.rc_3.control_in == 0 && g.rc_4.control_in < -2700) +#endif diff --git a/ArduCopterMega/motors.pde b/ArduCopterMega/motors.pde index 386136396b..cf0a6f98eb 100644 --- a/ArduCopterMega/motors.pde +++ b/ArduCopterMega/motors.pde @@ -6,24 +6,28 @@ void arm_motors() { static byte arming_counter; - + // Serial.printf("rc3: %u rc4: %u\n", g.rc_3.control_in, g.rc_4.control_in); // Arm motor output : Throttle down and full yaw right for more than 2 seconds - if (g.rc_3.control_in == 0){ - if (g.rc_4.control_in > 2700) { - if (arming_counter > ARM_DELAY) { - motor_armed = true; - } else{ - arming_counter++; + if (MOTOR_ARM_CONDITION) { + if (arming_counter > ARM_DELAY) { + if (!motor_armed) { + gcs.send_text(SEVERITY_MEDIUM, "Arming motors"); } - }else if (g.rc_4.control_in < -2700) { - if (arming_counter > DISARM_DELAY){ - motor_armed = false; - }else{ - arming_counter++; - } - }else{ - arming_counter = 0; + motor_armed = true; + } else{ + arming_counter++; } + } else if (MOTOR_DISARM_CONDITION) { + if (arming_counter > DISARM_DELAY){ + if (motor_armed) { + gcs.send_text(SEVERITY_MEDIUM, "Dis-arming motors"); + } + motor_armed = false; + } else { + arming_counter++; + } + } else { + arming_counter = 0; } }