2 // MESSAGE CAMERA_TRACKING_GEO_STATUS PACKING
4 #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS 276
7 typedef struct __mavlink_camera_tracking_geo_status_t
{
8 int32_t lat
; /*< [degE7] Latitude of tracked object*/
9 int32_t lon
; /*< [degE7] Longitude of tracked object*/
10 float alt
; /*< [m] Altitude of tracked object(AMSL, WGS84)*/
11 float h_acc
; /*< [m] Horizontal accuracy. NAN if unknown*/
12 float v_acc
; /*< [m] Vertical accuracy. NAN if unknown*/
13 float vel_n
; /*< [m/s] North velocity of tracked object. NAN if unknown*/
14 float vel_e
; /*< [m/s] East velocity of tracked object. NAN if unknown*/
15 float vel_d
; /*< [m/s] Down velocity of tracked object. NAN if unknown*/
16 float vel_acc
; /*< [m/s] Velocity accuracy. NAN if unknown*/
17 float dist
; /*< [m] Distance between camera and tracked object. NAN if unknown*/
18 float hdg
; /*< [rad] Heading in radians, in NED. NAN if unknown*/
19 float hdg_acc
; /*< [rad] Accuracy of heading, in NED. NAN if unknown*/
20 uint8_t tracking_status
; /*< Current tracking status*/
21 } mavlink_camera_tracking_geo_status_t
;
23 #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN 49
24 #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN 49
25 #define MAVLINK_MSG_ID_276_LEN 49
26 #define MAVLINK_MSG_ID_276_MIN_LEN 49
28 #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC 18
29 #define MAVLINK_MSG_ID_276_CRC 18
33 #if MAVLINK_COMMAND_24BIT
34 #define MAVLINK_MESSAGE_INFO_CAMERA_TRACKING_GEO_STATUS { \
36 "CAMERA_TRACKING_GEO_STATUS", \
38 { { "tracking_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 48, offsetof(mavlink_camera_tracking_geo_status_t, tracking_status) }, \
39 { "lat", NULL, MAVLINK_TYPE_INT32_T, 0, 0, offsetof(mavlink_camera_tracking_geo_status_t, lat) }, \
40 { "lon", NULL, MAVLINK_TYPE_INT32_T, 0, 4, offsetof(mavlink_camera_tracking_geo_status_t, lon) }, \
41 { "alt", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_camera_tracking_geo_status_t, alt) }, \
42 { "h_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_camera_tracking_geo_status_t, h_acc) }, \
43 { "v_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_camera_tracking_geo_status_t, v_acc) }, \
44 { "vel_n", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_camera_tracking_geo_status_t, vel_n) }, \
45 { "vel_e", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_camera_tracking_geo_status_t, vel_e) }, \
46 { "vel_d", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_camera_tracking_geo_status_t, vel_d) }, \
47 { "vel_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_camera_tracking_geo_status_t, vel_acc) }, \
48 { "dist", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_camera_tracking_geo_status_t, dist) }, \
49 { "hdg", NULL, MAVLINK_TYPE_FLOAT, 0, 40, offsetof(mavlink_camera_tracking_geo_status_t, hdg) }, \
50 { "hdg_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 44, offsetof(mavlink_camera_tracking_geo_status_t, hdg_acc) }, \
54 #define MAVLINK_MESSAGE_INFO_CAMERA_TRACKING_GEO_STATUS { \
55 "CAMERA_TRACKING_GEO_STATUS", \
57 { { "tracking_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 48, offsetof(mavlink_camera_tracking_geo_status_t, tracking_status) }, \
58 { "lat", NULL, MAVLINK_TYPE_INT32_T, 0, 0, offsetof(mavlink_camera_tracking_geo_status_t, lat) }, \
59 { "lon", NULL, MAVLINK_TYPE_INT32_T, 0, 4, offsetof(mavlink_camera_tracking_geo_status_t, lon) }, \
60 { "alt", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_camera_tracking_geo_status_t, alt) }, \
61 { "h_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_camera_tracking_geo_status_t, h_acc) }, \
62 { "v_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_camera_tracking_geo_status_t, v_acc) }, \
63 { "vel_n", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_camera_tracking_geo_status_t, vel_n) }, \
64 { "vel_e", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_camera_tracking_geo_status_t, vel_e) }, \
65 { "vel_d", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_camera_tracking_geo_status_t, vel_d) }, \
66 { "vel_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_camera_tracking_geo_status_t, vel_acc) }, \
67 { "dist", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_camera_tracking_geo_status_t, dist) }, \
68 { "hdg", NULL, MAVLINK_TYPE_FLOAT, 0, 40, offsetof(mavlink_camera_tracking_geo_status_t, hdg) }, \
69 { "hdg_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 44, offsetof(mavlink_camera_tracking_geo_status_t, hdg_acc) }, \
75 * @brief Pack a camera_tracking_geo_status message
76 * @param system_id ID of this system
77 * @param component_id ID of this component (e.g. 200 for IMU)
78 * @param msg The MAVLink message to compress the data into
80 * @param tracking_status Current tracking status
81 * @param lat [degE7] Latitude of tracked object
82 * @param lon [degE7] Longitude of tracked object
83 * @param alt [m] Altitude of tracked object(AMSL, WGS84)
84 * @param h_acc [m] Horizontal accuracy. NAN if unknown
85 * @param v_acc [m] Vertical accuracy. NAN if unknown
86 * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
87 * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
88 * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
89 * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
90 * @param dist [m] Distance between camera and tracked object. NAN if unknown
91 * @param hdg [rad] Heading in radians, in NED. NAN if unknown
92 * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
93 * @return length of the message in bytes (excluding serial stream start sign)
95 static inline uint16_t mavlink_msg_camera_tracking_geo_status_pack(uint8_t system_id
, uint8_t component_id
, mavlink_message_t
* msg
,
96 uint8_t tracking_status
, int32_t lat
, int32_t lon
, float alt
, float h_acc
, float v_acc
, float vel_n
, float vel_e
, float vel_d
, float vel_acc
, float dist
, float hdg
, float hdg_acc
)
98 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
99 char buf
[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
];
100 _mav_put_int32_t(buf
, 0, lat
);
101 _mav_put_int32_t(buf
, 4, lon
);
102 _mav_put_float(buf
, 8, alt
);
103 _mav_put_float(buf
, 12, h_acc
);
104 _mav_put_float(buf
, 16, v_acc
);
105 _mav_put_float(buf
, 20, vel_n
);
106 _mav_put_float(buf
, 24, vel_e
);
107 _mav_put_float(buf
, 28, vel_d
);
108 _mav_put_float(buf
, 32, vel_acc
);
109 _mav_put_float(buf
, 36, dist
);
110 _mav_put_float(buf
, 40, hdg
);
111 _mav_put_float(buf
, 44, hdg_acc
);
112 _mav_put_uint8_t(buf
, 48, tracking_status
);
114 memcpy(_MAV_PAYLOAD_NON_CONST(msg
), buf
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
);
116 mavlink_camera_tracking_geo_status_t packet
;
120 packet
.h_acc
= h_acc
;
121 packet
.v_acc
= v_acc
;
122 packet
.vel_n
= vel_n
;
123 packet
.vel_e
= vel_e
;
124 packet
.vel_d
= vel_d
;
125 packet
.vel_acc
= vel_acc
;
128 packet
.hdg_acc
= hdg_acc
;
129 packet
.tracking_status
= tracking_status
;
131 memcpy(_MAV_PAYLOAD_NON_CONST(msg
), &packet
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
);
134 msg
->msgid
= MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS
;
135 return mavlink_finalize_message(msg
, system_id
, component_id
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC
);
139 * @brief Pack a camera_tracking_geo_status message on a channel
140 * @param system_id ID of this system
141 * @param component_id ID of this component (e.g. 200 for IMU)
142 * @param chan The MAVLink channel this message will be sent over
143 * @param msg The MAVLink message to compress the data into
144 * @param tracking_status Current tracking status
145 * @param lat [degE7] Latitude of tracked object
146 * @param lon [degE7] Longitude of tracked object
147 * @param alt [m] Altitude of tracked object(AMSL, WGS84)
148 * @param h_acc [m] Horizontal accuracy. NAN if unknown
149 * @param v_acc [m] Vertical accuracy. NAN if unknown
150 * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
151 * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
152 * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
153 * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
154 * @param dist [m] Distance between camera and tracked object. NAN if unknown
155 * @param hdg [rad] Heading in radians, in NED. NAN if unknown
156 * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
157 * @return length of the message in bytes (excluding serial stream start sign)
159 static inline uint16_t mavlink_msg_camera_tracking_geo_status_pack_chan(uint8_t system_id
, uint8_t component_id
, uint8_t chan
,
160 mavlink_message_t
* msg
,
161 uint8_t tracking_status
,int32_t lat
,int32_t lon
,float alt
,float h_acc
,float v_acc
,float vel_n
,float vel_e
,float vel_d
,float vel_acc
,float dist
,float hdg
,float hdg_acc
)
163 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
164 char buf
[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
];
165 _mav_put_int32_t(buf
, 0, lat
);
166 _mav_put_int32_t(buf
, 4, lon
);
167 _mav_put_float(buf
, 8, alt
);
168 _mav_put_float(buf
, 12, h_acc
);
169 _mav_put_float(buf
, 16, v_acc
);
170 _mav_put_float(buf
, 20, vel_n
);
171 _mav_put_float(buf
, 24, vel_e
);
172 _mav_put_float(buf
, 28, vel_d
);
173 _mav_put_float(buf
, 32, vel_acc
);
174 _mav_put_float(buf
, 36, dist
);
175 _mav_put_float(buf
, 40, hdg
);
176 _mav_put_float(buf
, 44, hdg_acc
);
177 _mav_put_uint8_t(buf
, 48, tracking_status
);
179 memcpy(_MAV_PAYLOAD_NON_CONST(msg
), buf
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
);
181 mavlink_camera_tracking_geo_status_t packet
;
185 packet
.h_acc
= h_acc
;
186 packet
.v_acc
= v_acc
;
187 packet
.vel_n
= vel_n
;
188 packet
.vel_e
= vel_e
;
189 packet
.vel_d
= vel_d
;
190 packet
.vel_acc
= vel_acc
;
193 packet
.hdg_acc
= hdg_acc
;
194 packet
.tracking_status
= tracking_status
;
196 memcpy(_MAV_PAYLOAD_NON_CONST(msg
), &packet
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
);
199 msg
->msgid
= MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS
;
200 return mavlink_finalize_message_chan(msg
, system_id
, component_id
, chan
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC
);
204 * @brief Encode a camera_tracking_geo_status struct
206 * @param system_id ID of this system
207 * @param component_id ID of this component (e.g. 200 for IMU)
208 * @param msg The MAVLink message to compress the data into
209 * @param camera_tracking_geo_status C-struct to read the message contents from
211 static inline uint16_t mavlink_msg_camera_tracking_geo_status_encode(uint8_t system_id
, uint8_t component_id
, mavlink_message_t
* msg
, const mavlink_camera_tracking_geo_status_t
* camera_tracking_geo_status
)
213 return mavlink_msg_camera_tracking_geo_status_pack(system_id
, component_id
, msg
, camera_tracking_geo_status
->tracking_status
, camera_tracking_geo_status
->lat
, camera_tracking_geo_status
->lon
, camera_tracking_geo_status
->alt
, camera_tracking_geo_status
->h_acc
, camera_tracking_geo_status
->v_acc
, camera_tracking_geo_status
->vel_n
, camera_tracking_geo_status
->vel_e
, camera_tracking_geo_status
->vel_d
, camera_tracking_geo_status
->vel_acc
, camera_tracking_geo_status
->dist
, camera_tracking_geo_status
->hdg
, camera_tracking_geo_status
->hdg_acc
);
217 * @brief Encode a camera_tracking_geo_status struct on a channel
219 * @param system_id ID of this system
220 * @param component_id ID of this component (e.g. 200 for IMU)
221 * @param chan The MAVLink channel this message will be sent over
222 * @param msg The MAVLink message to compress the data into
223 * @param camera_tracking_geo_status C-struct to read the message contents from
225 static inline uint16_t mavlink_msg_camera_tracking_geo_status_encode_chan(uint8_t system_id
, uint8_t component_id
, uint8_t chan
, mavlink_message_t
* msg
, const mavlink_camera_tracking_geo_status_t
* camera_tracking_geo_status
)
227 return mavlink_msg_camera_tracking_geo_status_pack_chan(system_id
, component_id
, chan
, msg
, camera_tracking_geo_status
->tracking_status
, camera_tracking_geo_status
->lat
, camera_tracking_geo_status
->lon
, camera_tracking_geo_status
->alt
, camera_tracking_geo_status
->h_acc
, camera_tracking_geo_status
->v_acc
, camera_tracking_geo_status
->vel_n
, camera_tracking_geo_status
->vel_e
, camera_tracking_geo_status
->vel_d
, camera_tracking_geo_status
->vel_acc
, camera_tracking_geo_status
->dist
, camera_tracking_geo_status
->hdg
, camera_tracking_geo_status
->hdg_acc
);
231 * @brief Send a camera_tracking_geo_status message
232 * @param chan MAVLink channel to send the message
234 * @param tracking_status Current tracking status
235 * @param lat [degE7] Latitude of tracked object
236 * @param lon [degE7] Longitude of tracked object
237 * @param alt [m] Altitude of tracked object(AMSL, WGS84)
238 * @param h_acc [m] Horizontal accuracy. NAN if unknown
239 * @param v_acc [m] Vertical accuracy. NAN if unknown
240 * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
241 * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
242 * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
243 * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
244 * @param dist [m] Distance between camera and tracked object. NAN if unknown
245 * @param hdg [rad] Heading in radians, in NED. NAN if unknown
246 * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
248 #ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
250 static inline void mavlink_msg_camera_tracking_geo_status_send(mavlink_channel_t chan
, uint8_t tracking_status
, int32_t lat
, int32_t lon
, float alt
, float h_acc
, float v_acc
, float vel_n
, float vel_e
, float vel_d
, float vel_acc
, float dist
, float hdg
, float hdg_acc
)
252 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
253 char buf
[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
];
254 _mav_put_int32_t(buf
, 0, lat
);
255 _mav_put_int32_t(buf
, 4, lon
);
256 _mav_put_float(buf
, 8, alt
);
257 _mav_put_float(buf
, 12, h_acc
);
258 _mav_put_float(buf
, 16, v_acc
);
259 _mav_put_float(buf
, 20, vel_n
);
260 _mav_put_float(buf
, 24, vel_e
);
261 _mav_put_float(buf
, 28, vel_d
);
262 _mav_put_float(buf
, 32, vel_acc
);
263 _mav_put_float(buf
, 36, dist
);
264 _mav_put_float(buf
, 40, hdg
);
265 _mav_put_float(buf
, 44, hdg_acc
);
266 _mav_put_uint8_t(buf
, 48, tracking_status
);
268 _mav_finalize_message_chan_send(chan
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS
, buf
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC
);
270 mavlink_camera_tracking_geo_status_t packet
;
274 packet
.h_acc
= h_acc
;
275 packet
.v_acc
= v_acc
;
276 packet
.vel_n
= vel_n
;
277 packet
.vel_e
= vel_e
;
278 packet
.vel_d
= vel_d
;
279 packet
.vel_acc
= vel_acc
;
282 packet
.hdg_acc
= hdg_acc
;
283 packet
.tracking_status
= tracking_status
;
285 _mav_finalize_message_chan_send(chan
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS
, (const char *)&packet
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC
);
290 * @brief Send a camera_tracking_geo_status message
291 * @param chan MAVLink channel to send the message
292 * @param struct The MAVLink struct to serialize
294 static inline void mavlink_msg_camera_tracking_geo_status_send_struct(mavlink_channel_t chan
, const mavlink_camera_tracking_geo_status_t
* camera_tracking_geo_status
)
296 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
297 mavlink_msg_camera_tracking_geo_status_send(chan
, camera_tracking_geo_status
->tracking_status
, camera_tracking_geo_status
->lat
, camera_tracking_geo_status
->lon
, camera_tracking_geo_status
->alt
, camera_tracking_geo_status
->h_acc
, camera_tracking_geo_status
->v_acc
, camera_tracking_geo_status
->vel_n
, camera_tracking_geo_status
->vel_e
, camera_tracking_geo_status
->vel_d
, camera_tracking_geo_status
->vel_acc
, camera_tracking_geo_status
->dist
, camera_tracking_geo_status
->hdg
, camera_tracking_geo_status
->hdg_acc
);
299 _mav_finalize_message_chan_send(chan
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS
, (const char *)camera_tracking_geo_status
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC
);
303 #if MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN <= MAVLINK_MAX_PAYLOAD_LEN
305 This varient of _send() can be used to save stack space by re-using
306 memory from the receive buffer. The caller provides a
307 mavlink_message_t which is the size of a full mavlink message. This
308 is usually the receive buffer for the channel, and allows a reply to an
309 incoming message with minimum stack space usage.
311 static inline void mavlink_msg_camera_tracking_geo_status_send_buf(mavlink_message_t
*msgbuf
, mavlink_channel_t chan
, uint8_t tracking_status
, int32_t lat
, int32_t lon
, float alt
, float h_acc
, float v_acc
, float vel_n
, float vel_e
, float vel_d
, float vel_acc
, float dist
, float hdg
, float hdg_acc
)
313 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
314 char *buf
= (char *)msgbuf
;
315 _mav_put_int32_t(buf
, 0, lat
);
316 _mav_put_int32_t(buf
, 4, lon
);
317 _mav_put_float(buf
, 8, alt
);
318 _mav_put_float(buf
, 12, h_acc
);
319 _mav_put_float(buf
, 16, v_acc
);
320 _mav_put_float(buf
, 20, vel_n
);
321 _mav_put_float(buf
, 24, vel_e
);
322 _mav_put_float(buf
, 28, vel_d
);
323 _mav_put_float(buf
, 32, vel_acc
);
324 _mav_put_float(buf
, 36, dist
);
325 _mav_put_float(buf
, 40, hdg
);
326 _mav_put_float(buf
, 44, hdg_acc
);
327 _mav_put_uint8_t(buf
, 48, tracking_status
);
329 _mav_finalize_message_chan_send(chan
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS
, buf
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC
);
331 mavlink_camera_tracking_geo_status_t
*packet
= (mavlink_camera_tracking_geo_status_t
*)msgbuf
;
335 packet
->h_acc
= h_acc
;
336 packet
->v_acc
= v_acc
;
337 packet
->vel_n
= vel_n
;
338 packet
->vel_e
= vel_e
;
339 packet
->vel_d
= vel_d
;
340 packet
->vel_acc
= vel_acc
;
343 packet
->hdg_acc
= hdg_acc
;
344 packet
->tracking_status
= tracking_status
;
346 _mav_finalize_message_chan_send(chan
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS
, (const char *)packet
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC
);
353 // MESSAGE CAMERA_TRACKING_GEO_STATUS UNPACKING
357 * @brief Get field tracking_status from camera_tracking_geo_status message
359 * @return Current tracking status
361 static inline uint8_t mavlink_msg_camera_tracking_geo_status_get_tracking_status(const mavlink_message_t
* msg
)
363 return _MAV_RETURN_uint8_t(msg
, 48);
367 * @brief Get field lat from camera_tracking_geo_status message
369 * @return [degE7] Latitude of tracked object
371 static inline int32_t mavlink_msg_camera_tracking_geo_status_get_lat(const mavlink_message_t
* msg
)
373 return _MAV_RETURN_int32_t(msg
, 0);
377 * @brief Get field lon from camera_tracking_geo_status message
379 * @return [degE7] Longitude of tracked object
381 static inline int32_t mavlink_msg_camera_tracking_geo_status_get_lon(const mavlink_message_t
* msg
)
383 return _MAV_RETURN_int32_t(msg
, 4);
387 * @brief Get field alt from camera_tracking_geo_status message
389 * @return [m] Altitude of tracked object(AMSL, WGS84)
391 static inline float mavlink_msg_camera_tracking_geo_status_get_alt(const mavlink_message_t
* msg
)
393 return _MAV_RETURN_float(msg
, 8);
397 * @brief Get field h_acc from camera_tracking_geo_status message
399 * @return [m] Horizontal accuracy. NAN if unknown
401 static inline float mavlink_msg_camera_tracking_geo_status_get_h_acc(const mavlink_message_t
* msg
)
403 return _MAV_RETURN_float(msg
, 12);
407 * @brief Get field v_acc from camera_tracking_geo_status message
409 * @return [m] Vertical accuracy. NAN if unknown
411 static inline float mavlink_msg_camera_tracking_geo_status_get_v_acc(const mavlink_message_t
* msg
)
413 return _MAV_RETURN_float(msg
, 16);
417 * @brief Get field vel_n from camera_tracking_geo_status message
419 * @return [m/s] North velocity of tracked object. NAN if unknown
421 static inline float mavlink_msg_camera_tracking_geo_status_get_vel_n(const mavlink_message_t
* msg
)
423 return _MAV_RETURN_float(msg
, 20);
427 * @brief Get field vel_e from camera_tracking_geo_status message
429 * @return [m/s] East velocity of tracked object. NAN if unknown
431 static inline float mavlink_msg_camera_tracking_geo_status_get_vel_e(const mavlink_message_t
* msg
)
433 return _MAV_RETURN_float(msg
, 24);
437 * @brief Get field vel_d from camera_tracking_geo_status message
439 * @return [m/s] Down velocity of tracked object. NAN if unknown
441 static inline float mavlink_msg_camera_tracking_geo_status_get_vel_d(const mavlink_message_t
* msg
)
443 return _MAV_RETURN_float(msg
, 28);
447 * @brief Get field vel_acc from camera_tracking_geo_status message
449 * @return [m/s] Velocity accuracy. NAN if unknown
451 static inline float mavlink_msg_camera_tracking_geo_status_get_vel_acc(const mavlink_message_t
* msg
)
453 return _MAV_RETURN_float(msg
, 32);
457 * @brief Get field dist from camera_tracking_geo_status message
459 * @return [m] Distance between camera and tracked object. NAN if unknown
461 static inline float mavlink_msg_camera_tracking_geo_status_get_dist(const mavlink_message_t
* msg
)
463 return _MAV_RETURN_float(msg
, 36);
467 * @brief Get field hdg from camera_tracking_geo_status message
469 * @return [rad] Heading in radians, in NED. NAN if unknown
471 static inline float mavlink_msg_camera_tracking_geo_status_get_hdg(const mavlink_message_t
* msg
)
473 return _MAV_RETURN_float(msg
, 40);
477 * @brief Get field hdg_acc from camera_tracking_geo_status message
479 * @return [rad] Accuracy of heading, in NED. NAN if unknown
481 static inline float mavlink_msg_camera_tracking_geo_status_get_hdg_acc(const mavlink_message_t
* msg
)
483 return _MAV_RETURN_float(msg
, 44);
487 * @brief Decode a camera_tracking_geo_status message into a struct
489 * @param msg The message to decode
490 * @param camera_tracking_geo_status C-struct to decode the message contents into
492 static inline void mavlink_msg_camera_tracking_geo_status_decode(const mavlink_message_t
* msg
, mavlink_camera_tracking_geo_status_t
* camera_tracking_geo_status
)
494 #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
495 camera_tracking_geo_status
->lat
= mavlink_msg_camera_tracking_geo_status_get_lat(msg
);
496 camera_tracking_geo_status
->lon
= mavlink_msg_camera_tracking_geo_status_get_lon(msg
);
497 camera_tracking_geo_status
->alt
= mavlink_msg_camera_tracking_geo_status_get_alt(msg
);
498 camera_tracking_geo_status
->h_acc
= mavlink_msg_camera_tracking_geo_status_get_h_acc(msg
);
499 camera_tracking_geo_status
->v_acc
= mavlink_msg_camera_tracking_geo_status_get_v_acc(msg
);
500 camera_tracking_geo_status
->vel_n
= mavlink_msg_camera_tracking_geo_status_get_vel_n(msg
);
501 camera_tracking_geo_status
->vel_e
= mavlink_msg_camera_tracking_geo_status_get_vel_e(msg
);
502 camera_tracking_geo_status
->vel_d
= mavlink_msg_camera_tracking_geo_status_get_vel_d(msg
);
503 camera_tracking_geo_status
->vel_acc
= mavlink_msg_camera_tracking_geo_status_get_vel_acc(msg
);
504 camera_tracking_geo_status
->dist
= mavlink_msg_camera_tracking_geo_status_get_dist(msg
);
505 camera_tracking_geo_status
->hdg
= mavlink_msg_camera_tracking_geo_status_get_hdg(msg
);
506 camera_tracking_geo_status
->hdg_acc
= mavlink_msg_camera_tracking_geo_status_get_hdg_acc(msg
);
507 camera_tracking_geo_status
->tracking_status
= mavlink_msg_camera_tracking_geo_status_get_tracking_status(msg
);
509 uint8_t len
= msg
->len
< MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
? msg
->len
: MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
;
510 memset(camera_tracking_geo_status
, 0, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN
);
511 memcpy(camera_tracking_geo_status
, _MAV_PAYLOAD(msg
), len
);