mavlink_msg_camera_tracking_geo_status.h 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596
  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
  127. * @param system_id ID of this system
  128. * @param component_id ID of this component (e.g. 200 for IMU)
  129. * @param status MAVLink status structure
  130. * @param msg The MAVLink message to compress the data into
  131. *
  132. * @param tracking_status Current tracking status
  133. * @param lat [degE7] Latitude of tracked object
  134. * @param lon [degE7] Longitude of tracked object
  135. * @param alt [m] Altitude of tracked object(AMSL, WGS84)
  136. * @param h_acc [m] Horizontal accuracy. NAN if unknown
  137. * @param v_acc [m] Vertical accuracy. NAN if unknown
  138. * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
  139. * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
  140. * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
  141. * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
  142. * @param dist [m] Distance between camera and tracked object. NAN if unknown
  143. * @param hdg [rad] Heading in radians, in NED. NAN if unknown
  144. * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
  145. * @return length of the message in bytes (excluding serial stream start sign)
  146. */
  147. static inline uint16_t mavlink_msg_camera_tracking_geo_status_pack_status(uint8_t system_id, uint8_t component_id, mavlink_status_t *_status, 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. #if MAVLINK_CRC_EXTRA
  185. return mavlink_finalize_message_buffer(msg, system_id, component_id, _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);
  186. #else
  187. return mavlink_finalize_message_buffer(msg, system_id, component_id, _status, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_MIN_LEN, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  188. #endif
  189. }
  190. /**
  191. * @brief Pack a camera_tracking_geo_status message on a channel
  192. * @param system_id ID of this system
  193. * @param component_id ID of this component (e.g. 200 for IMU)
  194. * @param chan The MAVLink channel this message will be sent over
  195. * @param msg The MAVLink message to compress the data into
  196. * @param tracking_status Current tracking status
  197. * @param lat [degE7] Latitude of tracked object
  198. * @param lon [degE7] Longitude of tracked object
  199. * @param alt [m] Altitude of tracked object(AMSL, WGS84)
  200. * @param h_acc [m] Horizontal accuracy. NAN if unknown
  201. * @param v_acc [m] Vertical accuracy. NAN if unknown
  202. * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
  203. * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
  204. * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
  205. * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
  206. * @param dist [m] Distance between camera and tracked object. NAN if unknown
  207. * @param hdg [rad] Heading in radians, in NED. NAN if unknown
  208. * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
  209. * @return length of the message in bytes (excluding serial stream start sign)
  210. */
  211. static inline uint16_t mavlink_msg_camera_tracking_geo_status_pack_chan(uint8_t system_id, uint8_t component_id, uint8_t chan,
  212. mavlink_message_t* msg,
  213. 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)
  214. {
  215. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  216. char buf[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN];
  217. _mav_put_int32_t(buf, 0, lat);
  218. _mav_put_int32_t(buf, 4, lon);
  219. _mav_put_float(buf, 8, alt);
  220. _mav_put_float(buf, 12, h_acc);
  221. _mav_put_float(buf, 16, v_acc);
  222. _mav_put_float(buf, 20, vel_n);
  223. _mav_put_float(buf, 24, vel_e);
  224. _mav_put_float(buf, 28, vel_d);
  225. _mav_put_float(buf, 32, vel_acc);
  226. _mav_put_float(buf, 36, dist);
  227. _mav_put_float(buf, 40, hdg);
  228. _mav_put_float(buf, 44, hdg_acc);
  229. _mav_put_uint8_t(buf, 48, tracking_status);
  230. memcpy(_MAV_PAYLOAD_NON_CONST(msg), buf, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  231. #else
  232. mavlink_camera_tracking_geo_status_t packet;
  233. packet.lat = lat;
  234. packet.lon = lon;
  235. packet.alt = alt;
  236. packet.h_acc = h_acc;
  237. packet.v_acc = v_acc;
  238. packet.vel_n = vel_n;
  239. packet.vel_e = vel_e;
  240. packet.vel_d = vel_d;
  241. packet.vel_acc = vel_acc;
  242. packet.dist = dist;
  243. packet.hdg = hdg;
  244. packet.hdg_acc = hdg_acc;
  245. packet.tracking_status = tracking_status;
  246. memcpy(_MAV_PAYLOAD_NON_CONST(msg), &packet, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  247. #endif
  248. msg->msgid = MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS;
  249. 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);
  250. }
  251. /**
  252. * @brief Encode a camera_tracking_geo_status struct
  253. *
  254. * @param system_id ID of this system
  255. * @param component_id ID of this component (e.g. 200 for IMU)
  256. * @param msg The MAVLink message to compress the data into
  257. * @param camera_tracking_geo_status C-struct to read the message contents from
  258. */
  259. 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)
  260. {
  261. 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);
  262. }
  263. /**
  264. * @brief Encode a camera_tracking_geo_status struct on a channel
  265. *
  266. * @param system_id ID of this system
  267. * @param component_id ID of this component (e.g. 200 for IMU)
  268. * @param chan The MAVLink channel this message will be sent over
  269. * @param msg The MAVLink message to compress the data into
  270. * @param camera_tracking_geo_status C-struct to read the message contents from
  271. */
  272. 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)
  273. {
  274. 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);
  275. }
  276. /**
  277. * @brief Encode a camera_tracking_geo_status struct with provided status structure
  278. *
  279. * @param system_id ID of this system
  280. * @param component_id ID of this component (e.g. 200 for IMU)
  281. * @param status MAVLink status structure
  282. * @param msg The MAVLink message to compress the data into
  283. * @param camera_tracking_geo_status C-struct to read the message contents from
  284. */
  285. static inline uint16_t mavlink_msg_camera_tracking_geo_status_encode_status(uint8_t system_id, uint8_t component_id, mavlink_status_t* _status, mavlink_message_t* msg, const mavlink_camera_tracking_geo_status_t* camera_tracking_geo_status)
  286. {
  287. return mavlink_msg_camera_tracking_geo_status_pack_status(system_id, component_id, _status, 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);
  288. }
  289. /**
  290. * @brief Send a camera_tracking_geo_status message
  291. * @param chan MAVLink channel to send the message
  292. *
  293. * @param tracking_status Current tracking status
  294. * @param lat [degE7] Latitude of tracked object
  295. * @param lon [degE7] Longitude of tracked object
  296. * @param alt [m] Altitude of tracked object(AMSL, WGS84)
  297. * @param h_acc [m] Horizontal accuracy. NAN if unknown
  298. * @param v_acc [m] Vertical accuracy. NAN if unknown
  299. * @param vel_n [m/s] North velocity of tracked object. NAN if unknown
  300. * @param vel_e [m/s] East velocity of tracked object. NAN if unknown
  301. * @param vel_d [m/s] Down velocity of tracked object. NAN if unknown
  302. * @param vel_acc [m/s] Velocity accuracy. NAN if unknown
  303. * @param dist [m] Distance between camera and tracked object. NAN if unknown
  304. * @param hdg [rad] Heading in radians, in NED. NAN if unknown
  305. * @param hdg_acc [rad] Accuracy of heading, in NED. NAN if unknown
  306. */
  307. #ifdef MAVLINK_USE_CONVENIENCE_FUNCTIONS
  308. 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)
  309. {
  310. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  311. char buf[MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN];
  312. _mav_put_int32_t(buf, 0, lat);
  313. _mav_put_int32_t(buf, 4, lon);
  314. _mav_put_float(buf, 8, alt);
  315. _mav_put_float(buf, 12, h_acc);
  316. _mav_put_float(buf, 16, v_acc);
  317. _mav_put_float(buf, 20, vel_n);
  318. _mav_put_float(buf, 24, vel_e);
  319. _mav_put_float(buf, 28, vel_d);
  320. _mav_put_float(buf, 32, vel_acc);
  321. _mav_put_float(buf, 36, dist);
  322. _mav_put_float(buf, 40, hdg);
  323. _mav_put_float(buf, 44, hdg_acc);
  324. _mav_put_uint8_t(buf, 48, tracking_status);
  325. _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);
  326. #else
  327. mavlink_camera_tracking_geo_status_t packet;
  328. packet.lat = lat;
  329. packet.lon = lon;
  330. packet.alt = alt;
  331. packet.h_acc = h_acc;
  332. packet.v_acc = v_acc;
  333. packet.vel_n = vel_n;
  334. packet.vel_e = vel_e;
  335. packet.vel_d = vel_d;
  336. packet.vel_acc = vel_acc;
  337. packet.dist = dist;
  338. packet.hdg = hdg;
  339. packet.hdg_acc = hdg_acc;
  340. packet.tracking_status = tracking_status;
  341. _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);
  342. #endif
  343. }
  344. /**
  345. * @brief Send a camera_tracking_geo_status message
  346. * @param chan MAVLink channel to send the message
  347. * @param struct The MAVLink struct to serialize
  348. */
  349. 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)
  350. {
  351. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  352. 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);
  353. #else
  354. _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);
  355. #endif
  356. }
  357. #if MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN <= MAVLINK_MAX_PAYLOAD_LEN
  358. /*
  359. This variant of _send() can be used to save stack space by re-using
  360. memory from the receive buffer. The caller provides a
  361. mavlink_message_t which is the size of a full mavlink message. This
  362. is usually the receive buffer for the channel, and allows a reply to an
  363. incoming message with minimum stack space usage.
  364. */
  365. 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)
  366. {
  367. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  368. char *buf = (char *)msgbuf;
  369. _mav_put_int32_t(buf, 0, lat);
  370. _mav_put_int32_t(buf, 4, lon);
  371. _mav_put_float(buf, 8, alt);
  372. _mav_put_float(buf, 12, h_acc);
  373. _mav_put_float(buf, 16, v_acc);
  374. _mav_put_float(buf, 20, vel_n);
  375. _mav_put_float(buf, 24, vel_e);
  376. _mav_put_float(buf, 28, vel_d);
  377. _mav_put_float(buf, 32, vel_acc);
  378. _mav_put_float(buf, 36, dist);
  379. _mav_put_float(buf, 40, hdg);
  380. _mav_put_float(buf, 44, hdg_acc);
  381. _mav_put_uint8_t(buf, 48, tracking_status);
  382. _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);
  383. #else
  384. mavlink_camera_tracking_geo_status_t *packet = (mavlink_camera_tracking_geo_status_t *)msgbuf;
  385. packet->lat = lat;
  386. packet->lon = lon;
  387. packet->alt = alt;
  388. packet->h_acc = h_acc;
  389. packet->v_acc = v_acc;
  390. packet->vel_n = vel_n;
  391. packet->vel_e = vel_e;
  392. packet->vel_d = vel_d;
  393. packet->vel_acc = vel_acc;
  394. packet->dist = dist;
  395. packet->hdg = hdg;
  396. packet->hdg_acc = hdg_acc;
  397. packet->tracking_status = tracking_status;
  398. _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);
  399. #endif
  400. }
  401. #endif
  402. #endif
  403. // MESSAGE CAMERA_TRACKING_GEO_STATUS UNPACKING
  404. /**
  405. * @brief Get field tracking_status from camera_tracking_geo_status message
  406. *
  407. * @return Current tracking status
  408. */
  409. static inline uint8_t mavlink_msg_camera_tracking_geo_status_get_tracking_status(const mavlink_message_t* msg)
  410. {
  411. return _MAV_RETURN_uint8_t(msg, 48);
  412. }
  413. /**
  414. * @brief Get field lat from camera_tracking_geo_status message
  415. *
  416. * @return [degE7] Latitude of tracked object
  417. */
  418. static inline int32_t mavlink_msg_camera_tracking_geo_status_get_lat(const mavlink_message_t* msg)
  419. {
  420. return _MAV_RETURN_int32_t(msg, 0);
  421. }
  422. /**
  423. * @brief Get field lon from camera_tracking_geo_status message
  424. *
  425. * @return [degE7] Longitude of tracked object
  426. */
  427. static inline int32_t mavlink_msg_camera_tracking_geo_status_get_lon(const mavlink_message_t* msg)
  428. {
  429. return _MAV_RETURN_int32_t(msg, 4);
  430. }
  431. /**
  432. * @brief Get field alt from camera_tracking_geo_status message
  433. *
  434. * @return [m] Altitude of tracked object(AMSL, WGS84)
  435. */
  436. static inline float mavlink_msg_camera_tracking_geo_status_get_alt(const mavlink_message_t* msg)
  437. {
  438. return _MAV_RETURN_float(msg, 8);
  439. }
  440. /**
  441. * @brief Get field h_acc from camera_tracking_geo_status message
  442. *
  443. * @return [m] Horizontal accuracy. NAN if unknown
  444. */
  445. static inline float mavlink_msg_camera_tracking_geo_status_get_h_acc(const mavlink_message_t* msg)
  446. {
  447. return _MAV_RETURN_float(msg, 12);
  448. }
  449. /**
  450. * @brief Get field v_acc from camera_tracking_geo_status message
  451. *
  452. * @return [m] Vertical accuracy. NAN if unknown
  453. */
  454. static inline float mavlink_msg_camera_tracking_geo_status_get_v_acc(const mavlink_message_t* msg)
  455. {
  456. return _MAV_RETURN_float(msg, 16);
  457. }
  458. /**
  459. * @brief Get field vel_n from camera_tracking_geo_status message
  460. *
  461. * @return [m/s] North velocity of tracked object. NAN if unknown
  462. */
  463. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_n(const mavlink_message_t* msg)
  464. {
  465. return _MAV_RETURN_float(msg, 20);
  466. }
  467. /**
  468. * @brief Get field vel_e from camera_tracking_geo_status message
  469. *
  470. * @return [m/s] East velocity of tracked object. NAN if unknown
  471. */
  472. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_e(const mavlink_message_t* msg)
  473. {
  474. return _MAV_RETURN_float(msg, 24);
  475. }
  476. /**
  477. * @brief Get field vel_d from camera_tracking_geo_status message
  478. *
  479. * @return [m/s] Down velocity of tracked object. NAN if unknown
  480. */
  481. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_d(const mavlink_message_t* msg)
  482. {
  483. return _MAV_RETURN_float(msg, 28);
  484. }
  485. /**
  486. * @brief Get field vel_acc from camera_tracking_geo_status message
  487. *
  488. * @return [m/s] Velocity accuracy. NAN if unknown
  489. */
  490. static inline float mavlink_msg_camera_tracking_geo_status_get_vel_acc(const mavlink_message_t* msg)
  491. {
  492. return _MAV_RETURN_float(msg, 32);
  493. }
  494. /**
  495. * @brief Get field dist from camera_tracking_geo_status message
  496. *
  497. * @return [m] Distance between camera and tracked object. NAN if unknown
  498. */
  499. static inline float mavlink_msg_camera_tracking_geo_status_get_dist(const mavlink_message_t* msg)
  500. {
  501. return _MAV_RETURN_float(msg, 36);
  502. }
  503. /**
  504. * @brief Get field hdg from camera_tracking_geo_status message
  505. *
  506. * @return [rad] Heading in radians, in NED. NAN if unknown
  507. */
  508. static inline float mavlink_msg_camera_tracking_geo_status_get_hdg(const mavlink_message_t* msg)
  509. {
  510. return _MAV_RETURN_float(msg, 40);
  511. }
  512. /**
  513. * @brief Get field hdg_acc from camera_tracking_geo_status message
  514. *
  515. * @return [rad] Accuracy of heading, in NED. NAN if unknown
  516. */
  517. static inline float mavlink_msg_camera_tracking_geo_status_get_hdg_acc(const mavlink_message_t* msg)
  518. {
  519. return _MAV_RETURN_float(msg, 44);
  520. }
  521. /**
  522. * @brief Decode a camera_tracking_geo_status message into a struct
  523. *
  524. * @param msg The message to decode
  525. * @param camera_tracking_geo_status C-struct to decode the message contents into
  526. */
  527. 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)
  528. {
  529. #if MAVLINK_NEED_BYTE_SWAP || !MAVLINK_ALIGNED_FIELDS
  530. camera_tracking_geo_status->lat = mavlink_msg_camera_tracking_geo_status_get_lat(msg);
  531. camera_tracking_geo_status->lon = mavlink_msg_camera_tracking_geo_status_get_lon(msg);
  532. camera_tracking_geo_status->alt = mavlink_msg_camera_tracking_geo_status_get_alt(msg);
  533. camera_tracking_geo_status->h_acc = mavlink_msg_camera_tracking_geo_status_get_h_acc(msg);
  534. camera_tracking_geo_status->v_acc = mavlink_msg_camera_tracking_geo_status_get_v_acc(msg);
  535. camera_tracking_geo_status->vel_n = mavlink_msg_camera_tracking_geo_status_get_vel_n(msg);
  536. camera_tracking_geo_status->vel_e = mavlink_msg_camera_tracking_geo_status_get_vel_e(msg);
  537. camera_tracking_geo_status->vel_d = mavlink_msg_camera_tracking_geo_status_get_vel_d(msg);
  538. camera_tracking_geo_status->vel_acc = mavlink_msg_camera_tracking_geo_status_get_vel_acc(msg);
  539. camera_tracking_geo_status->dist = mavlink_msg_camera_tracking_geo_status_get_dist(msg);
  540. camera_tracking_geo_status->hdg = mavlink_msg_camera_tracking_geo_status_get_hdg(msg);
  541. camera_tracking_geo_status->hdg_acc = mavlink_msg_camera_tracking_geo_status_get_hdg_acc(msg);
  542. camera_tracking_geo_status->tracking_status = mavlink_msg_camera_tracking_geo_status_get_tracking_status(msg);
  543. #else
  544. uint8_t len = msg->len < MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN? msg->len : MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN;
  545. memset(camera_tracking_geo_status, 0, MAVLINK_MSG_ID_CAMERA_TRACKING_GEO_STATUS_LEN);
  546. memcpy(camera_tracking_geo_status, _MAV_PAYLOAD(msg), len);
  547. #endif
  548. }