mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
Copter: rename flightmode_ objects to mode_
This commit is contained in:
parent
c3fbf2671c
commit
2d23e1f7c7
@ -537,7 +537,7 @@ void Copter::update_GPS(void)
|
|||||||
|
|
||||||
void Copter::smart_rtl_save_position()
|
void Copter::smart_rtl_save_position()
|
||||||
{
|
{
|
||||||
flightmode_smartrtl.save_position();
|
mode_smartrtl.save_position();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Copter::init_simple_bearing()
|
void Copter::init_simple_bearing()
|
||||||
|
@ -57,7 +57,7 @@ Copter::Copter(void)
|
|||||||
auto_trim_counter(0),
|
auto_trim_counter(0),
|
||||||
in_mavlink_delay(false),
|
in_mavlink_delay(false),
|
||||||
param_loader(var_info),
|
param_loader(var_info),
|
||||||
flightmode(&flightmode_stabilize)
|
flightmode(&mode_stabilize)
|
||||||
{
|
{
|
||||||
memset(¤t_loc, 0, sizeof(current_loc));
|
memset(¤t_loc, 0, sizeof(current_loc));
|
||||||
|
|
||||||
|
@ -946,54 +946,54 @@ private:
|
|||||||
Copter::Mode *flightmode;
|
Copter::Mode *flightmode;
|
||||||
|
|
||||||
#if FRAME_CONFIG == HELI_FRAME
|
#if FRAME_CONFIG == HELI_FRAME
|
||||||
Copter::ModeAcro_Heli flightmode_acro{*this};
|
Copter::ModeAcro_Heli mode_acro{*this};
|
||||||
#else
|
#else
|
||||||
Copter::ModeAcro flightmode_acro{*this};
|
Copter::ModeAcro mode_acro{*this};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Copter::ModeAltHold flightmode_althold{*this};
|
Copter::ModeAltHold mode_althold{*this};
|
||||||
|
|
||||||
Copter::ModeAuto flightmode_auto{*this, mission, circle_nav};
|
Copter::ModeAuto mode_auto{*this, mission, circle_nav};
|
||||||
|
|
||||||
#if AUTOTUNE_ENABLED == ENABLED
|
#if AUTOTUNE_ENABLED == ENABLED
|
||||||
Copter::ModeAutoTune flightmode_autotune{*this};
|
Copter::ModeAutoTune mode_autotune{*this};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Copter::ModeBrake flightmode_brake{*this};
|
Copter::ModeBrake mode_brake{*this};
|
||||||
|
|
||||||
Copter::ModeCircle flightmode_circle{*this, circle_nav};
|
Copter::ModeCircle mode_circle{*this, circle_nav};
|
||||||
|
|
||||||
Copter::ModeDrift flightmode_drift{*this};
|
Copter::ModeDrift mode_drift{*this};
|
||||||
|
|
||||||
Copter::ModeFlip flightmode_flip{*this};
|
Copter::ModeFlip mode_flip{*this};
|
||||||
|
|
||||||
Copter::ModeGuided flightmode_guided{*this};
|
Copter::ModeGuided mode_guided{*this};
|
||||||
|
|
||||||
Copter::ModeLand flightmode_land{*this};
|
Copter::ModeLand mode_land{*this};
|
||||||
|
|
||||||
Copter::ModeLoiter flightmode_loiter{*this};
|
Copter::ModeLoiter mode_loiter{*this};
|
||||||
|
|
||||||
Copter::ModePosHold flightmode_poshold{*this};
|
Copter::ModePosHold mode_poshold{*this};
|
||||||
|
|
||||||
Copter::ModeRTL flightmode_rtl{*this};
|
Copter::ModeRTL mode_rtl{*this};
|
||||||
|
|
||||||
#if FRAME_CONFIG == HELI_FRAME
|
#if FRAME_CONFIG == HELI_FRAME
|
||||||
Copter::ModeStabilize_Heli flightmode_stabilize{*this};
|
Copter::ModeStabilize_Heli mode_stabilize{*this};
|
||||||
#else
|
#else
|
||||||
Copter::ModeStabilize flightmode_stabilize{*this};
|
Copter::ModeStabilize mode_stabilize{*this};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
Copter::ModeSport flightmode_sport{*this};
|
Copter::ModeSport mode_sport{*this};
|
||||||
|
|
||||||
Copter::ModeAvoidADSB flightmode_avoid_adsb{*this};
|
Copter::ModeAvoidADSB mode_avoid_adsb{*this};
|
||||||
|
|
||||||
Copter::ModeThrow flightmode_throw{*this};
|
Copter::ModeThrow mode_throw{*this};
|
||||||
|
|
||||||
Copter::ModeGuidedNoGPS flightmode_guided_nogps{*this};
|
Copter::ModeGuidedNoGPS mode_guided_nogps{*this};
|
||||||
|
|
||||||
Copter::ModeSmartRTL flightmode_smartrtl{*this};
|
Copter::ModeSmartRTL mode_smartrtl{*this};
|
||||||
|
|
||||||
Copter::Mode *flightmode_for_mode(const uint8_t mode);
|
Copter::Mode *mode_from_mode_num(const uint8_t mode);
|
||||||
|
|
||||||
void exit_mode(Mode *&old_flightmode, Mode *&new_flightmode);
|
void exit_mode(Mode *&old_flightmode, Mode *&new_flightmode);
|
||||||
|
|
||||||
|
@ -1291,7 +1291,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
|
|
||||||
if (!shot_mode) {
|
if (!shot_mode) {
|
||||||
if (copter.set_mode(BRAKE, MODE_REASON_GCS_COMMAND)) {
|
if (copter.set_mode(BRAKE, MODE_REASON_GCS_COMMAND)) {
|
||||||
copter.flightmode_brake.timeout_to_loiter_ms(2500);
|
copter.mode_brake.timeout_to_loiter_ms(2500);
|
||||||
} else {
|
} else {
|
||||||
copter.set_mode(ALT_HOLD, MODE_REASON_GCS_COMMAND);
|
copter.set_mode(ALT_HOLD, MODE_REASON_GCS_COMMAND);
|
||||||
}
|
}
|
||||||
@ -1335,7 +1335,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
mavlink_msg_set_attitude_target_decode(msg, &packet);
|
mavlink_msg_set_attitude_target_decode(msg, &packet);
|
||||||
|
|
||||||
// exit if vehicle is not in Guided mode or Auto-Guided mode
|
// exit if vehicle is not in Guided mode or Auto-Guided mode
|
||||||
if ((copter.control_mode != GUIDED) && (copter.control_mode != GUIDED_NOGPS) && !(copter.control_mode == AUTO && copter.flightmode_auto.mode() == Auto_NavGuided)) {
|
if ((copter.control_mode != GUIDED) && (copter.control_mode != GUIDED_NOGPS) && !(copter.control_mode == AUTO && copter.mode_auto.mode() == Auto_NavGuided)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1364,7 +1364,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
use_yaw_rate = true;
|
use_yaw_rate = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
copter.flightmode_guided.set_angle(Quaternion(packet.q[0],packet.q[1],packet.q[2],packet.q[3]),
|
copter.mode_guided.set_angle(Quaternion(packet.q[0],packet.q[1],packet.q[2],packet.q[3]),
|
||||||
climb_rate_cms, use_yaw_rate, packet.body_yaw_rate);
|
climb_rate_cms, use_yaw_rate, packet.body_yaw_rate);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@ -1377,7 +1377,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
mavlink_msg_set_position_target_local_ned_decode(msg, &packet);
|
mavlink_msg_set_position_target_local_ned_decode(msg, &packet);
|
||||||
|
|
||||||
// exit if vehicle is not in Guided mode or Auto-Guided mode
|
// exit if vehicle is not in Guided mode or Auto-Guided mode
|
||||||
if ((copter.control_mode != GUIDED) && !(copter.control_mode == AUTO && copter.flightmode_auto.mode() == Auto_NavGuided)) {
|
if ((copter.control_mode != GUIDED) && !(copter.control_mode == AUTO && copter.mode_auto.mode() == Auto_NavGuided)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1446,16 +1446,16 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
|
|
||||||
// send request
|
// send request
|
||||||
if (!pos_ignore && !vel_ignore && acc_ignore) {
|
if (!pos_ignore && !vel_ignore && acc_ignore) {
|
||||||
if (copter.flightmode_guided.set_destination_posvel(pos_vector, vel_vector, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
if (copter.mode_guided.set_destination_posvel(pos_vector, vel_vector, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
} else {
|
} else {
|
||||||
result = MAV_RESULT_FAILED;
|
result = MAV_RESULT_FAILED;
|
||||||
}
|
}
|
||||||
} else if (pos_ignore && !vel_ignore && acc_ignore) {
|
} else if (pos_ignore && !vel_ignore && acc_ignore) {
|
||||||
copter.flightmode_guided.set_velocity(vel_vector, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative);
|
copter.mode_guided.set_velocity(vel_vector, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative);
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
} else if (!pos_ignore && vel_ignore && acc_ignore) {
|
} else if (!pos_ignore && vel_ignore && acc_ignore) {
|
||||||
if (copter.flightmode_guided.set_destination(pos_vector, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
if (copter.mode_guided.set_destination(pos_vector, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
} else {
|
} else {
|
||||||
result = MAV_RESULT_FAILED;
|
result = MAV_RESULT_FAILED;
|
||||||
@ -1474,7 +1474,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
mavlink_msg_set_position_target_global_int_decode(msg, &packet);
|
mavlink_msg_set_position_target_global_int_decode(msg, &packet);
|
||||||
|
|
||||||
// exit if vehicle is not in Guided mode or Auto-Guided mode
|
// exit if vehicle is not in Guided mode or Auto-Guided mode
|
||||||
if ((copter.control_mode != GUIDED) && !(copter.control_mode == AUTO && copter.flightmode_auto.mode() == Auto_NavGuided)) {
|
if ((copter.control_mode != GUIDED) && !(copter.control_mode == AUTO && copter.mode_auto.mode() == Auto_NavGuided)) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1548,16 +1548,16 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!pos_ignore && !vel_ignore && acc_ignore) {
|
if (!pos_ignore && !vel_ignore && acc_ignore) {
|
||||||
if (copter.flightmode_guided.set_destination_posvel(pos_neu_cm, Vector3f(packet.vx * 100.0f, packet.vy * 100.0f, -packet.vz * 100.0f), !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
if (copter.mode_guided.set_destination_posvel(pos_neu_cm, Vector3f(packet.vx * 100.0f, packet.vy * 100.0f, -packet.vz * 100.0f), !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
} else {
|
} else {
|
||||||
result = MAV_RESULT_FAILED;
|
result = MAV_RESULT_FAILED;
|
||||||
}
|
}
|
||||||
} else if (pos_ignore && !vel_ignore && acc_ignore) {
|
} else if (pos_ignore && !vel_ignore && acc_ignore) {
|
||||||
copter.flightmode_guided.set_velocity(Vector3f(packet.vx * 100.0f, packet.vy * 100.0f, -packet.vz * 100.0f), !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative);
|
copter.mode_guided.set_velocity(Vector3f(packet.vx * 100.0f, packet.vy * 100.0f, -packet.vz * 100.0f), !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative);
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
} else if (!pos_ignore && vel_ignore && acc_ignore) {
|
} else if (!pos_ignore && vel_ignore && acc_ignore) {
|
||||||
if (copter.flightmode_guided.set_destination(pos_neu_cm, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
if (copter.mode_guided.set_destination(pos_neu_cm, !yaw_ignore, yaw_cd, !yaw_rate_ignore, yaw_rate_cds, yaw_relative)) {
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
} else {
|
} else {
|
||||||
result = MAV_RESULT_FAILED;
|
result = MAV_RESULT_FAILED;
|
||||||
|
@ -182,7 +182,7 @@ bool AP_Avoidance_Copter::handle_avoidance_vertical(const AP_Avoidance::Obstacle
|
|||||||
}
|
}
|
||||||
|
|
||||||
// send target velocity
|
// send target velocity
|
||||||
copter.flightmode_avoid_adsb.set_velocity(velocity_neu);
|
copter.mode_avoid_adsb.set_velocity(velocity_neu);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -208,7 +208,7 @@ bool AP_Avoidance_Copter::handle_avoidance_horizontal(const AP_Avoidance::Obstac
|
|||||||
velocity_neu.x *= copter.wp_nav->get_speed_xy();
|
velocity_neu.x *= copter.wp_nav->get_speed_xy();
|
||||||
velocity_neu.y *= copter.wp_nav->get_speed_xy();
|
velocity_neu.y *= copter.wp_nav->get_speed_xy();
|
||||||
// send target velocity
|
// send target velocity
|
||||||
copter.flightmode_avoid_adsb.set_velocity(velocity_neu);
|
copter.mode_avoid_adsb.set_velocity(velocity_neu);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -240,7 +240,7 @@ bool AP_Avoidance_Copter::handle_avoidance_perpendicular(const AP_Avoidance::Obs
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// send target velocity
|
// send target velocity
|
||||||
copter.flightmode_avoid_adsb.set_velocity(velocity_neu);
|
copter.mode_avoid_adsb.set_velocity(velocity_neu);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -292,7 +292,7 @@ void Copter::exit_mission()
|
|||||||
// if we are not on the ground switch to loiter or land
|
// if we are not on the ground switch to loiter or land
|
||||||
if(!ap.land_complete) {
|
if(!ap.land_complete) {
|
||||||
// try to enter loiter but if that fails land
|
// try to enter loiter but if that fails land
|
||||||
if(!flightmode_auto.loiter_start()) {
|
if(!mode_auto.loiter_start()) {
|
||||||
set_mode(LAND, MODE_REASON_MISSION_END);
|
set_mode(LAND, MODE_REASON_MISSION_END);
|
||||||
}
|
}
|
||||||
}else{
|
}else{
|
||||||
@ -309,7 +309,7 @@ void Copter::exit_mission()
|
|||||||
void Copter::do_RTL(void)
|
void Copter::do_RTL(void)
|
||||||
{
|
{
|
||||||
// start rtl in auto flight mode
|
// start rtl in auto flight mode
|
||||||
flightmode_auto.rtl_start();
|
mode_auto.rtl_start();
|
||||||
}
|
}
|
||||||
|
|
||||||
/********************************************************************************/
|
/********************************************************************************/
|
||||||
@ -320,7 +320,7 @@ void Copter::do_RTL(void)
|
|||||||
void Copter::do_takeoff(const AP_Mission::Mission_Command& cmd)
|
void Copter::do_takeoff(const AP_Mission::Mission_Command& cmd)
|
||||||
{
|
{
|
||||||
// Set wp navigation target to safe altitude above current position
|
// Set wp navigation target to safe altitude above current position
|
||||||
flightmode_auto.takeoff_start(cmd.content.location);
|
mode_auto.takeoff_start(cmd.content.location);
|
||||||
}
|
}
|
||||||
|
|
||||||
// do_nav_wp - initiate move to next waypoint
|
// do_nav_wp - initiate move to next waypoint
|
||||||
@ -350,7 +350,7 @@ void Copter::do_nav_wp(const AP_Mission::Mission_Command& cmd)
|
|||||||
loiter_time_max = cmd.p1;
|
loiter_time_max = cmd.p1;
|
||||||
|
|
||||||
// Set wp navigation target
|
// Set wp navigation target
|
||||||
flightmode_auto.wp_start(target_loc);
|
mode_auto.wp_start(target_loc);
|
||||||
|
|
||||||
// if no delay set the waypoint as "fast"
|
// if no delay set the waypoint as "fast"
|
||||||
if (loiter_time_max == 0 ) {
|
if (loiter_time_max == 0 ) {
|
||||||
@ -391,13 +391,13 @@ void Copter::do_land(const AP_Mission::Mission_Command& cmd)
|
|||||||
|
|
||||||
Location_Class target_loc = terrain_adjusted_location(cmd);
|
Location_Class target_loc = terrain_adjusted_location(cmd);
|
||||||
|
|
||||||
flightmode_auto.wp_start(target_loc);
|
mode_auto.wp_start(target_loc);
|
||||||
}else{
|
}else{
|
||||||
// set landing state
|
// set landing state
|
||||||
land_state = LandStateType_Descending;
|
land_state = LandStateType_Descending;
|
||||||
|
|
||||||
// initialise landing controller
|
// initialise landing controller
|
||||||
flightmode_auto.land_start();
|
mode_auto.land_start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -411,12 +411,12 @@ void Copter::do_payload_place(const AP_Mission::Mission_Command& cmd)
|
|||||||
|
|
||||||
Location_Class target_loc = terrain_adjusted_location(cmd);
|
Location_Class target_loc = terrain_adjusted_location(cmd);
|
||||||
|
|
||||||
flightmode_auto.wp_start(target_loc);
|
mode_auto.wp_start(target_loc);
|
||||||
} else {
|
} else {
|
||||||
nav_payload_place.state = PayloadPlaceStateType_Calibrating_Hover_Start;
|
nav_payload_place.state = PayloadPlaceStateType_Calibrating_Hover_Start;
|
||||||
|
|
||||||
// initialise placing controller
|
// initialise placing controller
|
||||||
flightmode_auto.payload_place_start();
|
mode_auto.payload_place_start();
|
||||||
}
|
}
|
||||||
nav_payload_place.descend_max = cmd.p1;
|
nav_payload_place.descend_max = cmd.p1;
|
||||||
}
|
}
|
||||||
@ -452,7 +452,7 @@ void Copter::do_loiter_unlimited(const AP_Mission::Mission_Command& cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// start way point navigator and provide it the desired location
|
// start way point navigator and provide it the desired location
|
||||||
flightmode_auto.wp_start(target_loc);
|
mode_auto.wp_start(target_loc);
|
||||||
}
|
}
|
||||||
|
|
||||||
// do_circle - initiate moving in a circle
|
// do_circle - initiate moving in a circle
|
||||||
@ -484,7 +484,7 @@ void Copter::do_circle(const AP_Mission::Mission_Command& cmd)
|
|||||||
uint8_t circle_radius_m = HIGHBYTE(cmd.p1); // circle radius held in high byte of p1
|
uint8_t circle_radius_m = HIGHBYTE(cmd.p1); // circle radius held in high byte of p1
|
||||||
|
|
||||||
// move to edge of circle (verify_circle) will ensure we begin circling once we reach the edge
|
// move to edge of circle (verify_circle) will ensure we begin circling once we reach the edge
|
||||||
flightmode_auto.circle_movetoedge_start(circle_center, circle_radius_m);
|
mode_auto.circle_movetoedge_start(circle_center, circle_radius_m);
|
||||||
}
|
}
|
||||||
|
|
||||||
// do_loiter_time - initiate loitering at a point for a given time period
|
// do_loiter_time - initiate loitering at a point for a given time period
|
||||||
@ -569,7 +569,7 @@ void Copter::do_spline_wp(const AP_Mission::Mission_Command& cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// set spline navigation target
|
// set spline navigation target
|
||||||
flightmode_auto.spline_start(target_loc, stopped_at_start, seg_end_type, next_loc);
|
mode_auto.spline_start(target_loc, stopped_at_start, seg_end_type, next_loc);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if NAV_GUIDED == ENABLED
|
#if NAV_GUIDED == ENABLED
|
||||||
@ -578,10 +578,10 @@ void Copter::do_nav_guided_enable(const AP_Mission::Mission_Command& cmd)
|
|||||||
{
|
{
|
||||||
if (cmd.p1 > 0) {
|
if (cmd.p1 > 0) {
|
||||||
// initialise guided limits
|
// initialise guided limits
|
||||||
flightmode_guided.limit_init_time_and_pos();
|
mode_guided.limit_init_time_and_pos();
|
||||||
|
|
||||||
// set spline navigation target
|
// set spline navigation target
|
||||||
flightmode_auto.nav_guided_start();
|
mode_auto.nav_guided_start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // NAV_GUIDED
|
#endif // NAV_GUIDED
|
||||||
@ -649,7 +649,7 @@ void Copter::do_gripper(const AP_Mission::Mission_Command& cmd)
|
|||||||
// do_guided_limits - pass guided limits to guided controller
|
// do_guided_limits - pass guided limits to guided controller
|
||||||
void Copter::do_guided_limits(const AP_Mission::Mission_Command& cmd)
|
void Copter::do_guided_limits(const AP_Mission::Mission_Command& cmd)
|
||||||
{
|
{
|
||||||
flightmode_guided.limit_set(cmd.p1 * 1000, // convert seconds to ms
|
mode_guided.limit_set(cmd.p1 * 1000, // convert seconds to ms
|
||||||
cmd.content.guided_limits.alt_min * 100.0f, // convert meters to cm
|
cmd.content.guided_limits.alt_min * 100.0f, // convert meters to cm
|
||||||
cmd.content.guided_limits.alt_max * 100.0f, // convert meters to cm
|
cmd.content.guided_limits.alt_max * 100.0f, // convert meters to cm
|
||||||
cmd.content.guided_limits.horiz_max * 100.0f); // convert meters to cm
|
cmd.content.guided_limits.horiz_max * 100.0f); // convert meters to cm
|
||||||
@ -703,7 +703,7 @@ bool Copter::verify_land()
|
|||||||
Vector3f dest = wp_nav->get_wp_destination();
|
Vector3f dest = wp_nav->get_wp_destination();
|
||||||
|
|
||||||
// initialise landing controller
|
// initialise landing controller
|
||||||
flightmode_auto.land_start(dest);
|
mode_auto.land_start(dest);
|
||||||
|
|
||||||
// advance to next state
|
// advance to next state
|
||||||
land_state = LandStateType_Descending;
|
land_state = LandStateType_Descending;
|
||||||
@ -866,7 +866,7 @@ bool Copter::verify_payload_place()
|
|||||||
case PayloadPlaceStateType_Ascending_Start: {
|
case PayloadPlaceStateType_Ascending_Start: {
|
||||||
Location_Class target_loc = inertial_nav.get_position();
|
Location_Class target_loc = inertial_nav.get_position();
|
||||||
target_loc.alt = nav_payload_place.descend_start_altitude;
|
target_loc.alt = nav_payload_place.descend_start_altitude;
|
||||||
flightmode_auto.wp_start(target_loc);
|
mode_auto.wp_start(target_loc);
|
||||||
nav_payload_place.state = PayloadPlaceStateType_Ascending;
|
nav_payload_place.state = PayloadPlaceStateType_Ascending;
|
||||||
}
|
}
|
||||||
FALLTHROUGH;
|
FALLTHROUGH;
|
||||||
@ -939,7 +939,7 @@ bool Copter::verify_loiter_time()
|
|||||||
bool Copter::verify_circle(const AP_Mission::Mission_Command& cmd)
|
bool Copter::verify_circle(const AP_Mission::Mission_Command& cmd)
|
||||||
{
|
{
|
||||||
// check if we've reached the edge
|
// check if we've reached the edge
|
||||||
if (flightmode_auto.mode() == Auto_CircleMoveToEdge) {
|
if (mode_auto.mode() == Auto_CircleMoveToEdge) {
|
||||||
if (wp_nav->reached_wp_destination()) {
|
if (wp_nav->reached_wp_destination()) {
|
||||||
Vector3f curr_pos = inertial_nav.get_position();
|
Vector3f curr_pos = inertial_nav.get_position();
|
||||||
Vector3f circle_center = pv_location_to_vector(cmd.content.location);
|
Vector3f circle_center = pv_location_to_vector(cmd.content.location);
|
||||||
@ -956,7 +956,7 @@ bool Copter::verify_circle(const AP_Mission::Mission_Command& cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// start circling
|
// start circling
|
||||||
flightmode_auto.circle_start();
|
mode_auto.circle_start();
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -970,7 +970,7 @@ bool Copter::verify_circle(const AP_Mission::Mission_Command& cmd)
|
|||||||
// returns true with RTL has completed successfully
|
// returns true with RTL has completed successfully
|
||||||
bool Copter::verify_RTL()
|
bool Copter::verify_RTL()
|
||||||
{
|
{
|
||||||
return (flightmode_rtl.state_complete() && (flightmode_rtl.state() == RTL_FinalDescent || flightmode_rtl.state() == RTL_Land));
|
return (mode_rtl.state_complete() && (mode_rtl.state() == RTL_FinalDescent || mode_rtl.state() == RTL_Land));
|
||||||
}
|
}
|
||||||
|
|
||||||
// verify_spline_wp - check if we have reached the next way point using spline
|
// verify_spline_wp - check if we have reached the next way point using spline
|
||||||
@ -1005,7 +1005,7 @@ bool Copter::verify_nav_guided_enable(const AP_Mission::Mission_Command& cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// check time and position limits
|
// check time and position limits
|
||||||
return flightmode_guided.limit_check();
|
return mode_guided.limit_check();
|
||||||
}
|
}
|
||||||
#endif // NAV_GUIDED
|
#endif // NAV_GUIDED
|
||||||
|
|
||||||
@ -1091,7 +1091,7 @@ bool Copter::verify_yaw()
|
|||||||
bool Copter::do_guided(const AP_Mission::Mission_Command& cmd)
|
bool Copter::do_guided(const AP_Mission::Mission_Command& cmd)
|
||||||
{
|
{
|
||||||
// only process guided waypoint if we are in guided mode
|
// only process guided waypoint if we are in guided mode
|
||||||
if (control_mode != GUIDED && !(control_mode == AUTO && flightmode_auto.mode() == Auto_NavGuided)) {
|
if (control_mode != GUIDED && !(control_mode == AUTO && mode_auto.mode() == Auto_NavGuided)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1102,7 +1102,7 @@ bool Copter::do_guided(const AP_Mission::Mission_Command& cmd)
|
|||||||
{
|
{
|
||||||
// set wp_nav's destination
|
// set wp_nav's destination
|
||||||
Location_Class dest(cmd.content.location);
|
Location_Class dest(cmd.content.location);
|
||||||
return flightmode_guided.set_destination(dest);
|
return mode_guided.set_destination(dest);
|
||||||
}
|
}
|
||||||
|
|
||||||
case MAV_CMD_CONDITION_YAW:
|
case MAV_CMD_CONDITION_YAW:
|
||||||
|
@ -175,7 +175,7 @@ void Copter::failsafe_ekf_event()
|
|||||||
|
|
||||||
// if flight mode is already LAND ensure it's not the GPS controlled LAND
|
// if flight mode is already LAND ensure it's not the GPS controlled LAND
|
||||||
if (control_mode == LAND) {
|
if (control_mode == LAND) {
|
||||||
flightmode_land.do_not_use_GPS();
|
mode_land.do_not_use_GPS();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -178,7 +178,7 @@ void Copter::failsafe_terrain_on_event()
|
|||||||
if (should_disarm_on_failsafe()) {
|
if (should_disarm_on_failsafe()) {
|
||||||
init_disarm_motors();
|
init_disarm_motors();
|
||||||
} else if (control_mode == RTL) {
|
} else if (control_mode == RTL) {
|
||||||
flightmode_rtl.restart_without_terrain();
|
mode_rtl.restart_without_terrain();
|
||||||
} else {
|
} else {
|
||||||
set_mode_RTL_or_land_with_pause(MODE_REASON_TERRAIN_FAILSAFE);
|
set_mode_RTL_or_land_with_pause(MODE_REASON_TERRAIN_FAILSAFE);
|
||||||
}
|
}
|
||||||
|
@ -6,87 +6,87 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// return the static controller object corresponding to supplied mode
|
// return the static controller object corresponding to supplied mode
|
||||||
Copter::Mode *Copter::flightmode_for_mode(const uint8_t mode)
|
Copter::Mode *Copter::mode_from_mode_num(const uint8_t mode)
|
||||||
{
|
{
|
||||||
Copter::Mode *ret = nullptr;
|
Copter::Mode *ret = nullptr;
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case ACRO:
|
case ACRO:
|
||||||
ret = &flightmode_acro;
|
ret = &mode_acro;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case STABILIZE:
|
case STABILIZE:
|
||||||
ret = &flightmode_stabilize;
|
ret = &mode_stabilize;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ALT_HOLD:
|
case ALT_HOLD:
|
||||||
ret = &flightmode_althold;
|
ret = &mode_althold;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case AUTO:
|
case AUTO:
|
||||||
ret = &flightmode_auto;
|
ret = &mode_auto;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case CIRCLE:
|
case CIRCLE:
|
||||||
ret = &flightmode_circle;
|
ret = &mode_circle;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LOITER:
|
case LOITER:
|
||||||
ret = &flightmode_loiter;
|
ret = &mode_loiter;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GUIDED:
|
case GUIDED:
|
||||||
ret = &flightmode_guided;
|
ret = &mode_guided;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LAND:
|
case LAND:
|
||||||
ret = &flightmode_land;
|
ret = &mode_land;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RTL:
|
case RTL:
|
||||||
ret = &flightmode_rtl;
|
ret = &mode_rtl;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DRIFT:
|
case DRIFT:
|
||||||
ret = &flightmode_drift;
|
ret = &mode_drift;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SPORT:
|
case SPORT:
|
||||||
ret = &flightmode_sport;
|
ret = &mode_sport;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FLIP:
|
case FLIP:
|
||||||
ret = &flightmode_flip;
|
ret = &mode_flip;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#if AUTOTUNE_ENABLED == ENABLED
|
#if AUTOTUNE_ENABLED == ENABLED
|
||||||
case AUTOTUNE:
|
case AUTOTUNE:
|
||||||
ret = &flightmode_autotune;
|
ret = &mode_autotune;
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
case POSHOLD:
|
case POSHOLD:
|
||||||
ret = &flightmode_poshold;
|
ret = &mode_poshold;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case BRAKE:
|
case BRAKE:
|
||||||
ret = &flightmode_brake;
|
ret = &mode_brake;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case THROW:
|
case THROW:
|
||||||
ret = &flightmode_throw;
|
ret = &mode_throw;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case AVOID_ADSB:
|
case AVOID_ADSB:
|
||||||
ret = &flightmode_avoid_adsb;
|
ret = &mode_avoid_adsb;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case GUIDED_NOGPS:
|
case GUIDED_NOGPS:
|
||||||
ret = &flightmode_guided_nogps;
|
ret = &mode_guided_nogps;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SMART_RTL:
|
case SMART_RTL:
|
||||||
ret = &flightmode_smartrtl;
|
ret = &mode_smartrtl;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -110,7 +110,7 @@ bool Copter::set_mode(control_mode_t mode, mode_reason_t reason)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
Copter::Mode *new_flightmode = flightmode_for_mode(mode);
|
Copter::Mode *new_flightmode = mode_from_mode_num(mode);
|
||||||
if (new_flightmode == nullptr) {
|
if (new_flightmode == nullptr) {
|
||||||
gcs().send_text(MAV_SEVERITY_WARNING,"No such mode");
|
gcs().send_text(MAV_SEVERITY_WARNING,"No such mode");
|
||||||
Log_Write_Error(ERROR_SUBSYSTEM_FLIGHT_MODE,mode);
|
Log_Write_Error(ERROR_SUBSYSTEM_FLIGHT_MODE,mode);
|
||||||
@ -180,13 +180,13 @@ void Copter::exit_mode(Copter::Mode *&old_flightmode,
|
|||||||
Copter::Mode *&new_flightmode)
|
Copter::Mode *&new_flightmode)
|
||||||
{
|
{
|
||||||
#if AUTOTUNE_ENABLED == ENABLED
|
#if AUTOTUNE_ENABLED == ENABLED
|
||||||
if (old_flightmode == &flightmode_autotune) {
|
if (old_flightmode == &mode_autotune) {
|
||||||
flightmode_autotune.stop();
|
mode_autotune.stop();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// stop mission when we leave auto mode
|
// stop mission when we leave auto mode
|
||||||
if (old_flightmode == &flightmode_auto) {
|
if (old_flightmode == &mode_auto) {
|
||||||
if (mission.state() == AP_Mission::MISSION_RUNNING) {
|
if (mission.state() == AP_Mission::MISSION_RUNNING) {
|
||||||
mission.stop();
|
mission.stop();
|
||||||
}
|
}
|
||||||
@ -205,13 +205,13 @@ void Copter::exit_mode(Copter::Mode *&old_flightmode,
|
|||||||
takeoff_stop();
|
takeoff_stop();
|
||||||
|
|
||||||
// call smart_rtl cleanup
|
// call smart_rtl cleanup
|
||||||
if (old_flightmode == &flightmode_smartrtl) {
|
if (old_flightmode == &mode_smartrtl) {
|
||||||
flightmode_smartrtl.exit();
|
mode_smartrtl.exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if FRAME_CONFIG == HELI_FRAME
|
#if FRAME_CONFIG == HELI_FRAME
|
||||||
// firmly reset the flybar passthrough to false when exiting acro mode.
|
// firmly reset the flybar passthrough to false when exiting acro mode.
|
||||||
if (old_flightmode == &flightmode_acro) {
|
if (old_flightmode == &mode_acro) {
|
||||||
attitude_control->use_flybar_passthrough(false, false);
|
attitude_control->use_flybar_passthrough(false, false);
|
||||||
motors->set_acro_tail(false);
|
motors->set_acro_tail(false);
|
||||||
}
|
}
|
||||||
@ -220,9 +220,9 @@ void Copter::exit_mode(Copter::Mode *&old_flightmode,
|
|||||||
// stab col ramp value should be pre-loaded to the correct value to avoid a twitch
|
// stab col ramp value should be pre-loaded to the correct value to avoid a twitch
|
||||||
// heli_stab_col_ramp should really only be active switching between Stabilize and Acro modes
|
// heli_stab_col_ramp should really only be active switching between Stabilize and Acro modes
|
||||||
if (!old_flightmode->has_manual_throttle()){
|
if (!old_flightmode->has_manual_throttle()){
|
||||||
if (new_flightmode == &flightmode_stabilize){
|
if (new_flightmode == &mode_stabilize){
|
||||||
input_manager.set_stab_col_ramp(1.0);
|
input_manager.set_stab_col_ramp(1.0);
|
||||||
} else if (new_flightmode == &flightmode_acro){
|
} else if (new_flightmode == &mode_acro){
|
||||||
input_manager.set_stab_col_ramp(0.0);
|
input_manager.set_stab_col_ramp(0.0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,7 @@ void Copter::heli_init()
|
|||||||
void Copter::check_dynamic_flight(void)
|
void Copter::check_dynamic_flight(void)
|
||||||
{
|
{
|
||||||
if (!motors->armed() || !motors->rotor_runup_complete() ||
|
if (!motors->armed() || !motors->rotor_runup_complete() ||
|
||||||
control_mode == LAND || (control_mode==RTL && flightmode_rtl.state() == RTL_Land) || (control_mode == AUTO && flightmode_auto.mode() == Auto_Land)) {
|
control_mode == LAND || (control_mode==RTL && mode_rtl.state() == RTL_Land) || (control_mode == AUTO && mode_auto.mode() == Auto_Land)) {
|
||||||
heli_dynamic_flight_counter = 0;
|
heli_dynamic_flight_counter = 0;
|
||||||
heli_flags.dynamic_flight = false;
|
heli_flags.dynamic_flight = false;
|
||||||
return;
|
return;
|
||||||
@ -109,7 +109,7 @@ void Copter::heli_update_landing_swash()
|
|||||||
|
|
||||||
case RTL:
|
case RTL:
|
||||||
case SMART_RTL:
|
case SMART_RTL:
|
||||||
if (flightmode_rtl.state() == RTL_Land) {
|
if (mode_rtl.state() == RTL_Land) {
|
||||||
motors->set_collective_for_landing(true);
|
motors->set_collective_for_landing(true);
|
||||||
}else{
|
}else{
|
||||||
motors->set_collective_for_landing(!heli_flags.dynamic_flight || ap.land_complete || !ap.auto_armed);
|
motors->set_collective_for_landing(!heli_flags.dynamic_flight || ap.land_complete || !ap.auto_armed);
|
||||||
@ -117,7 +117,7 @@ void Copter::heli_update_landing_swash()
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case AUTO:
|
case AUTO:
|
||||||
if (flightmode_auto.mode() == Auto_Land) {
|
if (mode_auto.mode() == Auto_Land) {
|
||||||
motors->set_collective_for_landing(true);
|
motors->set_collective_for_landing(true);
|
||||||
}else{
|
}else{
|
||||||
motors->set_collective_for_landing(!heli_flags.dynamic_flight || ap.land_complete || !ap.auto_armed);
|
motors->set_collective_for_landing(!heli_flags.dynamic_flight || ap.land_complete || !ap.auto_armed);
|
||||||
|
@ -15,8 +15,8 @@ void Copter::landinggear_update()
|
|||||||
// if we are doing an automatic landing procedure, force the landing gear to deploy.
|
// if we are doing an automatic landing procedure, force the landing gear to deploy.
|
||||||
// To-Do: should we pause the auto-land procedure to give time for gear to come down?
|
// To-Do: should we pause the auto-land procedure to give time for gear to come down?
|
||||||
if (control_mode == LAND ||
|
if (control_mode == LAND ||
|
||||||
(control_mode == RTL && flightmode_rtl.landing_gear_should_be_deployed()) ||
|
(control_mode == RTL && mode_rtl.landing_gear_should_be_deployed()) ||
|
||||||
(control_mode == AUTO && flightmode_auto.landing_gear_should_be_deployed())) {
|
(control_mode == AUTO && mode_auto.landing_gear_should_be_deployed())) {
|
||||||
landinggear.set_position(AP_LandingGear::LandingGear_Deploy_And_Keep_Deployed);
|
landinggear.set_position(AP_LandingGear::LandingGear_Deploy_And_Keep_Deployed);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ bool Copter::ModeAuto::init(bool ignore_checks)
|
|||||||
wp_nav->wp_and_spline_init();
|
wp_nav->wp_and_spline_init();
|
||||||
|
|
||||||
// clear guided limits
|
// clear guided limits
|
||||||
_copter.flightmode_guided.limit_clear();
|
_copter.mode_guided.limit_clear();
|
||||||
|
|
||||||
// start/resume the mission (based on MIS_RESTART parameter)
|
// start/resume the mission (based on MIS_RESTART parameter)
|
||||||
mission.start_or_resume();
|
mission.start_or_resume();
|
||||||
@ -417,7 +417,7 @@ bool Copter::ModeAuto::landing_gear_should_be_deployed()
|
|||||||
case Auto_Land:
|
case Auto_Land:
|
||||||
return true;
|
return true;
|
||||||
case Auto_RTL:
|
case Auto_RTL:
|
||||||
switch(_copter.flightmode_rtl.state()) {
|
switch(_copter.mode_rtl.state()) {
|
||||||
case RTL_LoiterAtHome:
|
case RTL_LoiterAtHome:
|
||||||
case RTL_Land:
|
case RTL_Land:
|
||||||
case RTL_FinalDescent:
|
case RTL_FinalDescent:
|
||||||
@ -438,7 +438,7 @@ void Copter::ModeAuto::rtl_start()
|
|||||||
_mode = Auto_RTL;
|
_mode = Auto_RTL;
|
||||||
|
|
||||||
// call regular rtl flight mode initialisation and ask it to ignore checks
|
// call regular rtl flight mode initialisation and ask it to ignore checks
|
||||||
_copter.flightmode_rtl.init(true);
|
_copter.mode_rtl.init(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
// auto_rtl_run - rtl in AUTO flight mode
|
// auto_rtl_run - rtl in AUTO flight mode
|
||||||
@ -446,7 +446,7 @@ void Copter::ModeAuto::rtl_start()
|
|||||||
void Copter::ModeAuto::rtl_run()
|
void Copter::ModeAuto::rtl_run()
|
||||||
{
|
{
|
||||||
// call regular rtl flight mode run function
|
// call regular rtl flight mode run function
|
||||||
_copter.flightmode_rtl.run(false);
|
_copter.mode_rtl.run(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// auto_circle_movetoedge_start - initialise waypoint controller to move to edge of a circle with it's center at the specified location
|
// auto_circle_movetoedge_start - initialise waypoint controller to move to edge of a circle with it's center at the specified location
|
||||||
@ -534,10 +534,10 @@ void Copter::ModeAuto::nav_guided_start()
|
|||||||
_mode = Auto_NavGuided;
|
_mode = Auto_NavGuided;
|
||||||
|
|
||||||
// call regular guided flight mode initialisation
|
// call regular guided flight mode initialisation
|
||||||
_copter.flightmode_guided.init(true);
|
_copter.mode_guided.init(true);
|
||||||
|
|
||||||
// initialise guided start time and position as reference for limit checking
|
// initialise guided start time and position as reference for limit checking
|
||||||
_copter.flightmode_guided.limit_init_time_and_pos();
|
_copter.mode_guided.limit_init_time_and_pos();
|
||||||
}
|
}
|
||||||
|
|
||||||
// auto_nav_guided_run - allows control by external navigation controller
|
// auto_nav_guided_run - allows control by external navigation controller
|
||||||
@ -545,7 +545,7 @@ void Copter::ModeAuto::nav_guided_start()
|
|||||||
void Copter::ModeAuto::nav_guided_run()
|
void Copter::ModeAuto::nav_guided_run()
|
||||||
{
|
{
|
||||||
// call regular guided flight mode run function
|
// call regular guided flight mode run function
|
||||||
_copter.flightmode_guided.run();
|
_copter.mode_guided.run();
|
||||||
}
|
}
|
||||||
#endif // NAV_GUIDED
|
#endif // NAV_GUIDED
|
||||||
|
|
||||||
|
@ -177,7 +177,7 @@ void Copter::land_run_vertical_control(bool pause_descent)
|
|||||||
// compute desired velocity
|
// compute desired velocity
|
||||||
const float precland_acceptable_error = 15.0f;
|
const float precland_acceptable_error = 15.0f;
|
||||||
const float precland_min_descent_speed = 10.0f;
|
const float precland_min_descent_speed = 10.0f;
|
||||||
int32_t alt_above_ground = flightmode_land.get_alt_above_ground();
|
int32_t alt_above_ground = mode_land.get_alt_above_ground();
|
||||||
|
|
||||||
float cmb_rate = 0;
|
float cmb_rate = 0;
|
||||||
if (!pause_descent) {
|
if (!pause_descent) {
|
||||||
@ -281,7 +281,7 @@ void Copter::land_run_horizontal_control()
|
|||||||
// there is any position estimate drift after touchdown. We
|
// there is any position estimate drift after touchdown. We
|
||||||
// limit attitude to 7 degrees below this limit and linearly
|
// limit attitude to 7 degrees below this limit and linearly
|
||||||
// interpolate for 1m above that
|
// interpolate for 1m above that
|
||||||
int alt_above_ground = flightmode_land.get_alt_above_ground();
|
int alt_above_ground = mode_land.get_alt_above_ground();
|
||||||
float attitude_limit_cd = linear_interpolate(700, aparm.angle_max, alt_above_ground,
|
float attitude_limit_cd = linear_interpolate(700, aparm.angle_max, alt_above_ground,
|
||||||
g2.wp_navalt_min*100U, (g2.wp_navalt_min+1)*100U);
|
g2.wp_navalt_min*100U, (g2.wp_navalt_min+1)*100U);
|
||||||
float total_angle_cd = norm(nav_roll, nav_pitch);
|
float total_angle_cd = norm(nav_roll, nav_pitch);
|
||||||
|
@ -246,7 +246,7 @@ void Copter::init_disarm_motors()
|
|||||||
|
|
||||||
#if AUTOTUNE_ENABLED == ENABLED
|
#if AUTOTUNE_ENABLED == ENABLED
|
||||||
// save auto tuned parameters
|
// save auto tuned parameters
|
||||||
flightmode_autotune.save_tuning_gains();
|
mode_autotune.save_tuning_gains();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// we are not in the air
|
// we are not in the air
|
||||||
|
@ -562,10 +562,10 @@ void Copter::do_aux_switch_function(int8_t ch_function, uint8_t ch_flag)
|
|||||||
#if PRECISION_LANDING == ENABLED
|
#if PRECISION_LANDING == ENABLED
|
||||||
switch (ch_flag) {
|
switch (ch_flag) {
|
||||||
case AUX_SWITCH_HIGH:
|
case AUX_SWITCH_HIGH:
|
||||||
flightmode_loiter.set_precision_loiter_enabled(true);
|
mode_loiter.set_precision_loiter_enabled(true);
|
||||||
break;
|
break;
|
||||||
case AUX_SWITCH_LOW:
|
case AUX_SWITCH_LOW:
|
||||||
flightmode_loiter.set_precision_loiter_enabled(false);
|
mode_loiter.set_precision_loiter_enabled(false);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -36,7 +36,7 @@ bool Copter::do_user_takeoff(float takeoff_alt_cm, bool must_navigate)
|
|||||||
|
|
||||||
switch(control_mode) {
|
switch(control_mode) {
|
||||||
case GUIDED:
|
case GUIDED:
|
||||||
if (flightmode_guided.takeoff_start(takeoff_alt_cm)) {
|
if (mode_guided.takeoff_start(takeoff_alt_cm)) {
|
||||||
set_auto_armed(true);
|
set_auto_armed(true);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user