mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-23 09:08:30 -04:00
8f17f95cbc
updated motor setup test to be sequencial pulses of the motors in CW order. Fixed Mission scripting logic fixed Free yaw error in neutral throttle fixed D term issue with Baro hold - was too high incremented firmware revision, removed frame var removed setup show from startup removed unused EEPROM functions fixed broken demo mission fixed non working loiter with delay git-svn-id: https://arducopter.googlecode.com/svn/trunk@2275 f9c3cf11-9bcb-44bc-f272-b75c42450872
105 lines
2.1 KiB
Plaintext
105 lines
2.1 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){
|
|
int pulsewidth = g.rc_5.radio_in; // default for Arducopter
|
|
|
|
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 > 150){
|
|
g.throttle_cruise.set_and_save(g.rc_3.control_in);
|
|
//Serial.printf("tnom %d\n", g.throttle_cruise.get());
|
|
}
|
|
}
|
|
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());*/
|
|
}
|
|
|