Browse Source

rtl: head towards home location after descend

release/1.12
David Jablonski 4 years ago committed by Silvan Fuhrer
parent
commit
ed7a5314d8
  1. 27
      src/modules/navigator/rtl.cpp
  2. 1
      src/modules/navigator/rtl.h

27
src/modules/navigator/rtl.cpp

@ -258,6 +258,7 @@ void RTL::on_activation()
const vehicle_global_position_s &global_position = *_navigator->get_global_position(); const vehicle_global_position_s &global_position = *_navigator->get_global_position();
_rtl_loiter_rad = _param_rtl_loiter_rad.get(); _rtl_loiter_rad = _param_rtl_loiter_rad.get();
if (_navigator->get_vstatus()->vehicle_type == vehicle_status_s::VEHICLE_TYPE_ROTARY_WING) { if (_navigator->get_vstatus()->vehicle_type == vehicle_status_s::VEHICLE_TYPE_ROTARY_WING) {
_rtl_alt = calculate_return_alt_from_cone_half_angle((float)_param_rtl_cone_half_angle_deg.get()); _rtl_alt = calculate_return_alt_from_cone_half_angle((float)_param_rtl_cone_half_angle_deg.get());
@ -458,6 +459,24 @@ void RTL::set_rtl_item()
break; break;
} }
case RTL_STATE_HEAD_TO_CENTER: {
_mission_item.nav_cmd = NAV_CMD_WAYPOINT;
_mission_item.lat = _destination.lat;
_mission_item.lon = _destination.lon;
_mission_item.altitude = loiter_altitude;
_mission_item.altitude_is_relative = false;
_mission_item.yaw = get_bearing_to_next_waypoint(gpos.lat, gpos.lon, _mission_item.lat, _mission_item.lon);
_mission_item.acceptance_radius = _navigator->get_acceptance_radius();
_mission_item.time_inside = 0.0f;
_mission_item.autocontinue = true;
_mission_item.origin = ORIGIN_ONBOARD;
// Disable previous setpoint to prevent drift.
pos_sp_triplet->previous.valid = false;
break;
}
case RTL_STATE_TRANSITION_TO_MC: { case RTL_STATE_TRANSITION_TO_MC: {
set_vtol_transition_item(&_mission_item, vtol_vehicle_status_s::VEHICLE_VTOL_STATE_MC); set_vtol_transition_item(&_mission_item, vtol_vehicle_status_s::VEHICLE_VTOL_STATE_MC);
break; break;
@ -559,7 +578,7 @@ void RTL::advance_rtl()
_rtl_state = RTL_STATE_LOITER; _rtl_state = RTL_STATE_LOITER;
} else if (vtol_in_fw_mode) { } else if (vtol_in_fw_mode) {
_rtl_state = RTL_STATE_TRANSITION_TO_MC; _rtl_state = RTL_STATE_HEAD_TO_CENTER;
} else { } else {
_rtl_state = RTL_STATE_LAND; _rtl_state = RTL_STATE_LAND;
@ -578,6 +597,12 @@ void RTL::advance_rtl()
_rtl_state = RTL_STATE_LAND; _rtl_state = RTL_STATE_LAND;
break; break;
case RTL_STATE_HEAD_TO_CENTER:
_rtl_state = RTL_STATE_TRANSITION_TO_MC;
break;
case RTL_STATE_TRANSITION_TO_MC: case RTL_STATE_TRANSITION_TO_MC:
_rtl_state = RTL_MOVE_TO_LAND_HOVER_VTOL; _rtl_state = RTL_MOVE_TO_LAND_HOVER_VTOL;

1
src/modules/navigator/rtl.h

@ -121,6 +121,7 @@ private:
RTL_MOVE_TO_LAND_HOVER_VTOL, RTL_MOVE_TO_LAND_HOVER_VTOL,
RTL_STATE_LAND, RTL_STATE_LAND,
RTL_STATE_LANDED, RTL_STATE_LANDED,
RTL_STATE_HEAD_TO_CENTER,
} _rtl_state{RTL_STATE_NONE}; } _rtl_state{RTL_STATE_NONE};
struct RTLPosition { struct RTLPosition {

Loading…
Cancel
Save