2016-11-07 10:04:22 +00:00
# pragma once
// MESSAGE CAMERA_CAPTURE_STATUS PACKING
# define MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS 262
MAVPACKED (
typedef struct __mavlink_camera_capture_status_t {
uint32_t time_boot_ms ; /*< Timestamp (milliseconds since system boot)*/
float image_interval ; /*< Image capture interval in seconds*/
2017-02-27 15:57:39 +00:00
uint32_t recording_time_ms ; /*< Time in milliseconds since recording started*/
float available_capacity ; /*< Available storage capacity in MiB*/
2017-07-13 06:39:06 +00:00
uint8_t image_status ; /*< Current status of image capturing (0: idle, 1: capture in progress, 2: interval set but idle, 3: interval set and capture in progress)*/
uint8_t video_status ; /*< Current status of video capturing (0: idle, 1: capture in progress)*/
2016-11-07 10:04:22 +00:00
} ) mavlink_camera_capture_status_t ;
2017-07-21 16:53:13 +00:00
# define MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN 18
# define MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN 18
# define MAVLINK_MSG_ID_262_LEN 18
# define MAVLINK_MSG_ID_262_MIN_LEN 18
2016-11-07 10:04:22 +00:00
2017-07-21 16:53:13 +00:00
# define MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC 12
# define MAVLINK_MSG_ID_262_CRC 12
2016-11-07 10:04:22 +00:00
# if MAVLINK_COMMAND_24BIT
# define MAVLINK_MESSAGE_INFO_CAMERA_CAPTURE_STATUS { \
262, \
"CAMERA_CAPTURE_STATUS", \
2017-07-21 16:53:13 +00:00
6, \
2016-11-07 10:04:22 +00:00
{ { "time_boot_ms", NULL, MAVLINK_TYPE_UINT32_T, 0, 0, offsetof(mavlink_camera_capture_status_t, time_boot_ms) }, \
{ "image_interval", NULL, MAVLINK_TYPE_FLOAT, 0, 4, offsetof(mavlink_camera_capture_status_t, image_interval) }, \
2017-06-26 13:51:38 +00:00
{ "recording_time_ms", NULL, MAVLINK_TYPE_UINT32_T, 0, 8, offsetof(mavlink_camera_capture_status_t, recording_time_ms) }, \
{ "available_capacity", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_camera_capture_status_t, available_capacity) }, \
2017-07-21 16:53:13 +00:00
{ "image_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 16, offsetof(mavlink_camera_capture_status_t, image_status) }, \
{ "video_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 17, offsetof(mavlink_camera_capture_status_t, video_status) }, \
2016-11-07 10:04:22 +00:00
} \
}
# else
# define MAVLINK_MESSAGE_INFO_CAMERA_CAPTURE_STATUS { \
"CAMERA_CAPTURE_STATUS", \
2017-07-21 16:53:13 +00:00
6, \
2016-11-07 10:04:22 +00:00
{ { "time_boot_ms", NULL, MAVLINK_TYPE_UINT32_T, 0, 0, offsetof(mavlink_camera_capture_status_t, time_boot_ms) }, \
{ "image_interval", NULL, MAVLINK_TYPE_FLOAT, 0, 4, offsetof(mavlink_camera_capture_status_t, image_interval) }, \
2017-06-26 13:51:38 +00:00
{ "recording_time_ms", NULL, MAVLINK_TYPE_UINT32_T, 0, 8, offsetof(mavlink_camera_capture_status_t, recording_time_ms) }, \
{ "available_capacity", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_camera_capture_status_t, available_capacity) }, \
2017-07-21 16:53:13 +00:00
{ "image_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 16, offsetof(mavlink_camera_capture_status_t, image_status) }, \
{ "video_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 17, offsetof(mavlink_camera_capture_status_t, video_status) }, \
2016-11-07 10:04:22 +00:00
} \
}
# endif
/**
* @brief Pack a camera_capture_status 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_boot_ms Timestamp (milliseconds since system boot)
2017-07-13 06:39:06 +00:00
* @param image_status Current status of image capturing (0: idle, 1: capture in progress, 2: interval set but idle, 3: interval set and capture in progress)
* @param video_status Current status of video capturing (0: idle, 1: capture in progress)
2016-11-07 10:04:22 +00:00
* @param image_interval Image capture interval in seconds
2017-02-27 15:57:39 +00:00
* @param recording_time_ms Time in milliseconds since recording started
* @param available_capacity Available storage capacity in MiB
2016-11-07 10:04:22 +00:00
* @return length of the message in bytes (excluding serial stream start sign)
*/
static inline uint16_t mavlink_msg_camera_capture_status_pack ( uint8_t system_id , uint8_t component_id , mavlink_message_t * msg ,
2017-07-21 16:53:13 +00:00
uint32_t time_boot_ms , uint8_t image_status , uint8_t video_status , float image_interval , uint32_t recording_time_ms , float available_capacity )
2016-11-07 10:04:22 +00:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
char buf [ MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ] ;
_mav_put_uint32_t ( buf , 0 , time_boot_ms ) ;
_mav_put_float ( buf , 4 , image_interval ) ;
2017-06-26 13:51:38 +00:00
_mav_put_uint32_t ( buf , 8 , recording_time_ms ) ;
_mav_put_float ( buf , 12 , available_capacity ) ;
2017-07-21 16:53:13 +00:00
_mav_put_uint8_t ( buf , 16 , image_status ) ;
_mav_put_uint8_t ( buf , 17 , video_status ) ;
2016-11-07 10:04:22 +00:00
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , buf , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ) ;
# else
mavlink_camera_capture_status_t packet ;
packet . time_boot_ms = time_boot_ms ;
packet . image_interval = image_interval ;
2017-02-27 15:57:39 +00:00
packet . recording_time_ms = recording_time_ms ;
packet . available_capacity = available_capacity ;
2016-11-07 10:04:22 +00:00
packet . image_status = image_status ;
packet . video_status = video_status ;
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , & packet , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ) ;
# endif
msg - > msgid = MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS ;
return mavlink_finalize_message ( msg , system_id , component_id , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC ) ;
}
/**
* @brief Pack a camera_capture_status 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_boot_ms Timestamp (milliseconds since system boot)
2017-07-13 06:39:06 +00:00
* @param image_status Current status of image capturing (0: idle, 1: capture in progress, 2: interval set but idle, 3: interval set and capture in progress)
* @param video_status Current status of video capturing (0: idle, 1: capture in progress)
2016-11-07 10:04:22 +00:00
* @param image_interval Image capture interval in seconds
2017-02-27 15:57:39 +00:00
* @param recording_time_ms Time in milliseconds since recording started
* @param available_capacity Available storage capacity in MiB
2016-11-07 10:04:22 +00:00
* @return length of the message in bytes (excluding serial stream start sign)
*/
static inline uint16_t mavlink_msg_camera_capture_status_pack_chan ( uint8_t system_id , uint8_t component_id , uint8_t chan ,
mavlink_message_t * msg ,
2017-07-21 16:53:13 +00:00
uint32_t time_boot_ms , uint8_t image_status , uint8_t video_status , float image_interval , uint32_t recording_time_ms , float available_capacity )
2016-11-07 10:04:22 +00:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
char buf [ MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ] ;
_mav_put_uint32_t ( buf , 0 , time_boot_ms ) ;
_mav_put_float ( buf , 4 , image_interval ) ;
2017-06-26 13:51:38 +00:00
_mav_put_uint32_t ( buf , 8 , recording_time_ms ) ;
_mav_put_float ( buf , 12 , available_capacity ) ;
2017-07-21 16:53:13 +00:00
_mav_put_uint8_t ( buf , 16 , image_status ) ;
_mav_put_uint8_t ( buf , 17 , video_status ) ;
2016-11-07 10:04:22 +00:00
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , buf , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ) ;
# else
mavlink_camera_capture_status_t packet ;
packet . time_boot_ms = time_boot_ms ;
packet . image_interval = image_interval ;
2017-02-27 15:57:39 +00:00
packet . recording_time_ms = recording_time_ms ;
packet . available_capacity = available_capacity ;
2016-11-07 10:04:22 +00:00
packet . image_status = image_status ;
packet . video_status = video_status ;
memcpy ( _MAV_PAYLOAD_NON_CONST ( msg ) , & packet , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ) ;
# endif
msg - > msgid = MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS ;
return mavlink_finalize_message_chan ( msg , system_id , component_id , chan , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC ) ;
}
/**
* @brief Encode a camera_capture_status 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 camera_capture_status C-struct to read the message contents from
*/
static inline uint16_t mavlink_msg_camera_capture_status_encode ( uint8_t system_id , uint8_t component_id , mavlink_message_t * msg , const mavlink_camera_capture_status_t * camera_capture_status )
{
2017-07-21 16:53:13 +00:00
return mavlink_msg_camera_capture_status_pack ( system_id , component_id , msg , camera_capture_status - > time_boot_ms , camera_capture_status - > image_status , camera_capture_status - > video_status , camera_capture_status - > image_interval , camera_capture_status - > recording_time_ms , camera_capture_status - > available_capacity ) ;
2016-11-07 10:04:22 +00:00
}
/**
* @brief Encode a camera_capture_status 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 camera_capture_status C-struct to read the message contents from
*/
static inline uint16_t mavlink_msg_camera_capture_status_encode_chan ( uint8_t system_id , uint8_t component_id , uint8_t chan , mavlink_message_t * msg , const mavlink_camera_capture_status_t * camera_capture_status )
{
2017-07-21 16:53:13 +00:00
return mavlink_msg_camera_capture_status_pack_chan ( system_id , component_id , chan , msg , camera_capture_status - > time_boot_ms , camera_capture_status - > image_status , camera_capture_status - > video_status , camera_capture_status - > image_interval , camera_capture_status - > recording_time_ms , camera_capture_status - > available_capacity ) ;
2016-11-07 10:04:22 +00:00
}
/**
* @brief Send a camera_capture_status message
* @param chan MAVLink channel to send the message
*
* @param time_boot_ms Timestamp (milliseconds since system boot)
2017-07-13 06:39:06 +00:00
* @param image_status Current status of image capturing (0: idle, 1: capture in progress, 2: interval set but idle, 3: interval set and capture in progress)
* @param video_status Current status of video capturing (0: idle, 1: capture in progress)
2016-11-07 10:04:22 +00:00
* @param image_interval Image capture interval in seconds
2017-02-27 15:57:39 +00:00
* @param recording_time_ms Time in milliseconds since recording started
* @param available_capacity Available storage capacity in MiB
2016-11-07 10:04:22 +00:00
*/
# ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
2017-07-21 16:53:13 +00:00
static inline void mavlink_msg_camera_capture_status_send ( mavlink_channel_t chan , uint32_t time_boot_ms , uint8_t image_status , uint8_t video_status , float image_interval , uint32_t recording_time_ms , float available_capacity )
2016-11-07 10:04:22 +00:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
char buf [ MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ] ;
_mav_put_uint32_t ( buf , 0 , time_boot_ms ) ;
_mav_put_float ( buf , 4 , image_interval ) ;
2017-06-26 13:51:38 +00:00
_mav_put_uint32_t ( buf , 8 , recording_time_ms ) ;
_mav_put_float ( buf , 12 , available_capacity ) ;
2017-07-21 16:53:13 +00:00
_mav_put_uint8_t ( buf , 16 , image_status ) ;
_mav_put_uint8_t ( buf , 17 , video_status ) ;
2016-11-07 10:04:22 +00:00
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS , buf , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC ) ;
# else
mavlink_camera_capture_status_t packet ;
packet . time_boot_ms = time_boot_ms ;
packet . image_interval = image_interval ;
2017-02-27 15:57:39 +00:00
packet . recording_time_ms = recording_time_ms ;
packet . available_capacity = available_capacity ;
2016-11-07 10:04:22 +00:00
packet . image_status = image_status ;
packet . video_status = video_status ;
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS , ( const char * ) & packet , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC ) ;
# endif
}
/**
* @brief Send a camera_capture_status message
* @param chan MAVLink channel to send the message
* @param struct The MAVLink struct to serialize
*/
static inline void mavlink_msg_camera_capture_status_send_struct ( mavlink_channel_t chan , const mavlink_camera_capture_status_t * camera_capture_status )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
2017-07-21 16:53:13 +00:00
mavlink_msg_camera_capture_status_send ( chan , camera_capture_status - > time_boot_ms , camera_capture_status - > image_status , camera_capture_status - > video_status , camera_capture_status - > image_interval , camera_capture_status - > recording_time_ms , camera_capture_status - > available_capacity ) ;
2016-11-07 10:04:22 +00:00
# else
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS , ( const char * ) camera_capture_status , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC ) ;
# endif
}
# if MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_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.
*/
2017-07-21 16:53:13 +00:00
static inline void mavlink_msg_camera_capture_status_send_buf ( mavlink_message_t * msgbuf , mavlink_channel_t chan , uint32_t time_boot_ms , uint8_t image_status , uint8_t video_status , float image_interval , uint32_t recording_time_ms , float available_capacity )
2016-11-07 10:04:22 +00:00
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
char * buf = ( char * ) msgbuf ;
_mav_put_uint32_t ( buf , 0 , time_boot_ms ) ;
_mav_put_float ( buf , 4 , image_interval ) ;
2017-06-26 13:51:38 +00:00
_mav_put_uint32_t ( buf , 8 , recording_time_ms ) ;
_mav_put_float ( buf , 12 , available_capacity ) ;
2017-07-21 16:53:13 +00:00
_mav_put_uint8_t ( buf , 16 , image_status ) ;
_mav_put_uint8_t ( buf , 17 , video_status ) ;
2016-11-07 10:04:22 +00:00
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS , buf , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC ) ;
# else
mavlink_camera_capture_status_t * packet = ( mavlink_camera_capture_status_t * ) msgbuf ;
packet - > time_boot_ms = time_boot_ms ;
packet - > image_interval = image_interval ;
2017-02-27 15:57:39 +00:00
packet - > recording_time_ms = recording_time_ms ;
packet - > available_capacity = available_capacity ;
2016-11-07 10:04:22 +00:00
packet - > image_status = image_status ;
packet - > video_status = video_status ;
_mav_finalize_message_chan_send ( chan , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS , ( const char * ) packet , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_MIN_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_CRC ) ;
# endif
}
# endif
# endif
// MESSAGE CAMERA_CAPTURE_STATUS UNPACKING
/**
* @brief Get field time_boot_ms from camera_capture_status message
*
* @return Timestamp (milliseconds since system boot)
*/
static inline uint32_t mavlink_msg_camera_capture_status_get_time_boot_ms ( const mavlink_message_t * msg )
{
return _MAV_RETURN_uint32_t ( msg , 0 ) ;
}
/**
* @brief Get field image_status from camera_capture_status message
*
2017-07-13 06:39:06 +00:00
* @return Current status of image capturing (0: idle, 1: capture in progress, 2: interval set but idle, 3: interval set and capture in progress)
2016-11-07 10:04:22 +00:00
*/
static inline uint8_t mavlink_msg_camera_capture_status_get_image_status ( const mavlink_message_t * msg )
{
2017-07-21 16:53:13 +00:00
return _MAV_RETURN_uint8_t ( msg , 16 ) ;
2016-11-07 10:04:22 +00:00
}
/**
* @brief Get field video_status from camera_capture_status message
*
2017-07-13 06:39:06 +00:00
* @return Current status of video capturing (0: idle, 1: capture in progress)
2016-11-07 10:04:22 +00:00
*/
static inline uint8_t mavlink_msg_camera_capture_status_get_video_status ( const mavlink_message_t * msg )
{
2017-07-21 16:53:13 +00:00
return _MAV_RETURN_uint8_t ( msg , 17 ) ;
2016-11-07 10:04:22 +00:00
}
/**
* @brief Get field image_interval from camera_capture_status message
*
* @return Image capture interval in seconds
*/
static inline float mavlink_msg_camera_capture_status_get_image_interval ( const mavlink_message_t * msg )
{
return _MAV_RETURN_float ( msg , 4 ) ;
}
2017-02-27 15:57:39 +00:00
/**
* @brief Get field recording_time_ms from camera_capture_status message
*
* @return Time in milliseconds since recording started
*/
static inline uint32_t mavlink_msg_camera_capture_status_get_recording_time_ms ( const mavlink_message_t * msg )
{
2017-06-26 13:51:38 +00:00
return _MAV_RETURN_uint32_t ( msg , 8 ) ;
2017-02-27 15:57:39 +00:00
}
/**
* @brief Get field available_capacity from camera_capture_status message
*
* @return Available storage capacity in MiB
*/
static inline float mavlink_msg_camera_capture_status_get_available_capacity ( const mavlink_message_t * msg )
{
2017-06-26 13:51:38 +00:00
return _MAV_RETURN_float ( msg , 12 ) ;
2016-11-07 10:04:22 +00:00
}
/**
* @brief Decode a camera_capture_status message into a struct
*
* @param msg The message to decode
* @param camera_capture_status C-struct to decode the message contents into
*/
static inline void mavlink_msg_camera_capture_status_decode ( const mavlink_message_t * msg , mavlink_camera_capture_status_t * camera_capture_status )
{
# if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
camera_capture_status - > time_boot_ms = mavlink_msg_camera_capture_status_get_time_boot_ms ( msg ) ;
camera_capture_status - > image_interval = mavlink_msg_camera_capture_status_get_image_interval ( msg ) ;
2017-02-27 15:57:39 +00:00
camera_capture_status - > recording_time_ms = mavlink_msg_camera_capture_status_get_recording_time_ms ( msg ) ;
camera_capture_status - > available_capacity = mavlink_msg_camera_capture_status_get_available_capacity ( msg ) ;
2016-11-07 10:04:22 +00:00
camera_capture_status - > image_status = mavlink_msg_camera_capture_status_get_image_status ( msg ) ;
camera_capture_status - > video_status = mavlink_msg_camera_capture_status_get_video_status ( msg ) ;
# else
uint8_t len = msg - > len < MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ? msg - > len : MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ;
memset ( camera_capture_status , 0 , MAVLINK_MSG_ID_CAMERA_CAPTURE_STATUS_LEN ) ;
memcpy ( camera_capture_status , _MAV_PAYLOAD ( msg ) , len ) ;
# endif
}