mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-25 10:08:28 -04:00
d666f6ed02
we need to setup last_fw_mode_ms and last_fw_nav_pitch_cd when we enter POSITION1 mode so that the expanding envelope pitch limit from Q_BACKTRANS_MS is applied correctly
126 lines
3.4 KiB
C++
126 lines
3.4 KiB
C++
/*
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#pragma once
|
|
#include <GCS_MAVLink/GCS.h>
|
|
|
|
class QuadPlane;
|
|
class AP_MotorsMulticopter;
|
|
// Transition empty base class
|
|
class Transition
|
|
{
|
|
public:
|
|
|
|
Transition(QuadPlane& _quadplane, AP_MotorsMulticopter*& _motors):quadplane(_quadplane),motors(_motors) {};
|
|
|
|
virtual void update() = 0;
|
|
|
|
virtual void VTOL_update() = 0;
|
|
|
|
virtual void force_transistion_complete() = 0;
|
|
|
|
virtual bool complete() const = 0;
|
|
|
|
virtual void restart() = 0;
|
|
|
|
virtual uint8_t get_log_transision_state() const = 0;
|
|
|
|
virtual bool active() const = 0;
|
|
|
|
virtual bool show_vtol_view() const = 0;
|
|
|
|
virtual void set_FW_roll_pitch(int32_t& nav_pitch_cd, int32_t& nav_roll_cd, bool& allow_stick_mixing) {};
|
|
|
|
virtual bool set_FW_roll_limit(int32_t& roll_limit_cd) { return false; }
|
|
|
|
virtual bool allow_update_throttle_mix() const { return true; }
|
|
|
|
virtual bool update_yaw_target(float& yaw_target_cd) { return false; }
|
|
|
|
virtual MAV_VTOL_STATE get_mav_vtol_state() const = 0;
|
|
|
|
virtual bool set_VTOL_roll_pitch_limit(int32_t& nav_roll_cd, int32_t& nav_pitch_cd) { return false; }
|
|
|
|
virtual bool allow_weathervane() { return true; }
|
|
|
|
virtual void set_last_fw_pitch(void) {}
|
|
|
|
protected:
|
|
|
|
// refences for convenience
|
|
QuadPlane& quadplane;
|
|
AP_MotorsMulticopter*& motors;
|
|
|
|
};
|
|
|
|
// Transition for separate left thrust quadplanes
|
|
class SLT_Transition : public Transition
|
|
{
|
|
public:
|
|
|
|
using Transition::Transition;
|
|
|
|
void update() override;
|
|
|
|
void VTOL_update() override;
|
|
|
|
void force_transistion_complete() override;
|
|
|
|
bool complete() const override { return transition_state == TRANSITION_DONE; }
|
|
|
|
void restart() override { transition_state = TRANSITION_AIRSPEED_WAIT; }
|
|
|
|
uint8_t get_log_transision_state() const override { return static_cast<uint8_t>(transition_state); }
|
|
|
|
bool active() const override;
|
|
|
|
bool show_vtol_view() const override;
|
|
|
|
bool set_FW_roll_limit(int32_t& roll_limit_cd) override;
|
|
|
|
bool allow_update_throttle_mix() const override;
|
|
|
|
MAV_VTOL_STATE get_mav_vtol_state() const override;
|
|
|
|
bool set_VTOL_roll_pitch_limit(int32_t& nav_roll_cd, int32_t& nav_pitch_cd) override;
|
|
|
|
void set_last_fw_pitch(void) override;
|
|
|
|
protected:
|
|
|
|
enum {
|
|
TRANSITION_AIRSPEED_WAIT,
|
|
TRANSITION_TIMER,
|
|
TRANSITION_DONE
|
|
} transition_state;
|
|
|
|
// timer start for transition
|
|
uint32_t transition_start_ms;
|
|
uint32_t transition_low_airspeed_ms;
|
|
|
|
// last throttle value when active
|
|
float last_throttle;
|
|
|
|
// time and pitch angle whe last in a vtol or FW control mode
|
|
uint32_t last_fw_mode_ms;
|
|
int32_t last_fw_nav_pitch_cd;
|
|
|
|
// tiltrotor tilt angle when airspeed wait transition stage completes
|
|
float airspeed_reached_tilt;
|
|
|
|
bool in_forced_transition;
|
|
|
|
};
|
|
|