Copter: allow tradheli inverted feature for stabilize, althold, loiter and auto modes

This commit is contained in:
bnsgeyer 2024-03-05 23:18:38 -05:00 committed by Randy Mackay
parent f06bbd471f
commit a07b514ee8
3 changed files with 14 additions and 4 deletions

View File

@ -106,8 +106,9 @@ void Copter::update_heli_control_dynamics(void)
bool Copter::should_use_landing_swash() const bool Copter::should_use_landing_swash() const
{ {
if (flightmode->has_manual_throttle() || if (flightmode->has_manual_throttle() ||
flightmode->mode_number() == Mode::Number::DRIFT) { flightmode->mode_number() == Mode::Number::DRIFT ||
// manual modes always uses full swash range attitude_control->get_inverted_flight()) {
// manual modes or modes using inverted flight uses full swash range
return false; return false;
} }
if (flightmode->is_landing()) { if (flightmode->is_landing()) {

View File

@ -471,7 +471,9 @@ public:
} }
bool allows_autotune() const override { return true; } bool allows_autotune() const override { return true; }
bool allows_flip() const override { return true; } bool allows_flip() const override { return true; }
#if FRAME_CONFIG == HELI_FRAME
bool allows_inverted() const override { return true; };
#endif
protected: protected:
const char *name() const override { return "ALT_HOLD"; } const char *name() const override { return "ALT_HOLD"; }
@ -499,6 +501,9 @@ public:
bool allows_arming(AP_Arming::Method method) const override; bool allows_arming(AP_Arming::Method method) const override;
bool is_autopilot() const override { return true; } bool is_autopilot() const override { return true; }
bool in_guided_mode() const override { return _mode == SubMode::NAVGUIDED || _mode == SubMode::NAV_SCRIPT_TIME; } bool in_guided_mode() const override { return _mode == SubMode::NAVGUIDED || _mode == SubMode::NAV_SCRIPT_TIME; }
#if FRAME_CONFIG == HELI_FRAME
bool allows_inverted() const override { return true; };
#endif
// Auto modes // Auto modes
enum class SubMode : uint8_t { enum class SubMode : uint8_t {
@ -1250,6 +1255,10 @@ public:
bool has_user_takeoff(bool must_navigate) const override { return true; } bool has_user_takeoff(bool must_navigate) const override { return true; }
bool allows_autotune() const override { return true; } bool allows_autotune() const override { return true; }
#if FRAME_CONFIG == HELI_FRAME
bool allows_inverted() const override { return true; };
#endif
#if AC_PRECLAND_ENABLED #if AC_PRECLAND_ENABLED
void set_precision_loiter_enabled(bool value) { _precision_loiter_enabled = value; } void set_precision_loiter_enabled(bool value) { _precision_loiter_enabled = value; }
#endif #endif

View File

@ -78,7 +78,7 @@ void ModeStabilize_Heli::run()
attitude_control->input_euler_angle_roll_pitch_euler_rate_yaw(target_roll, target_pitch, target_yaw_rate); attitude_control->input_euler_angle_roll_pitch_euler_rate_yaw(target_roll, target_pitch, target_yaw_rate);
// output pilot's throttle - note that TradHeli does not used angle-boost // output pilot's throttle - note that TradHeli does not used angle-boost
attitude_control->set_throttle_out(pilot_throttle_scaled, false, g.throttle_filt); attitude_control->set_throttle_out(pilot_throttle_scaled, true, g.throttle_filt);
} }
#endif //HELI_FRAME #endif //HELI_FRAME