mavlink_msg_camera_tracking_geo_status.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513
  1. #pragma once
  2. // MESSAGE CAMERA_TRACKING_GEO_STATUS PACKING
  3. #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS 276
  4. typedef struct __mavlink_camera_tracking_geo_status_t {
  5. int32_t lat; /*< [degE7] Latitude of tracked object*/
  6. int32_t lon; /*< [degE7] Longitude of tracked object*/
  7. float alt; /*< [m] Altitude of tracked object(AMSL, WGS84)*/
  8. float h_acc; /*< [m] Horizontal accuracy. NAN if unknown*/
  9. float v_acc; /*< [m] Vertical accuracy. NAN if unknown*/
  10. float vel_n; /*< [m/s] North velocity of tracked object. NAN if unknown*/
  11. float vel_e; /*< [m/s] East velocity of tracked object. NAN if unknown*/
  12. float vel_d; /*< [m/s] Down velocity of tracked object. NAN if unknown*/
  13. float vel_acc; /*< [m/s] Velocity accuracy. NAN if unknown*/
  14. float dist; /*< [m] Distance between camera and tracked object. NAN if unknown*/
  15. float hdg; /*< [rad] Heading in radians, in NED. NAN if unknown*/
  16. float hdg_acc; /*< [rad] Accuracy of heading, in NED. NAN if unknown*/
  17. uint8_t tracking_status; /*< Current tracking status*/
  18. } mavlink_camera_tracking_geo_status_t;
  19. #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN 49
  20. #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN 49
  21. #define MAVLINK_MSG_ID_276_LEN 49
  22. #define MAVLINK_MSG_ID_276_MIN_LEN 49
  23. #define MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_CRC 18
  24. #define MAVLINK_MSG_ID_276_CRC 18
  25. #if MAVLINK_COMMAND_24BIT
  26. #define MAVLINK_MESSAGE_INFO_CAMERA_TRACKING_GEO_STATUS { \
  27. 276, \
  28. "CAMERA_TRACKING_GEO_STATUS", \
  29. 13, \
  30. { { "tracking_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 48, offsetof(mavlink_camera_tracking_geo_status_t, tracking_status) }, \
  31. { "lat", NULL, MAVLINK_TYPE_INT32_T, 0, 0, offsetof(mavlink_camera_tracking_geo_status_t, lat) }, \
  32. { "lon", NULL, MAVLINK_TYPE_INT32_T, 0, 4, offsetof(mavlink_camera_tracking_geo_status_t, lon) }, \
  33. { "alt", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_camera_tracking_geo_status_t, alt) }, \
  34. { "h_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_camera_tracking_geo_status_t, h_acc) }, \
  35. { "v_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_camera_tracking_geo_status_t, v_acc) }, \
  36. { "vel_n", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_camera_tracking_geo_status_t, vel_n) }, \
  37. { "vel_e", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_camera_tracking_geo_status_t, vel_e) }, \
  38. { "vel_d", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_camera_tracking_geo_status_t, vel_d) }, \
  39. { "vel_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_camera_tracking_geo_status_t, vel_acc) }, \
  40. { "dist", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_camera_tracking_geo_status_t, dist) }, \
  41. { "hdg", NULL, MAVLINK_TYPE_FLOAT, 0, 40, offsetof(mavlink_camera_tracking_geo_status_t, hdg) }, \
  42. { "hdg_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 44, offsetof(mavlink_camera_tracking_geo_status_t, hdg_acc) }, \
  43. } \
  44. }
  45. #else
  46. #define MAVLINK_MESSAGE_INFO_CAMERA_TRACKING_GEO_STATUS { \
  47. "CAMERA_TRACKING_GEO_STATUS", \
  48. 13, \
  49. { { "tracking_status", NULL, MAVLINK_TYPE_UINT8_T, 0, 48, offsetof(mavlink_camera_tracking_geo_status_t, tracking_status) }, \
  50. { "lat", NULL, MAVLINK_TYPE_INT32_T, 0, 0, offsetof(mavlink_camera_tracking_geo_status_t, lat) }, \
  51. { "lon", NULL, MAVLINK_TYPE_INT32_T, 0, 4, offsetof(mavlink_camera_tracking_geo_status_t, lon) }, \
  52. { "alt", NULL, MAVLINK_TYPE_FLOAT, 0, 8, offsetof(mavlink_camera_tracking_geo_status_t, alt) }, \
  53. { "h_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 12, offsetof(mavlink_camera_tracking_geo_status_t, h_acc) }, \
  54. { "v_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 16, offsetof(mavlink_camera_tracking_geo_status_t, v_acc) }, \
  55. { "vel_n", NULL, MAVLINK_TYPE_FLOAT, 0, 20, offsetof(mavlink_camera_tracking_geo_status_t, vel_n) }, \
  56. { "vel_e", NULL, MAVLINK_TYPE_FLOAT, 0, 24, offsetof(mavlink_camera_tracking_geo_status_t, vel_e) }, \
  57. { "vel_d", NULL, MAVLINK_TYPE_FLOAT, 0, 28, offsetof(mavlink_camera_tracking_geo_status_t, vel_d) }, \
  58. { "vel_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 32, offsetof(mavlink_camera_tracking_geo_status_t, vel_acc) }, \
  59. { "dist", NULL, MAVLINK_TYPE_FLOAT, 0, 36, offsetof(mavlink_camera_tracking_geo_status_t, dist) }, \
  60. { "hdg", NULL, MAVLINK_TYPE_FLOAT, 0, 40, offsetof(mavlink_camera_tracking_geo_status_t, hdg) }, \
  61. { "hdg_acc", NULL, MAVLINK_TYPE_FLOAT, 0, 44, offsetof(mavlink_camera_tracking_geo_status_t, hdg_acc) }, \
  62. } \
  63. }
  64. #endif
  65. /**
  66. * @brief Pack a camera_tracking_geo_status message
  67. * @param system_id ID of this system
  68. * @param component_id ID of this component (e.g. 200 for IMU)
  69. * @param msg The MAVLink message to compress the data into
  70. *
  71. * @param tracking_status Current tracking status
  72. * @param lat [degE7] Latitude of tracked object
  73. * @param lon [degE7] Longitude of tracked object
  74. * @param alt [m] Altitude of tracked object(AMSL, WGS84)
  75. * @param h_acc [m] Horizontal accuracy. NAN if unknown
  76. * @param v_acc [m] Vertical accuracy. NAN if unknown
  77. * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
  78. * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
  79. * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
  80. * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
  81. * @param dist [m] Distance between camera and tracked object. NAN if unknown
  82. * @param hdg [rad] Heading in radians, in NED. NAN if unknown
  83. * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
  84. * @return length of the message in bytes (excluding serial stream start sign)
  85. */
  86. static inline uint16_t mavlink_msg_camera_tracking_geo_status_pack(uint8_t system_id, uint8_t component_id, mavlink_message_t* msg,
  87. 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)
  88. {
  89. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  90. char buf[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN];
  91. _mav_put_int32_t(buf, 0, lat);
  92. _mav_put_int32_t(buf, 4, lon);
  93. _mav_put_float(buf, 8, alt);
  94. _mav_put_float(buf, 12, h_acc);
  95. _mav_put_float(buf, 16, v_acc);
  96. _mav_put_float(buf, 20, vel_n);
  97. _mav_put_float(buf, 24, vel_e);
  98. _mav_put_float(buf, 28, vel_d);
  99. _mav_put_float(buf, 32, vel_acc);
  100. _mav_put_float(buf, 36, dist);
  101. _mav_put_float(buf, 40, hdg);
  102. _mav_put_float(buf, 44, hdg_acc);
  103. _mav_put_uint8_t(buf, 48, tracking_status);
  104. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  105. #else
  106. mavlink_camera_tracking_geo_status_t packet;
  107. packet.lat = lat;
  108. packet.lon = lon;
  109. packet.alt = alt;
  110. packet.h_acc = h_acc;
  111. packet.v_acc = v_acc;
  112. packet.vel_n = vel_n;
  113. packet.vel_e = vel_e;
  114. packet.vel_d = vel_d;
  115. packet.vel_acc = vel_acc;
  116. packet.dist = dist;
  117. packet.hdg = hdg;
  118. packet.hdg_acc = hdg_acc;
  119. packet.tracking_status = tracking_status;
  120. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  121. #endif
  122. msg->msgid = MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS;
  123. 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);
  124. }
  125. /**
  126. * @brief Pack a camera_tracking_geo_status message on a channel
  127. * @param system_id ID of this system
  128. * @param component_id ID of this component (e.g. 200 for IMU)
  129. * @param chan The MAVLink channel this message will be sent over
  130. * @param msg The MAVLink message to compress the data into
  131. * @param tracking_status Current tracking status
  132. * @param lat [degE7] Latitude of tracked object
  133. * @param lon [degE7] Longitude of tracked object
  134. * @param alt [m] Altitude of tracked object(AMSL, WGS84)
  135. * @param h_acc [m] Horizontal accuracy. NAN if unknown
  136. * @param v_acc [m] Vertical accuracy. NAN if unknown
  137. * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
  138. * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
  139. * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
  140. * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
  141. * @param dist [m] Distance between camera and tracked object. NAN if unknown
  142. * @param hdg [rad] Heading in radians, in NED. NAN if unknown
  143. * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
  144. * @return length of the message in bytes (excluding serial stream start sign)
  145. */
  146. static inline uint16_t mavlink_msg_camera_tracking_geo_status_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
  147. mavlink_message_t* msg,
  148. 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)
  149. {
  150. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  151. char buf[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN];
  152. _mav_put_int32_t(buf, 0, lat);
  153. _mav_put_int32_t(buf, 4, lon);
  154. _mav_put_float(buf, 8, alt);
  155. _mav_put_float(buf, 12, h_acc);
  156. _mav_put_float(buf, 16, v_acc);
  157. _mav_put_float(buf, 20, vel_n);
  158. _mav_put_float(buf, 24, vel_e);
  159. _mav_put_float(buf, 28, vel_d);
  160. _mav_put_float(buf, 32, vel_acc);
  161. _mav_put_float(buf, 36, dist);
  162. _mav_put_float(buf, 40, hdg);
  163. _mav_put_float(buf, 44, hdg_acc);
  164. _mav_put_uint8_t(buf, 48, tracking_status);
  165. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  166. #else
  167. mavlink_camera_tracking_geo_status_t packet;
  168. packet.lat = lat;
  169. packet.lon = lon;
  170. packet.alt = alt;
  171. packet.h_acc = h_acc;
  172. packet.v_acc = v_acc;
  173. packet.vel_n = vel_n;
  174. packet.vel_e = vel_e;
  175. packet.vel_d = vel_d;
  176. packet.vel_acc = vel_acc;
  177. packet.dist = dist;
  178. packet.hdg = hdg;
  179. packet.hdg_acc = hdg_acc;
  180. packet.tracking_status = tracking_status;
  181. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  182. #endif
  183. msg->msgid = MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS;
  184. 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);
  185. }
  186. /**
  187. * @brief Encode a camera_tracking_geo_status struct
  188. *
  189. * @param system_id ID of this system
  190. * @param component_id ID of this component (e.g. 200 for IMU)
  191. * @param msg The MAVLink message to compress the data into
  192. * @param camera_tracking_geo_status C-struct to read the message contents from
  193. */
  194. 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)
  195. {
  196. 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);
  197. }
  198. /**
  199. * @brief Encode a camera_tracking_geo_status struct on a channel
  200. *
  201. * @param system_id ID of this system
  202. * @param component_id ID of this component (e.g. 200 for IMU)
  203. * @param chan The MAVLink channel this message will be sent over
  204. * @param msg The MAVLink message to compress the data into
  205. * @param camera_tracking_geo_status C-struct to read the message contents from
  206. */
  207. 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)
  208. {
  209. 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);
  210. }
  211. /**
  212. * @brief Send a camera_tracking_geo_status message
  213. * @param chan MAVLink channel to send the message
  214. *
  215. * @param tracking_status Current tracking status
  216. * @param lat [degE7] Latitude of tracked object
  217. * @param lon [degE7] Longitude of tracked object
  218. * @param alt [m] Altitude of tracked object(AMSL, WGS84)
  219. * @param h_acc [m] Horizontal accuracy. NAN if unknown
  220. * @param v_acc [m] Vertical accuracy. NAN if unknown
  221. * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
  222. * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
  223. * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
  224. * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
  225. * @param dist [m] Distance between camera and tracked object. NAN if unknown
  226. * @param hdg [rad] Heading in radians, in NED. NAN if unknown
  227. * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
  228. */
  229. #ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
  230. 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)
  231. {
  232. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  233. char buf[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN];
  234. _mav_put_int32_t(buf, 0, lat);
  235. _mav_put_int32_t(buf, 4, lon);
  236. _mav_put_float(buf, 8, alt);
  237. _mav_put_float(buf, 12, h_acc);
  238. _mav_put_float(buf, 16, v_acc);
  239. _mav_put_float(buf, 20, vel_n);
  240. _mav_put_float(buf, 24, vel_e);
  241. _mav_put_float(buf, 28, vel_d);
  242. _mav_put_float(buf, 32, vel_acc);
  243. _mav_put_float(buf, 36, dist);
  244. _mav_put_float(buf, 40, hdg);
  245. _mav_put_float(buf, 44, hdg_acc);
  246. _mav_put_uint8_t(buf, 48, tracking_status);
  247. _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);
  248. #else
  249. mavlink_camera_tracking_geo_status_t packet;
  250. packet.lat = lat;
  251. packet.lon = lon;
  252. packet.alt = alt;
  253. packet.h_acc = h_acc;
  254. packet.v_acc = v_acc;
  255. packet.vel_n = vel_n;
  256. packet.vel_e = vel_e;
  257. packet.vel_d = vel_d;
  258. packet.vel_acc = vel_acc;
  259. packet.dist = dist;
  260. packet.hdg = hdg;
  261. packet.hdg_acc = hdg_acc;
  262. packet.tracking_status = tracking_status;
  263. _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);
  264. #endif
  265. }
  266. /**
  267. * @brief Send a camera_tracking_geo_status message
  268. * @param chan MAVLink channel to send the message
  269. * @param struct The MAVLink struct to serialize
  270. */
  271. 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)
  272. {
  273. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  274. 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);
  275. #else
  276. _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);
  277. #endif
  278. }
  279. #if MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN <= MAVLINK_MAX_PAYLOAD_LEN
  280. /*
  281. This variant of _send() can be used to save stack space by re-using
  282. memory from the receive buffer. The caller provides a
  283. mavlink_message_t which is the size of a full mavlink message. This
  284. is usually the receive buffer for the channel, and allows a reply to an
  285. incoming message with minimum stack space usage.
  286. */
  287. 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)
  288. {
  289. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  290. char *buf = (char *)msgbuf;
  291. _mav_put_int32_t(buf, 0, lat);
  292. _mav_put_int32_t(buf, 4, lon);
  293. _mav_put_float(buf, 8, alt);
  294. _mav_put_float(buf, 12, h_acc);
  295. _mav_put_float(buf, 16, v_acc);
  296. _mav_put_float(buf, 20, vel_n);
  297. _mav_put_float(buf, 24, vel_e);
  298. _mav_put_float(buf, 28, vel_d);
  299. _mav_put_float(buf, 32, vel_acc);
  300. _mav_put_float(buf, 36, dist);
  301. _mav_put_float(buf, 40, hdg);
  302. _mav_put_float(buf, 44, hdg_acc);
  303. _mav_put_uint8_t(buf, 48, tracking_status);
  304. _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);
  305. #else
  306. mavlink_camera_tracking_geo_status_t *packet = (mavlink_camera_tracking_geo_status_t *)msgbuf;
  307. packet->lat = lat;
  308. packet->lon = lon;
  309. packet->alt = alt;
  310. packet->h_acc = h_acc;
  311. packet->v_acc = v_acc;
  312. packet->vel_n = vel_n;
  313. packet->vel_e = vel_e;
  314. packet->vel_d = vel_d;
  315. packet->vel_acc = vel_acc;
  316. packet->dist = dist;
  317. packet->hdg = hdg;
  318. packet->hdg_acc = hdg_acc;
  319. packet->tracking_status = tracking_status;
  320. _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);
  321. #endif
  322. }
  323. #endif
  324. #endif
  325. // MESSAGE CAMERA_TRACKING_GEO_STATUS UNPACKING
  326. /**
  327. * @brief Get field tracking_status from camera_tracking_geo_status message
  328. *
  329. * @return Current tracking status
  330. */
  331. static inline uint8_t mavlink_msg_camera_tracking_geo_status_get_tracking_status(const mavlink_message_t* msg)
  332. {
  333. return _MAV_RETURN_uint8_t(msg, 48);
  334. }
  335. /**
  336. * @brief Get field lat from camera_tracking_geo_status message
  337. *
  338. * @return [degE7] Latitude of tracked object
  339. */
  340. static inline int32_t mavlink_msg_camera_tracking_geo_status_get_lat(const mavlink_message_t* msg)
  341. {
  342. return _MAV_RETURN_int32_t(msg, 0);
  343. }
  344. /**
  345. * @brief Get field lon from camera_tracking_geo_status message
  346. *
  347. * @return [degE7] Longitude of tracked object
  348. */
  349. static inline int32_t mavlink_msg_camera_tracking_geo_status_get_lon(const mavlink_message_t* msg)
  350. {
  351. return _MAV_RETURN_int32_t(msg, 4);
  352. }
  353. /**
  354. * @brief Get field alt from camera_tracking_geo_status message
  355. *
  356. * @return [m] Altitude of tracked object(AMSL, WGS84)
  357. */
  358. static inline float mavlink_msg_camera_tracking_geo_status_get_alt(const mavlink_message_t* msg)
  359. {
  360. return _MAV_RETURN_float(msg, 8);
  361. }
  362. /**
  363. * @brief Get field h_acc from camera_tracking_geo_status message
  364. *
  365. * @return [m] Horizontal accuracy. NAN if unknown
  366. */
  367. static inline float mavlink_msg_camera_tracking_geo_status_get_h_acc(const mavlink_message_t* msg)
  368. {
  369. return _MAV_RETURN_float(msg, 12);
  370. }
  371. /**
  372. * @brief Get field v_acc from camera_tracking_geo_status message
  373. *
  374. * @return [m] Vertical accuracy. NAN if unknown
  375. */
  376. static inline float mavlink_msg_camera_tracking_geo_status_get_v_acc(const mavlink_message_t* msg)
  377. {
  378. return _MAV_RETURN_float(msg, 16);
  379. }
  380. /**
  381. * @brief Get field vel_n from camera_tracking_geo_status message
  382. *
  383. * @return [m/s] North velocity of tracked object. NAN if unknown
  384. */
  385. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_n(const mavlink_message_t* msg)
  386. {
  387. return _MAV_RETURN_float(msg, 20);
  388. }
  389. /**
  390. * @brief Get field vel_e from camera_tracking_geo_status message
  391. *
  392. * @return [m/s] East velocity of tracked object. NAN if unknown
  393. */
  394. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_e(const mavlink_message_t* msg)
  395. {
  396. return _MAV_RETURN_float(msg, 24);
  397. }
  398. /**
  399. * @brief Get field vel_d from camera_tracking_geo_status message
  400. *
  401. * @return [m/s] Down velocity of tracked object. NAN if unknown
  402. */
  403. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_d(const mavlink_message_t* msg)
  404. {
  405. return _MAV_RETURN_float(msg, 28);
  406. }
  407. /**
  408. * @brief Get field vel_acc from camera_tracking_geo_status message
  409. *
  410. * @return [m/s] Velocity accuracy. NAN if unknown
  411. */
  412. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_acc(const mavlink_message_t* msg)
  413. {
  414. return _MAV_RETURN_float(msg, 32);
  415. }
  416. /**
  417. * @brief Get field dist from camera_tracking_geo_status message
  418. *
  419. * @return [m] Distance between camera and tracked object. NAN if unknown
  420. */
  421. static inline float mavlink_msg_camera_tracking_geo_status_get_dist(const mavlink_message_t* msg)
  422. {
  423. return _MAV_RETURN_float(msg, 36);
  424. }
  425. /**
  426. * @brief Get field hdg from camera_tracking_geo_status message
  427. *
  428. * @return [rad] Heading in radians, in NED. NAN if unknown
  429. */
  430. static inline float mavlink_msg_camera_tracking_geo_status_get_hdg(const mavlink_message_t* msg)
  431. {
  432. return _MAV_RETURN_float(msg, 40);
  433. }
  434. /**
  435. * @brief Get field hdg_acc from camera_tracking_geo_status message
  436. *
  437. * @return [rad] Accuracy of heading, in NED. NAN if unknown
  438. */
  439. static inline float mavlink_msg_camera_tracking_geo_status_get_hdg_acc(const mavlink_message_t* msg)
  440. {
  441. return _MAV_RETURN_float(msg, 44);
  442. }
  443. /**
  444. * @brief Decode a camera_tracking_geo_status message into a struct
  445. *
  446. * @param msg The message to decode
  447. * @param camera_tracking_geo_status C-struct to decode the message contents into
  448. */
  449. 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)
  450. {
  451. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  452. camera_tracking_geo_status->lat = mavlink_msg_camera_tracking_geo_status_get_lat(msg);
  453. camera_tracking_geo_status->lon = mavlink_msg_camera_tracking_geo_status_get_lon(msg);
  454. camera_tracking_geo_status->alt = mavlink_msg_camera_tracking_geo_status_get_alt(msg);
  455. camera_tracking_geo_status->h_acc = mavlink_msg_camera_tracking_geo_status_get_h_acc(msg);
  456. camera_tracking_geo_status->v_acc = mavlink_msg_camera_tracking_geo_status_get_v_acc(msg);
  457. camera_tracking_geo_status->vel_n = mavlink_msg_camera_tracking_geo_status_get_vel_n(msg);
  458. camera_tracking_geo_status->vel_e = mavlink_msg_camera_tracking_geo_status_get_vel_e(msg);
  459. camera_tracking_geo_status->vel_d = mavlink_msg_camera_tracking_geo_status_get_vel_d(msg);
  460. camera_tracking_geo_status->vel_acc = mavlink_msg_camera_tracking_geo_status_get_vel_acc(msg);
  461. camera_tracking_geo_status->dist = mavlink_msg_camera_tracking_geo_status_get_dist(msg);
  462. camera_tracking_geo_status->hdg = mavlink_msg_camera_tracking_geo_status_get_hdg(msg);
  463. camera_tracking_geo_status->hdg_acc = mavlink_msg_camera_tracking_geo_status_get_hdg_acc(msg);
  464. camera_tracking_geo_status->tracking_status = mavlink_msg_camera_tracking_geo_status_get_tracking_status(msg);
  465. #else
  466. uint8_t len = msg->len < MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN? msg->len : MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN;
  467. memset(camera_tracking_geo_status, 0, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  468. memcpy(camera_tracking_geo_status, _MAV_PAYLOAD(msg), len);
  469. #endif
  470. }