From 763757b8b284fd6ae5d011f51840f976c832c4bd Mon Sep 17 00:00:00 2001 From: timtuxworth Date: Mon, 26 Aug 2024 11:09:13 -0600 Subject: [PATCH] ArduPlane: use Location::AltFrame for guided_state.target_alt_frame --- ArduPlane/mode_guided.cpp | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/ArduPlane/mode_guided.cpp b/ArduPlane/mode_guided.cpp index 758e403a68c313..5602ec9b5cbe50 100644 --- a/ArduPlane/mode_guided.cpp +++ b/ArduPlane/mode_guided.cpp @@ -139,15 +139,17 @@ void ModeGuided::update_target_altitude() // then scale x100 to match last_target_alt and convert to a signed int32_t as it may be negative int32_t delta_amt_i = (int32_t)(100.0 * delta_amt_f); Location temp {}; + int32_t temp_alt = plane.guided_state.last_target_alt + delta_amt_i; // Restore the last altitude that the plane had been flying - temp.set_alt_cm(plane.guided_state.last_target_alt + delta_amt_i, plane.guided_state.last_target_alt_frame); - if (is_positive(plane.guided_state.target_alt_accel)) { - temp.alt = MIN(plane.guided_state.target_alt, temp.alt); + temp_alt = MIN(plane.guided_state.target_alt, temp_alt); } else { - temp.alt = MAX(plane.guided_state.target_alt, temp.alt); + temp_alt = MAX(plane.guided_state.target_alt, temp_alt); } + temp.set_alt_cm(temp_alt, plane.guided_state.last_target_alt_frame); + plane.guided_state.last_target_alt = temp.alt; + plane.guided_state.last_target_alt_frame = temp.get_alt_frame(); plane.set_target_altitude_location(temp); } else #endif // AP_PLANE_OFFBOARD_GUIDED_SLEW_ENABLED