2016-10-05 22:52:07 +00:00
# pragma once
2015-02-10 22:23:12 +00:00
// MESSAGE ACTUATOR_CONTROL_TARGET PACKING
# define MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET 140
2016-08-02 12:16:40 +00:00
MAVPACKED (
typedef struct __mavlink_actuator_control_target_t {
2015-08-14 21:55:31 +00:00
uint64_t time_usec ; /*< Timestamp (micros since boot or Unix epoch)*/
float controls [ 8 ] ; /*< Actuator controls. Normed to -1..+1 where 0 is neutral position. Throttle for single rotation direction motors is 0..1, negative range for reverse direction. Standard mapping for attitude controls (group 0): (index 0-7): roll, pitch, yaw, throttle, flaps, spoilers, airbrakes, landing gear. Load a pass-through mixer to repurpose them as generic outputs.*/
uint8_t group_mlx ; /*< Actuator group. The "_mlx" indicates this is a multi-instance message and a MAVLink parser should use this field to difference between instances.*/
2016-08-02 12:16:40 +00:00
} ) mavlink_actuator_control_target_t ;
2015-02-10 22:23:12 +00:00
# define MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN 41
2016-05-16 08:33:08 +00:00
# define MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN 41
2015-02-10 22:23:12 +00:00
# define MAVLINK_MSG_ID_140_LEN 41
2016-05-16 08:33:08 +00:00
# define MAVLINK_MSG_ID_140_MIN_LEN 41
2015-02-10 22:23:12 +00:00
# define MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC 181
# define MAVLINK_MSG_ID_140_CRC 181
# define MAVLINK_MSG_ACTUATOR_CONTROL_TARGET_FIELD_CONTROLS_LEN 8
2016-05-16 08:33:08 +00:00
# if MAVLINK_COMMAND_24BIT
2015-02-10 22:23:12 +00:00
# define MAVLINK_MESSAGE_INFO_ACTUATOR_CONTROL_TARGET { \
2016-10-10 10:40:57 +00:00
140, \
"ACTUATOR_CONTROL_TARGET", \
3, \
{ { "time_usec", NULL, MAVLINK_TYPE_UINT64_T, 0, 0, offsetof(mavlink_actuator_control_target_t, time_usec) }, \
2015-02-10 22:23:12 +00:00
{ "controls", NULL, MAVLINK_TYPE_FLOAT, 8, 8, offsetof(mavlink_actuator_control_target_t, controls) }, \
{ "group_mlx", NULL, MAVLINK_TYPE_UINT8_T, 0, 40, offsetof(mavlink_actuator_control_target_t, group_mlx) }, \
} \
}
2016-05-16 08:33:08 +00:00
# else
# define MAVLINK_MESSAGE_INFO_ACTUATOR_CONTROL_TARGET { \
2016-10-10 10:40:57 +00:00
"ACTUATOR_CONTROL_TARGET", \
3, \
{ { "time_usec", NULL, MAVLINK_TYPE_UINT64_T, 0, 0, offsetof(mavlink_actuator_control_target_t, time_usec) }, \
2016-05-16 08:33:08 +00:00
{ "controls", NULL, MAVLINK_TYPE_FLOAT, 8, 8, offsetof(mavlink_actuator_control_target_t, controls) }, \
{ "group_mlx", NULL, MAVLINK_TYPE_UINT8_T, 0, 40, offsetof(mavlink_actuator_control_target_t, group_mlx) }, \
} \
}
# endif
2015-02-10 22:23:12 +00:00
/**
* @brief Pack a actuator_control_target message
* @param system_id ID of this system
* @param component_id ID of this component (e.g. 200 for IMU)
* @param msg The MAVLink message to compress the data into
*
* @param time_usec Timestamp (micros since boot or Unix epoch)
* @param group_mlx Actuator group. The "_mlx" indicates this is a multi-instance message and a MAVLink parser should use this field to difference between instances.
* @param controls Actuator controls. Normed to -1..+1 where 0 is neutral position. Throttle for single rotation direction motors is 0..1, negative range for reverse direction. Standard mapping for attitude controls (group 0): (index 0-7): roll, pitch, yaw, throttle, flaps, spoilers, airbrakes, landing gear. Load a pass-through mixer to repurpose them as generic outputs.
* @return length of the message in bytes (excluding serial stream start sign)
*/
static inline uint16_t mavlink_msg_actuator_control_target_pack ( uint8_t system_id , uint8_t component_id , mavlink_message_t * msg ,
2016-10-10 10:40:57 +00:00
uint64_t time_usec , uint8_t group_mlx , const float * controls )
2015-02-10 22:23:12 +00:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2016-10-10 10:40:57 +00:00
char buf [ MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ] ;
_mav_put_uint64_t ( buf , 0 , time_usec ) ;
_mav_put_uint8_t ( buf , 40 , group_mlx ) ;
_mav_put_float_array ( buf , 8 , controls , 8 ) ;
2015-02-10 22:23:12 +00:00
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , buf , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ) ;
# else
2016-10-10 10:40:57 +00:00
mavlink_actuator_control_target_t packet ;
packet . time_usec = time_usec ;
packet . group_mlx = group_mlx ;
mav_array_memcpy ( packet . controls , controls , sizeof ( float ) * 8 ) ;
2015-02-10 22:23:12 +00:00
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , & packet , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ) ;
# endif
2016-10-10 10:40:57 +00:00
msg - > msgid = MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET ;
2016-05-16 08:33:08 +00:00
return mavlink_finalize_message ( msg , system_id , component_id , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC ) ;
2015-02-10 22:23:12 +00:00
}
/**
* @brief Pack a actuator_control_target message on a channel
* @param system_id ID of this system
* @param component_id ID of this component (e.g. 200 for IMU)
* @param chan The MAVLink channel this message will be sent over
* @param msg The MAVLink message to compress the data into
* @param time_usec Timestamp (micros since boot or Unix epoch)
* @param group_mlx Actuator group. The "_mlx" indicates this is a multi-instance message and a MAVLink parser should use this field to difference between instances.
* @param controls Actuator controls. Normed to -1..+1 where 0 is neutral position. Throttle for single rotation direction motors is 0..1, negative range for reverse direction. Standard mapping for attitude controls (group 0): (index 0-7): roll, pitch, yaw, throttle, flaps, spoilers, airbrakes, landing gear. Load a pass-through mixer to repurpose them as generic outputs.
* @return length of the message in bytes (excluding serial stream start sign)
*/
static inline uint16_t mavlink_msg_actuator_control_target_pack_chan ( uint8_t system_id , uint8_t component_id , uint8_t chan ,
2016-10-10 10:40:57 +00:00
mavlink_message_t * msg ,
uint64_t time_usec , uint8_t group_mlx , const float * controls )
2015-02-10 22:23:12 +00:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2016-10-10 10:40:57 +00:00
char buf [ MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ] ;
_mav_put_uint64_t ( buf , 0 , time_usec ) ;
_mav_put_uint8_t ( buf , 40 , group_mlx ) ;
_mav_put_float_array ( buf , 8 , controls , 8 ) ;
2015-02-10 22:23:12 +00:00
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , buf , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ) ;
# else
2016-10-10 10:40:57 +00:00
mavlink_actuator_control_target_t packet ;
packet . time_usec = time_usec ;
packet . group_mlx = group_mlx ;
mav_array_memcpy ( packet . controls , controls , sizeof ( float ) * 8 ) ;
2015-02-10 22:23:12 +00:00
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , & packet , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ) ;
# endif
2016-10-10 10:40:57 +00:00
msg - > msgid = MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET ;
2016-05-16 08:33:08 +00:00
return mavlink_finalize_message_chan ( msg , system_id , component_id , chan , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC ) ;
2015-02-10 22:23:12 +00:00
}
/**
* @brief Encode a actuator_control_target struct
*
* @param system_id ID of this system
* @param component_id ID of this component (e.g. 200 for IMU)
* @param msg The MAVLink message to compress the data into
* @param actuator_control_target C-struct to read the message contents from
*/
static inline uint16_t mavlink_msg_actuator_control_target_encode ( uint8_t system_id , uint8_t component_id , mavlink_message_t * msg , const mavlink_actuator_control_target_t * actuator_control_target )
{
2016-10-10 10:40:57 +00:00
return mavlink_msg_actuator_control_target_pack ( system_id , component_id , msg , actuator_control_target - > time_usec , actuator_control_target - > group_mlx , actuator_control_target - > controls ) ;
2015-02-10 22:23:12 +00:00
}
/**
* @brief Encode a actuator_control_target struct on a channel
*
* @param system_id ID of this system
* @param component_id ID of this component (e.g. 200 for IMU)
* @param chan The MAVLink channel this message will be sent over
* @param msg The MAVLink message to compress the data into
* @param actuator_control_target C-struct to read the message contents from
*/
static inline uint16_t mavlink_msg_actuator_control_target_encode_chan ( uint8_t system_id , uint8_t component_id , uint8_t chan , mavlink_message_t * msg , const mavlink_actuator_control_target_t * actuator_control_target )
{
2016-10-10 10:40:57 +00:00
return mavlink_msg_actuator_control_target_pack_chan ( system_id , component_id , chan , msg , actuator_control_target - > time_usec , actuator_control_target - > group_mlx , actuator_control_target - > controls ) ;
2015-02-10 22:23:12 +00:00
}
/**
* @brief Send a actuator_control_target message
* @param chan MAVLink channel to send the message
*
* @param time_usec Timestamp (micros since boot or Unix epoch)
* @param group_mlx Actuator group. The "_mlx" indicates this is a multi-instance message and a MAVLink parser should use this field to difference between instances.
* @param controls Actuator controls. Normed to -1..+1 where 0 is neutral position. Throttle for single rotation direction motors is 0..1, negative range for reverse direction. Standard mapping for attitude controls (group 0): (index 0-7): roll, pitch, yaw, throttle, flaps, spoilers, airbrakes, landing gear. Load a pass-through mixer to repurpose them as generic outputs.
*/
# ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
static inline void mavlink_msg_actuator_control_target_send ( mavlink_channel_t chan , uint64_t time_usec , uint8_t group_mlx , const float * controls )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2016-10-10 10:40:57 +00:00
char buf [ MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ] ;
_mav_put_uint64_t ( buf , 0 , time_usec ) ;
_mav_put_uint8_t ( buf , 40 , group_mlx ) ;
_mav_put_float_array ( buf , 8 , controls , 8 ) ;
2016-05-16 08:33:08 +00:00
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET , buf , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC ) ;
2015-02-10 22:23:12 +00:00
# else
2016-10-10 10:40:57 +00:00
mavlink_actuator_control_target_t packet ;
packet . time_usec = time_usec ;
packet . group_mlx = group_mlx ;
mav_array_memcpy ( packet . controls , controls , sizeof ( float ) * 8 ) ;
2016-05-16 08:33:08 +00:00
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET , ( const char * ) & packet , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC ) ;
2015-02-10 22:23:12 +00:00
# endif
2016-05-16 08:33:08 +00:00
}
/**
* @brief Send a actuator_control_target message
* @param chan MAVLink channel to send the message
* @param struct The MAVLink struct to serialize
*/
static inline void mavlink_msg_actuator_control_target_send_struct ( mavlink_channel_t chan , const mavlink_actuator_control_target_t * actuator_control_target )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
mavlink_msg_actuator_control_target_send ( chan , actuator_control_target - > time_usec , actuator_control_target - > group_mlx , actuator_control_target - > controls ) ;
# else
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET , ( const char * ) actuator_control_target , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC ) ;
2015-02-10 22:23:12 +00:00
# endif
}
# if MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN <= MAVLINK_MAX_PAYLOAD_LEN
/*
This varient of _send() can be used to save stack space by re-using
memory from the receive buffer. The caller provides a
mavlink_message_t which is the size of a full mavlink message. This
is usually the receive buffer for the channel, and allows a reply to an
incoming message with minimum stack space usage.
*/
static inline void mavlink_msg_actuator_control_target_send_buf ( mavlink_message_t * msgbuf , mavlink_channel_t chan , uint64_t time_usec , uint8_t group_mlx , const float * controls )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2016-10-10 10:40:57 +00:00
char * buf = ( char * ) msgbuf ;
_mav_put_uint64_t ( buf , 0 , time_usec ) ;
_mav_put_uint8_t ( buf , 40 , group_mlx ) ;
_mav_put_float_array ( buf , 8 , controls , 8 ) ;
2016-05-16 08:33:08 +00:00
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET , buf , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC ) ;
2015-02-10 22:23:12 +00:00
# else
2016-10-10 10:40:57 +00:00
mavlink_actuator_control_target_t * packet = ( mavlink_actuator_control_target_t * ) msgbuf ;
packet - > time_usec = time_usec ;
packet - > group_mlx = group_mlx ;
mav_array_memcpy ( packet - > controls , controls , sizeof ( float ) * 8 ) ;
2016-05-16 08:33:08 +00:00
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET , ( const char * ) packet , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_MIN_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_CRC ) ;
2015-02-10 22:23:12 +00:00
# endif
}
# endif
# endif
// MESSAGE ACTUATOR_CONTROL_TARGET UNPACKING
/**
* @brief Get field time_usec from actuator_control_target message
*
* @return Timestamp (micros since boot or Unix epoch)
*/
static inline uint64_t mavlink_msg_actuator_control_target_get_time_usec ( const mavlink_message_t * msg )
{
2016-10-10 10:40:57 +00:00
return _MAV_RETURN_uint64_t ( msg , 0 ) ;
2015-02-10 22:23:12 +00:00
}
/**
* @brief Get field group_mlx from actuator_control_target message
*
* @return Actuator group. The "_mlx" indicates this is a multi-instance message and a MAVLink parser should use this field to difference between instances.
*/
static inline uint8_t mavlink_msg_actuator_control_target_get_group_mlx ( const mavlink_message_t * msg )
{
2016-10-10 10:40:57 +00:00
return _MAV_RETURN_uint8_t ( msg , 40 ) ;
2015-02-10 22:23:12 +00:00
}
/**
* @brief Get field controls from actuator_control_target message
*
* @return Actuator controls. Normed to -1..+1 where 0 is neutral position. Throttle for single rotation direction motors is 0..1, negative range for reverse direction. Standard mapping for attitude controls (group 0): (index 0-7): roll, pitch, yaw, throttle, flaps, spoilers, airbrakes, landing gear. Load a pass-through mixer to repurpose them as generic outputs.
*/
static inline uint16_t mavlink_msg_actuator_control_target_get_controls ( const mavlink_message_t * msg , float * controls )
{
2016-10-10 10:40:57 +00:00
return _MAV_RETURN_float_array ( msg , controls , 8 , 8 ) ;
2015-02-10 22:23:12 +00:00
}
/**
* @brief Decode a actuator_control_target message into a struct
*
* @param msg The message to decode
* @param actuator_control_target C-struct to decode the message contents into
*/
static inline void mavlink_msg_actuator_control_target_decode ( const mavlink_message_t * msg , mavlink_actuator_control_target_t * actuator_control_target )
{
2016-05-16 08:33:08 +00:00
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2016-10-10 10:40:57 +00:00
actuator_control_target - > time_usec = mavlink_msg_actuator_control_target_get_time_usec ( msg ) ;
mavlink_msg_actuator_control_target_get_controls ( msg , actuator_control_target - > controls ) ;
actuator_control_target - > group_mlx = mavlink_msg_actuator_control_target_get_group_mlx ( msg ) ;
2015-02-10 22:23:12 +00:00
# else
2016-05-16 08:33:08 +00:00
uint8_t len = msg - > len < MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ? msg - > len : MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ;
memset ( actuator_control_target , 0 , MAVLINK_MSG_ID_ACTUATOR_CONTROL_TARGET_LEN ) ;
2016-10-10 10:40:57 +00:00
memcpy ( actuator_control_target , _MAV_PAYLOAD ( msg ) , len ) ;
2015-02-10 22:23:12 +00:00
# endif
}