2021-03-18 00:12:54 -03:00
# include "Blimp.h"
2024-12-22 22:26:53 -04:00
# include "GCS_MAVLink_Blimp.h"
2022-09-27 22:37:45 -03:00
# include <AP_RPM/AP_RPM_config.h>
2023-10-27 04:13:08 -03:00
# include <AP_OpticalFlow/AP_OpticalFlow_config.h>
2021-03-18 00:12:54 -03:00
MAV_TYPE GCS_Blimp : : frame_type ( ) const
{
return blimp . get_frame_mav_type ( ) ;
}
MAV_MODE GCS_MAVLINK_Blimp : : base_mode ( ) const
{
uint8_t _base_mode = MAV_MODE_FLAG_STABILIZE_ENABLED ;
_base_mode | = MAV_MODE_FLAG_MANUAL_INPUT_ENABLED ;
// we are armed if we are not initialising
if ( blimp . motors ! = nullptr & & blimp . motors - > armed ( ) ) {
_base_mode | = MAV_MODE_FLAG_SAFETY_ARMED ;
}
// indicate we have set a custom mode
_base_mode | = MAV_MODE_FLAG_CUSTOM_MODE_ENABLED ;
return ( MAV_MODE ) _base_mode ;
}
uint32_t GCS_Blimp : : custom_mode ( ) const
{
return ( uint32_t ) blimp . control_mode ;
}
MAV_STATE GCS_MAVLINK_Blimp : : vehicle_system_status ( ) const
{
// set system as critical if any failsafe have triggered
if ( blimp . any_failsafe_triggered ( ) ) {
return MAV_STATE_CRITICAL ;
}
if ( blimp . ap . land_complete ) {
return MAV_STATE_STANDBY ;
}
2024-06-14 11:16:58 -03:00
if ( ! blimp . ap . initialised ) {
return MAV_STATE_BOOT ;
}
2021-03-18 00:12:54 -03:00
return MAV_STATE_ACTIVE ;
}
void GCS_MAVLINK_Blimp : : send_position_target_global_int ( )
{
Location target ;
if ( ! blimp . flightmode - > get_wp ( target ) ) {
return ;
}
2021-04-21 14:01:23 -03:00
static constexpr uint16_t POSITION_TARGET_TYPEMASK_LAST_BYTE = 0xF000 ;
static constexpr uint16_t TYPE_MASK = POSITION_TARGET_TYPEMASK_VX_IGNORE | POSITION_TARGET_TYPEMASK_VY_IGNORE | POSITION_TARGET_TYPEMASK_VZ_IGNORE |
2023-08-21 08:19:19 -03:00
POSITION_TARGET_TYPEMASK_AX_IGNORE | POSITION_TARGET_TYPEMASK_AY_IGNORE | POSITION_TARGET_TYPEMASK_AZ_IGNORE |
POSITION_TARGET_TYPEMASK_YAW_IGNORE | POSITION_TARGET_TYPEMASK_YAW_RATE_IGNORE | POSITION_TARGET_TYPEMASK_LAST_BYTE ;
2021-04-21 14:01:23 -03:00
2021-03-18 00:12:54 -03:00
mavlink_msg_position_target_global_int_send (
chan ,
AP_HAL : : millis ( ) , // time_boot_ms
MAV_FRAME_GLOBAL , // targets are always global altitude
2021-04-21 14:01:23 -03:00
TYPE_MASK , // ignore everything except the x/y/z components
2021-03-18 00:12:54 -03:00
target . lat , // latitude as 1e7
target . lng , // longitude as 1e7
target . alt * 0.01f , // altitude is sent as a float
0.0f , // vx
0.0f , // vy
0.0f , // vz
0.0f , // afx
0.0f , // afy
0.0f , // afz
0.0f , // yaw
0.0f ) ; // yaw_rate
}
void GCS_MAVLINK_Blimp : : send_nav_controller_output ( ) const
{
2021-03-29 11:43:54 -03:00
2021-03-18 00:12:54 -03:00
}
float GCS_MAVLINK_Blimp : : vfr_hud_airspeed ( ) const
{
Vector3f airspeed_vec_bf ;
if ( AP : : ahrs ( ) . airspeed_vector_true ( airspeed_vec_bf ) ) {
// we are running the EKF3 wind estimation code which can give
// us an airspeed estimate
return airspeed_vec_bf . length ( ) ;
}
return AP : : gps ( ) . ground_speed ( ) ;
}
int16_t GCS_MAVLINK_Blimp : : vfr_hud_throttle ( ) const
{
if ( blimp . motors = = nullptr ) {
return 0 ;
}
return ( int16_t ) ( blimp . motors - > get_throttle ( ) * 100 ) ;
}
/*
send PID tuning message
*/
void GCS_MAVLINK_Blimp : : send_pid_tuning ( )
{
2023-07-27 02:06:32 -03:00
if ( blimp . control_mode = = Mode : : Number : : MANUAL | | blimp . control_mode = = Mode : : Number : : LAND ) {
2021-06-23 23:26:56 -03:00
//No PIDs are used in Manual or Land mode.
return ;
}
2023-07-27 02:06:32 -03:00
2021-06-23 23:26:56 -03:00
static const int8_t axes [ ] = {
PID_SEND : : VELX ,
PID_SEND : : VELY ,
PID_SEND : : VELZ ,
PID_SEND : : VELYAW ,
PID_SEND : : POSX ,
PID_SEND : : POSY ,
PID_SEND : : POSZ ,
PID_SEND : : POSYAW
2021-03-18 00:12:54 -03:00
} ;
for ( uint8_t i = 0 ; i < ARRAY_SIZE ( axes ) ; i + + ) {
if ( ! ( blimp . g . gcs_pid_mask & ( 1 < < ( axes [ i ] - 1 ) ) ) ) {
continue ;
}
if ( ! HAVE_PAYLOAD_SPACE ( chan , PID_TUNING ) ) {
return ;
}
2022-03-03 23:29:50 -04:00
const AP_PIDInfo * pid_info = nullptr ;
2021-06-23 23:26:56 -03:00
switch ( axes [ i ] ) {
case PID_SEND : : VELX :
pid_info = & blimp . pid_vel_xy . get_pid_info_x ( ) ;
break ;
case PID_SEND : : VELY :
pid_info = & blimp . pid_vel_xy . get_pid_info_y ( ) ;
break ;
case PID_SEND : : VELZ :
pid_info = & blimp . pid_vel_z . get_pid_info ( ) ;
break ;
case PID_SEND : : VELYAW :
pid_info = & blimp . pid_vel_yaw . get_pid_info ( ) ;
break ;
case PID_SEND : : POSX :
pid_info = & blimp . pid_pos_xy . get_pid_info_x ( ) ;
break ;
case PID_SEND : : POSY :
pid_info = & blimp . pid_pos_xy . get_pid_info_y ( ) ;
break ;
case PID_SEND : : POSZ :
pid_info = & blimp . pid_pos_z . get_pid_info ( ) ;
break ;
case PID_SEND : : POSYAW :
pid_info = & blimp . pid_pos_yaw . get_pid_info ( ) ;
break ;
2021-03-18 00:12:54 -03:00
default :
continue ;
}
if ( pid_info ! = nullptr ) {
mavlink_msg_pid_tuning_send ( chan ,
axes [ i ] ,
pid_info - > target ,
pid_info - > actual ,
pid_info - > FF ,
pid_info - > P ,
pid_info - > I ,
2021-08-14 00:11:09 -03:00
pid_info - > D ,
pid_info - > slew_rate ,
pid_info - > Dmod ) ;
2021-03-18 00:12:54 -03:00
}
}
}
uint8_t GCS_MAVLINK_Blimp : : sysid_my_gcs ( ) const
{
return blimp . g . sysid_my_gcs ;
}
bool GCS_MAVLINK_Blimp : : sysid_enforce ( ) const
{
return blimp . g2 . sysid_enforce ;
}
uint32_t GCS_MAVLINK_Blimp : : telem_delay ( ) const
{
return ( uint32_t ) ( blimp . g . telem_delay ) ;
}
bool GCS_Blimp : : vehicle_initialised ( ) const
{
return blimp . ap . initialised ;
}
// try to send a message, return false if it wasn't sent
bool GCS_MAVLINK_Blimp : : try_send_message ( enum ap_message id )
{
switch ( id ) {
case MSG_WIND :
CHECK_PAYLOAD_SIZE ( WIND ) ;
send_wind ( ) ;
break ;
case MSG_SERVO_OUT :
case MSG_AOA_SSA :
case MSG_LANDING :
case MSG_ADSB_VEHICLE :
// unused
break ;
default :
return GCS_MAVLINK : : try_send_message ( id ) ;
}
return true ;
}
const AP_Param : : GroupInfo GCS_MAVLINK_Parameters : : var_info [ ] = {
// @Param: RAW_SENS
// @DisplayName: Raw sensor stream rate
2023-01-21 15:14:00 -04:00
// @Description: Stream rate of RAW_IMU, SCALED_IMU2, SCALED_IMU3, SCALED_PRESSURE, SCALED_PRESSURE2, SCALED_PRESSURE3, AIRSPEED and SENSOR_OFFSETS to ground station
2021-03-18 00:12:54 -03:00
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " RAW_SENS " , 0 , GCS_MAVLINK_Parameters , streamRates [ 0 ] , 0 ) ,
// @Param: EXT_STAT
// @DisplayName: Extended status stream rate to ground station
2021-08-23 01:56:22 -03:00
// @Description: Stream rate of SYS_STATUS, POWER_STATUS, MCU_STATUS, MEMINFO, CURRENT_WAYPOINT, GPS_RAW_INT, GPS_RTK (if available), GPS2_RAW (if available), GPS2_RTK (if available), NAV_CONTROLLER_OUTPUT, and FENCE_STATUS to ground station
2021-03-18 00:12:54 -03:00
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " EXT_STAT " , 1 , GCS_MAVLINK_Parameters , streamRates [ 1 ] , 0 ) ,
// @Param: RC_CHAN
// @DisplayName: RC Channel stream rate to ground station
// @Description: Stream rate of SERVO_OUTPUT_RAW and RC_CHANNELS to ground station
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " RC_CHAN " , 2 , GCS_MAVLINK_Parameters , streamRates [ 2 ] , 0 ) ,
// @Param: RAW_CTRL
2021-06-09 08:31:35 -03:00
// @DisplayName: Unused
// @Description: Unused
2021-03-18 00:12:54 -03:00
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " RAW_CTRL " , 3 , GCS_MAVLINK_Parameters , streamRates [ 3 ] , 0 ) ,
// @Param: POSITION
// @DisplayName: Position stream rate to ground station
// @Description: Stream rate of GLOBAL_POSITION_INT and LOCAL_POSITION_NED to ground station
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " POSITION " , 4 , GCS_MAVLINK_Parameters , streamRates [ 4 ] , 0 ) ,
// @Param: EXTRA1
// @DisplayName: Extra data type 1 stream rate to ground station
// @Description: Stream rate of ATTITUDE, SIMSTATE (SITL only), AHRS2 and PID_TUNING to ground station
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " EXTRA1 " , 5 , GCS_MAVLINK_Parameters , streamRates [ 5 ] , 0 ) ,
// @Param: EXTRA2
// @DisplayName: Extra data type 2 stream rate to ground station
// @Description: Stream rate of VFR_HUD to ground station
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " EXTRA2 " , 6 , GCS_MAVLINK_Parameters , streamRates [ 6 ] , 0 ) ,
// @Param: EXTRA3
// @DisplayName: Extra data type 3 stream rate to ground station
2024-09-26 22:01:25 -03:00
// @Description: Stream rate of AHRS, SYSTEM_TIME, RANGEFINDER, DISTANCE_SENSOR, GIMBAL_DEVICE_ATTITUDE_STATUS, OPTICAL_FLOW, MAG_CAL_REPORT, MAG_CAL_PROGRESS, EKF_STATUS_REPORT, VIBRATION and RPM to ground station
2021-03-18 00:12:54 -03:00
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " EXTRA3 " , 7 , GCS_MAVLINK_Parameters , streamRates [ 7 ] , 0 ) ,
// @Param: PARAMS
// @DisplayName: Parameter stream rate to ground station
// @Description: Stream rate of PARAM_VALUE to ground station
// @Units: Hz
// @Range: 0 10
// @Increment: 1
2022-02-19 21:08:11 -04:00
// @RebootRequired: True
2021-03-18 00:12:54 -03:00
// @User: Advanced
AP_GROUPINFO ( " PARAMS " , 8 , GCS_MAVLINK_Parameters , streamRates [ 8 ] , 0 ) ,
AP_GROUPEND
} ;
static const ap_message STREAM_RAW_SENSORS_msgs [ ] = {
MSG_RAW_IMU ,
MSG_SCALED_IMU2 ,
MSG_SCALED_IMU3 ,
MSG_SCALED_PRESSURE ,
MSG_SCALED_PRESSURE2 ,
MSG_SCALED_PRESSURE3 ,
2024-09-22 13:53:03 -03:00
# if AP_AIRSPEED_ENABLED
2023-01-21 15:14:00 -04:00
MSG_AIRSPEED ,
2024-09-22 13:53:03 -03:00
# endif
2021-03-18 00:12:54 -03:00
} ;
static const ap_message STREAM_EXTENDED_STATUS_msgs [ ] = {
MSG_SYS_STATUS ,
MSG_POWER_STATUS ,
2023-10-27 04:16:35 -03:00
# if HAL_WITH_MCU_MONITORING
2021-08-23 01:56:22 -03:00
MSG_MCU_STATUS ,
2023-10-27 04:16:35 -03:00
# endif
2021-03-18 00:12:54 -03:00
MSG_MEMINFO ,
MSG_CURRENT_WAYPOINT , // MISSION_CURRENT
2024-11-10 03:24:50 -04:00
# if AP_GPS_GPS_RAW_INT_SENDING_ENABLED
2021-03-18 00:12:54 -03:00
MSG_GPS_RAW ,
2024-11-10 03:24:50 -04:00
# endif
# if AP_GPS_GPS_RTK_SENDING_ENABLED
2021-03-18 00:12:54 -03:00
MSG_GPS_RTK ,
2024-11-10 03:24:50 -04:00
# endif
# if AP_GPS_GPS2_RAW_SENDING_ENABLED
2021-03-18 00:12:54 -03:00
MSG_GPS2_RAW ,
2024-11-10 03:24:50 -04:00
# endif
# if AP_GPS_GPS2_RTK_SENDING_ENABLED
2021-03-18 00:12:54 -03:00
MSG_GPS2_RTK ,
2023-10-25 01:23:59 -03:00
# endif
2021-03-18 00:12:54 -03:00
MSG_NAV_CONTROLLER_OUTPUT ,
2023-10-03 06:49:35 -03:00
# if AP_FENCE_ENABLED
2021-03-18 00:12:54 -03:00
MSG_FENCE_STATUS ,
2023-10-03 06:49:35 -03:00
# endif
2021-03-18 00:12:54 -03:00
MSG_POSITION_TARGET_GLOBAL_INT ,
} ;
static const ap_message STREAM_POSITION_msgs [ ] = {
MSG_LOCATION ,
MSG_LOCAL_POSITION
} ;
static const ap_message STREAM_RC_CHANNELS_msgs [ ] = {
MSG_SERVO_OUTPUT_RAW ,
MSG_RC_CHANNELS ,
2024-07-25 03:22:14 -03:00
# if AP_MAVLINK_MSG_RC_CHANNELS_RAW_ENABLED
2021-03-18 00:12:54 -03:00
MSG_RC_CHANNELS_RAW , // only sent on a mavlink1 connection
2024-07-25 03:22:14 -03:00
# endif
2021-03-18 00:12:54 -03:00
} ;
static const ap_message STREAM_EXTRA1_msgs [ ] = {
MSG_ATTITUDE ,
2023-11-18 20:38:47 -04:00
# if AP_SIM_ENABLED
2021-03-18 00:12:54 -03:00
MSG_SIMSTATE ,
2023-11-18 20:38:47 -04:00
# endif
2021-03-18 00:12:54 -03:00
MSG_AHRS2 ,
MSG_PID_TUNING // Up to four PID_TUNING messages are sent, depending on GCS_PID_MASK parameter
} ;
static const ap_message STREAM_EXTRA2_msgs [ ] = {
MSG_VFR_HUD
} ;
static const ap_message STREAM_EXTRA3_msgs [ ] = {
MSG_AHRS ,
MSG_SYSTEM_TIME ,
MSG_WIND ,
2024-02-29 11:57:37 -04:00
# if AP_RANGEFINDER_ENABLED
2021-03-18 00:12:54 -03:00
MSG_RANGEFINDER ,
2024-02-29 11:57:37 -04:00
# endif
2021-03-18 00:12:54 -03:00
MSG_DISTANCE_SENSOR ,
2023-10-24 22:15:02 -03:00
# if AP_BATTERY_ENABLED
2021-03-18 00:12:54 -03:00
MSG_BATTERY_STATUS ,
2023-10-24 22:15:02 -03:00
# endif
2023-10-27 04:10:36 -03:00
# if HAL_MOUNT_ENABLED
2022-07-11 05:08:41 -03:00
MSG_GIMBAL_DEVICE_ATTITUDE_STATUS ,
2023-10-27 04:10:36 -03:00
# endif
2023-10-27 04:13:08 -03:00
# if AP_OPTICALFLOW_ENABLED
2021-03-18 00:12:54 -03:00
MSG_OPTICAL_FLOW ,
2023-10-27 04:13:08 -03:00
# endif
2023-09-20 09:58:20 -03:00
# if COMPASS_CAL_ENABLED
2021-03-18 00:12:54 -03:00
MSG_MAG_CAL_REPORT ,
MSG_MAG_CAL_PROGRESS ,
2023-09-20 09:58:20 -03:00
# endif
2021-03-18 00:12:54 -03:00
MSG_EKF_STATUS_REPORT ,
MSG_VIBRATION ,
2022-09-27 22:37:45 -03:00
# if AP_RPM_ENABLED
2021-03-18 00:12:54 -03:00
MSG_RPM ,
2022-09-27 22:37:45 -03:00
# endif
2023-10-27 04:24:38 -03:00
# if HAL_WITH_ESC_TELEM
2021-03-18 00:12:54 -03:00
MSG_ESC_TELEMETRY ,
2023-10-27 04:24:38 -03:00
# endif
2023-10-27 04:21:49 -03:00
# if HAL_GENERATOR_ENABLED
2021-03-18 00:12:54 -03:00
MSG_GENERATOR_STATUS ,
2023-10-27 04:21:49 -03:00
# endif
2021-03-18 00:12:54 -03:00
} ;
static const ap_message STREAM_PARAMS_msgs [ ] = {
2024-11-09 08:35:04 -04:00
MSG_NEXT_PARAM ,
MSG_AVAILABLE_MODES
2021-03-18 00:12:54 -03:00
} ;
static const ap_message STREAM_ADSB_msgs [ ] = {
2021-08-14 18:28:23 -03:00
MSG_ADSB_VEHICLE ,
2023-10-24 22:42:16 -03:00
# if AP_AIS_ENABLED
2021-08-14 18:28:23 -03:00
MSG_AIS_VESSEL ,
2023-10-24 22:42:16 -03:00
# endif
2021-03-18 00:12:54 -03:00
} ;
const struct GCS_MAVLINK : : stream_entries GCS_MAVLINK : : all_stream_entries [ ] = {
MAV_STREAM_ENTRY ( STREAM_RAW_SENSORS ) ,
MAV_STREAM_ENTRY ( STREAM_EXTENDED_STATUS ) ,
MAV_STREAM_ENTRY ( STREAM_POSITION ) ,
MAV_STREAM_ENTRY ( STREAM_RC_CHANNELS ) ,
MAV_STREAM_ENTRY ( STREAM_EXTRA1 ) ,
MAV_STREAM_ENTRY ( STREAM_EXTRA2 ) ,
MAV_STREAM_ENTRY ( STREAM_EXTRA3 ) ,
MAV_STREAM_ENTRY ( STREAM_ADSB ) ,
MAV_STREAM_ENTRY ( STREAM_PARAMS ) ,
MAV_STREAM_TERMINATOR // must have this at end of stream_entries
} ;
void GCS_MAVLINK_Blimp : : packetReceived ( const mavlink_status_t & status ,
const mavlink_message_t & msg )
{
GCS_MAVLINK : : packetReceived ( status , msg ) ;
}
bool GCS_MAVLINK_Blimp : : params_ready ( ) const
{
if ( AP_BoardConfig : : in_config_error ( ) ) {
// we may never have parameters "initialised" in this case
return true ;
}
// if we have not yet initialised (including allocating the motors
// object) we drop this request. That prevents the GCS from getting
// a confusing parameter count during bootup
return blimp . ap . initialised_params ;
}
void GCS_MAVLINK_Blimp : : send_banner ( )
{
GCS_MAVLINK : : send_banner ( ) ;
send_text ( MAV_SEVERITY_INFO , " Frame: %s " , blimp . get_frame_string ( ) ) ;
}
2023-09-07 07:13:30 -03:00
MAV_RESULT GCS_MAVLINK_Blimp : : _handle_command_preflight_calibration ( const mavlink_command_int_t & packet , const mavlink_message_t & msg )
2021-03-18 00:12:54 -03:00
{
2022-12-08 02:47:13 -04:00
return GCS_MAVLINK : : _handle_command_preflight_calibration ( packet , msg ) ;
2021-03-18 00:12:54 -03:00
}
MAV_RESULT GCS_MAVLINK_Blimp : : handle_command_do_set_roi ( const Location & roi_loc )
{
if ( ! roi_loc . check_latlng ( ) ) {
return MAV_RESULT_FAILED ;
}
// blimp.flightmode->auto_yaw.set_roi(roi_loc);
return MAV_RESULT_ACCEPTED ;
}
MAV_RESULT GCS_MAVLINK_Blimp : : handle_command_int_do_reposition ( const mavlink_command_int_t & packet )
{
const bool change_modes = ( ( int32_t ) packet . param2 & MAV_DO_REPOSITION_FLAGS_CHANGE_MODE ) = = MAV_DO_REPOSITION_FLAGS_CHANGE_MODE ;
if ( ! blimp . flightmode - > in_guided_mode ( ) & & ! change_modes ) {
return MAV_RESULT_DENIED ;
}
// sanity check location
if ( ! check_latlng ( packet . x , packet . y ) ) {
return MAV_RESULT_DENIED ;
}
Location request_location { } ;
2022-02-03 00:01:56 -04:00
if ( ! location_from_command_t ( packet , request_location ) ) {
2021-03-18 00:12:54 -03:00
return MAV_RESULT_DENIED ;
}
if ( request_location . sanitize ( blimp . current_loc ) ) {
// if the location wasn't already sane don't load it
return MAV_RESULT_DENIED ; // failed as the location is not valid
}
return MAV_RESULT_ACCEPTED ;
}
2023-08-17 04:53:03 -03:00
MAV_RESULT GCS_MAVLINK_Blimp : : handle_command_int_packet ( const mavlink_command_int_t & packet , const mavlink_message_t & msg )
2021-03-18 00:12:54 -03:00
{
switch ( packet . command ) {
case MAV_CMD_DO_REPOSITION :
return handle_command_int_do_reposition ( packet ) ;
2023-10-18 03:30:32 -03:00
case MAV_CMD_NAV_TAKEOFF :
return MAV_RESULT_ACCEPTED ;
2021-03-18 00:12:54 -03:00
default :
2023-08-17 04:53:03 -03:00
return GCS_MAVLINK : : handle_command_int_packet ( packet , msg ) ;
2021-03-18 00:12:54 -03:00
}
}
2023-11-08 06:31:04 -04:00
# if AP_MAVLINK_COMMAND_LONG_ENABLED
2023-10-18 03:30:32 -03:00
bool GCS_MAVLINK_Blimp : : mav_frame_for_command_long ( MAV_FRAME & frame , MAV_CMD packet_command ) const
2021-03-18 00:12:54 -03:00
{
2023-10-18 03:30:32 -03:00
if ( packet_command = = MAV_CMD_NAV_TAKEOFF ) {
frame = MAV_FRAME_GLOBAL_RELATIVE_ALT ;
return true ;
2021-03-18 00:12:54 -03:00
}
2023-10-18 03:30:32 -03:00
return GCS_MAVLINK : : mav_frame_for_command_long ( frame , packet_command ) ;
2021-03-18 00:12:54 -03:00
}
2023-11-08 06:31:04 -04:00
# endif
2021-03-18 00:12:54 -03:00
2024-01-23 02:41:49 -04:00
void GCS_MAVLINK_Blimp : : handle_message ( const mavlink_message_t & msg )
2021-03-18 00:12:54 -03:00
{
switch ( msg . msgid ) {
case MAVLINK_MSG_ID_TERRAIN_DATA :
case MAVLINK_MSG_ID_TERRAIN_CHECK :
break ;
default :
2024-01-23 02:41:49 -04:00
GCS_MAVLINK : : handle_message ( msg ) ;
2021-03-18 00:12:54 -03:00
break ;
} // end switch
} // end handle mavlink
2023-09-26 03:25:02 -03:00
MAV_RESULT GCS_MAVLINK_Blimp : : handle_flight_termination ( const mavlink_command_int_t & packet )
2021-03-18 00:12:54 -03:00
{
MAV_RESULT result = MAV_RESULT_FAILED ;
if ( packet . param1 > 0.5f ) {
blimp . arming . disarm ( AP_Arming : : Method : : TERMINATION ) ;
result = MAV_RESULT_ACCEPTED ;
}
return result ;
}
float GCS_MAVLINK_Blimp : : vfr_hud_alt ( ) const
{
if ( blimp . g2 . dev_options . get ( ) & DevOptionVFR_HUDRelativeAlt ) {
// compatibility option for older mavlink-aware devices that
// assume Blimp returns a relative altitude in VFR_HUD.alt
return blimp . current_loc . alt * 0.01f ;
}
return GCS_MAVLINK : : vfr_hud_alt ( ) ;
}
uint64_t GCS_MAVLINK_Blimp : : capabilities ( ) const
{
return ( MAV_PROTOCOL_CAPABILITY_MISSION_FLOAT |
MAV_PROTOCOL_CAPABILITY_MISSION_INT |
MAV_PROTOCOL_CAPABILITY_COMMAND_INT |
MAV_PROTOCOL_CAPABILITY_SET_POSITION_TARGET_LOCAL_NED |
MAV_PROTOCOL_CAPABILITY_SET_POSITION_TARGET_GLOBAL_INT |
MAV_PROTOCOL_CAPABILITY_FLIGHT_TERMINATION |
MAV_PROTOCOL_CAPABILITY_SET_ATTITUDE_TARGET |
GCS_MAVLINK : : capabilities ( ) ) ;
}
MAV_LANDED_STATE GCS_MAVLINK_Blimp : : landed_state ( ) const
{
if ( blimp . ap . land_complete ) {
return MAV_LANDED_STATE_ON_GROUND ;
}
if ( blimp . flightmode - > is_landing ( ) ) {
return MAV_LANDED_STATE_LANDING ;
}
// if (blimp.flightmode->is_taking_off()) {
// return MAV_LANDED_STATE_TAKEOFF;
// }
return MAV_LANDED_STATE_IN_AIR ;
}
void GCS_MAVLINK_Blimp : : send_wind ( ) const
{
Vector3f airspeed_vec_bf ;
if ( ! AP : : ahrs ( ) . airspeed_vector_true ( airspeed_vec_bf ) ) {
// if we don't have an airspeed estimate then we don't have a
// valid wind estimate on blimps
return ;
}
const Vector3f wind = AP : : ahrs ( ) . wind_estimate ( ) ;
mavlink_msg_wind_send (
chan ,
degrees ( atan2f ( - wind . y , - wind . x ) ) ,
wind . length ( ) ,
wind . z ) ;
}
2021-07-06 07:53:53 -03:00
# if HAL_HIGH_LATENCY2_ENABLED
uint8_t GCS_MAVLINK_Blimp : : high_latency_wind_speed ( ) const
{
Vector3f airspeed_vec_bf ;
if ( ! AP : : ahrs ( ) . airspeed_vector_true ( airspeed_vec_bf ) ) {
// if we don't have an airspeed estimate then we don't have a
// valid wind estimate on blimps
return 0 ;
}
// return units are m/s*5
const Vector3f wind = AP : : ahrs ( ) . wind_estimate ( ) ;
return wind . length ( ) * 5 ;
}
uint8_t GCS_MAVLINK_Blimp : : high_latency_wind_direction ( ) const
{
Vector3f airspeed_vec_bf ;
if ( ! AP : : ahrs ( ) . airspeed_vector_true ( airspeed_vec_bf ) ) {
// if we don't have an airspeed estimate then we don't have a
// valid wind estimate on blimps
return 0 ;
}
const Vector3f wind = AP : : ahrs ( ) . wind_estimate ( ) ;
// need to convert -180->180 to 0->360/2
return wrap_360 ( degrees ( atan2f ( - wind . y , - wind . x ) ) ) / 2 ;
}
2021-08-17 09:08:59 -03:00
# endif // HAL_HIGH_LATENCY2_ENABLED
2024-11-09 08:35:04 -04:00
// Send the mode with the given index (not mode number!) return the total number of modes
// Index starts at 1
uint8_t GCS_MAVLINK_Blimp : : send_available_mode ( uint8_t index ) const
{
const Mode * modes [ ] {
& blimp . mode_land ,
& blimp . mode_manual ,
& blimp . mode_velocity ,
& blimp . mode_loiter ,
& blimp . mode_rtl ,
} ;
const uint8_t mode_count = ARRAY_SIZE ( modes ) ;
// Convert to zero indexed
const uint8_t index_zero = index - 1 ;
if ( index_zero > = mode_count ) {
// Mode does not exist!?
return mode_count ;
}
// Ask the mode for its name and number
const char * name = modes [ index_zero ] - > name ( ) ;
const uint8_t mode_number = ( uint8_t ) modes [ index_zero ] - > number ( ) ;
mavlink_msg_available_modes_send (
chan ,
mode_count ,
index ,
MAV_STANDARD_MODE : : MAV_STANDARD_MODE_NON_STANDARD ,
mode_number ,
0 , // MAV_MODE_PROPERTY bitmask
name
) ;
return mode_count ;
}