5d63a05de7
removed FBW mode - no longer needed added set_throttle_cruise_flag to auto set the throttle value for alt hold added altitude minimum option for waypoints added support for relative WPs added support for Yaw tracking per WP in options bitmask lowered default sonar kD value increased minimal value to set the throttle cruise value with CH7 switch updated README.txt added additional stock test missions available in CLI git-svn-id: https://arducopter.googlecode.com/svn/trunk@1856 f9c3cf11-9bcb-44bc-f272-b75c42450872
122 lines
2.7 KiB
Plaintext
122 lines
2.7 KiB
Plaintext
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
void read_control_switch()
|
|
{
|
|
byte switchPosition = readSwitch();
|
|
//motor_armed = (switchPosition < 5);
|
|
|
|
if (oldSwitchPosition != switchPosition){
|
|
|
|
set_mode(g.flight_modes[switchPosition]);
|
|
|
|
oldSwitchPosition = switchPosition;
|
|
prev_WP = current_loc;
|
|
|
|
// reset navigation integrators
|
|
// -------------------------
|
|
reset_I();
|
|
}
|
|
}
|
|
|
|
byte readSwitch(void){
|
|
#if FLIGHT_MODE_CHANNEL == CH_5
|
|
int pulsewidth = g.rc_5.radio_in; // default for Arducopter
|
|
#elif FLIGHT_MODE_CHANNEL == CH_6
|
|
int pulsewidth = g.rc_6.radio_in; //
|
|
#elif FLIGHT_MODE_CHANNEL == CH_7
|
|
int pulsewidth = g.rc_7.radio_in; //
|
|
#elif FLIGHT_MODE_CHANNEL == CH_8
|
|
int pulsewidth = g.rc_8.radio_in; // default for Ardupilot. Don't use for Arducopter! it has a hardware failsafe mux!
|
|
#else
|
|
# error Must define FLIGHT_MODE_CHANNEL as CH_5 - CH_8
|
|
#endif
|
|
|
|
if (pulsewidth > 1230 && pulsewidth <= 1360) return 1;
|
|
if (pulsewidth > 1360 && pulsewidth <= 1490) return 2;
|
|
if (pulsewidth > 1490 && pulsewidth <= 1620) return 3;
|
|
if (pulsewidth > 1620 && pulsewidth <= 1749) return 4; // Software Manual
|
|
if (pulsewidth >= 1750) return 5; // Hardware Manual
|
|
return 0;
|
|
}
|
|
|
|
void reset_control_switch()
|
|
{
|
|
oldSwitchPosition = -1;
|
|
read_control_switch();
|
|
SendDebug("MSG: reset_control_switch ");
|
|
SendDebugln(oldSwitchPosition , DEC);
|
|
}
|
|
|
|
void update_servo_switches()
|
|
{
|
|
|
|
}
|
|
|
|
boolean trim_flag;
|
|
unsigned long trim_timer;
|
|
|
|
// read at 10 hz
|
|
// set this to your trainer switch
|
|
void read_trim_switch()
|
|
{
|
|
// switch is engaged
|
|
if (g.rc_7.control_in > 800){
|
|
if(trim_flag == false){
|
|
// called once
|
|
trim_timer = millis();
|
|
}
|
|
|
|
trim_flag = true;
|
|
trim_accel();
|
|
|
|
|
|
}else{ // switch is disengaged
|
|
|
|
if(trim_flag){
|
|
// switch was just released
|
|
if((millis() - trim_timer) > 2000){
|
|
#if HIL_MODE != HIL_MODE_ATTITUDE
|
|
imu.save();
|
|
#endif
|
|
}else{
|
|
// set the throttle nominal
|
|
if(g.rc_3.control_in > 200){
|
|
g.throttle_cruise.set_and_save(g.rc_3.control_in);
|
|
//Serial.printf("tnom %d\n", g.throttle_cruise.get());
|
|
}
|
|
|
|
// this is a test for Max's tri-copter
|
|
if(g.frame_type == TRI_FRAME){
|
|
g.rc_4.trim(); // yaw
|
|
g.rc_4.save_eeprom();
|
|
}
|
|
}
|
|
trim_flag = false;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
void trim_accel()
|
|
{
|
|
if(g.rc_1.control_in > 0){
|
|
imu.ay(imu.ay() + 1);
|
|
}else if (g.rc_1.control_in < 0){
|
|
imu.ay(imu.ay() - 1);
|
|
}
|
|
|
|
if(g.rc_2.control_in > 0){
|
|
imu.ax(imu.ax() + 1);
|
|
}else if (g.rc_2.control_in < 0){
|
|
imu.ax(imu.ax() - 1);
|
|
}
|
|
|
|
/*Serial.printf_P(PSTR("r:%ld p:%ld ax:%f, ay:%f, az:%f\n"),
|
|
dcm.roll_sensor,
|
|
dcm.pitch_sensor,
|
|
(double)imu.ax(),
|
|
(double)imu.ay(),
|
|
(double)imu.az());*/
|
|
}
|
|
|