mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 14:38:30 -04:00
Plane: bugfix - RTL_AUTOLAND no longer overrides loiter direction
This commit is contained in:
parent
a25e6bbb2d
commit
9440e3c544
@ -99,34 +99,28 @@ void ModeRTL::navigate()
|
||||
}
|
||||
#endif
|
||||
|
||||
if (plane.g.rtl_autoland == RtlAutoland::RTL_THEN_DO_LAND_START &&
|
||||
!plane.auto_state.checked_for_autoland &&
|
||||
if (!plane.auto_state.checked_for_autoland) {
|
||||
if ((plane.g.rtl_autoland == RtlAutoland::RTL_IMMEDIATE_DO_LAND_START) ||
|
||||
(plane.g.rtl_autoland == RtlAutoland::RTL_THEN_DO_LAND_START &&
|
||||
plane.reached_loiter_target() &&
|
||||
labs(plane.altitude_error_cm) < 1000) {
|
||||
labs(plane.altitude_error_cm) < 1000))
|
||||
{
|
||||
// we've reached the RTL point, see if we have a landing sequence
|
||||
if (plane.mission.jump_to_landing_sequence()) {
|
||||
// switch from RTL -> AUTO
|
||||
plane.mission.set_force_resume(true);
|
||||
plane.set_mode(plane.mode_auto, ModeReason::RTL_COMPLETE_SWITCHING_TO_FIXEDWING_AUTOLAND);
|
||||
if (plane.set_mode(plane.mode_auto, ModeReason::RTL_COMPLETE_SWITCHING_TO_FIXEDWING_AUTOLAND)) {
|
||||
// return here so we don't change the radius and don't run the rtl update_loiter()
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
// prevent running the expensive jump_to_landing_sequence
|
||||
// on every loop
|
||||
plane.auto_state.checked_for_autoland = true;
|
||||
}
|
||||
else if (plane.g.rtl_autoland == RtlAutoland::RTL_IMMEDIATE_DO_LAND_START &&
|
||||
!plane.auto_state.checked_for_autoland) {
|
||||
// Go directly to the landing sequence
|
||||
if (plane.mission.jump_to_landing_sequence()) {
|
||||
// switch from RTL -> AUTO
|
||||
plane.mission.set_force_resume(true);
|
||||
plane.set_mode(plane.mode_auto, ModeReason::RTL_COMPLETE_SWITCHING_TO_FIXEDWING_AUTOLAND);
|
||||
}
|
||||
|
||||
// prevent running the expensive jump_to_landing_sequence
|
||||
// on every loop
|
||||
plane.auto_state.checked_for_autoland = true;
|
||||
}
|
||||
uint16_t radius = abs(plane.g.rtl_radius);
|
||||
if (radius > 0) {
|
||||
plane.loiter.direction = (plane.g.rtl_radius < 0) ? -1 : 1;
|
||||
|
Loading…
Reference in New Issue
Block a user