2014-02-26 00:24:14 +04:00
|
|
|
/*
|
|
|
|
|
* mavlink_messages.cpp
|
2012-10-14 17:59:15 -07:00
|
|
|
*
|
2014-02-26 00:24:14 +04:00
|
|
|
* Created on: 25.02.2014
|
|
|
|
|
* Author: ton
|
2012-10-14 17:59:15 -07:00
|
|
|
*/
|
|
|
|
|
|
2014-02-26 00:24:14 +04:00
|
|
|
#include <commander/px4_custom_mode.h>
|
2014-02-26 22:47:19 +04:00
|
|
|
#include <lib/geo/geo.h>
|
2013-04-27 00:10:20 +02:00
|
|
|
|
2014-02-26 22:47:19 +04:00
|
|
|
#include <uORB/uORB.h>
|
|
|
|
|
#include <uORB/topics/vehicle_global_position.h>
|
|
|
|
|
#include <uORB/topics/home_position.h>
|
2014-02-26 00:24:14 +04:00
|
|
|
#include <uORB/topics/vehicle_status.h>
|
|
|
|
|
#include <uORB/topics/position_setpoint_triplet.h>
|
2014-02-26 22:47:19 +04:00
|
|
|
#include <uORB/topics/vehicle_gps_position.h>
|
|
|
|
|
#include <uORB/topics/sensor_combined.h>
|
2013-11-13 22:30:39 +04:00
|
|
|
|
2014-02-26 00:24:14 +04:00
|
|
|
#include "mavlink_messages.h"
|
2014-01-28 19:30:23 +01:00
|
|
|
|
2014-02-26 22:47:19 +04:00
|
|
|
|
|
|
|
|
uint16_t
|
|
|
|
|
cm_uint16_from_m_float(float m)
|
|
|
|
|
{
|
|
|
|
|
if (m < 0.0f) {
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
} else if (m > 655.35f) {
|
|
|
|
|
return 65535;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return (uint16_t)(m * 100.0f);
|
|
|
|
|
}
|
|
|
|
|
|
2014-02-26 21:28:35 +04:00
|
|
|
class MavlinkStreamHeartbeat : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "HEARTBEAT";
|
|
|
|
|
}
|
2013-09-21 10:17:00 +02:00
|
|
|
|
2014-02-26 21:28:35 +04:00
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamHeartbeat();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *status_sub;
|
|
|
|
|
MavlinkOrbSubscription *pos_sp_triplet_sub;
|
|
|
|
|
|
|
|
|
|
struct vehicle_status_s *status;
|
|
|
|
|
struct position_setpoint_triplet_s *pos_sp_triplet;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
status_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_status), sizeof(struct vehicle_status_s));
|
|
|
|
|
status = (struct vehicle_status_s *)status_sub->get_data();
|
2014-01-09 08:10:35 +01:00
|
|
|
|
2014-02-26 21:28:35 +04:00
|
|
|
pos_sp_triplet_sub = mavlink->add_orb_subscription(ORB_ID(position_setpoint_triplet), sizeof(position_setpoint_triplet_s));
|
2014-02-26 22:13:49 +04:00
|
|
|
pos_sp_triplet = (struct position_setpoint_triplet_s *)pos_sp_triplet_sub->get_data();
|
2014-02-26 21:28:35 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
status_sub->update(t);
|
|
|
|
|
pos_sp_triplet_sub->update(t);
|
|
|
|
|
|
|
|
|
|
uint8_t mavlink_state = 0;
|
|
|
|
|
uint8_t mavlink_base_mode = 0;
|
|
|
|
|
uint32_t mavlink_custom_mode = 0;
|
|
|
|
|
|
|
|
|
|
/* HIL */
|
|
|
|
|
if (status->hil_state == HIL_STATE_ON) {
|
|
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_HIL_ENABLED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* arming state */
|
|
|
|
|
if (status->arming_state == ARMING_STATE_ARMED
|
|
|
|
|
|| status->arming_state == ARMING_STATE_ARMED_ERROR) {
|
|
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_SAFETY_ARMED;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* main state */
|
|
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_CUSTOM_MODE_ENABLED;
|
2014-02-26 22:13:49 +04:00
|
|
|
|
2014-02-26 21:28:35 +04:00
|
|
|
union px4_custom_mode custom_mode;
|
|
|
|
|
custom_mode.data = 0;
|
|
|
|
|
if (pos_sp_triplet->nav_state == NAV_STATE_NONE) {
|
|
|
|
|
/* use main state when navigator is not active */
|
|
|
|
|
if (status->main_state == MAIN_STATE_MANUAL) {
|
|
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_MANUAL_INPUT_ENABLED | (status->is_rotary_wing ? MAV_MODE_FLAG_STABILIZE_ENABLED : 0);
|
|
|
|
|
custom_mode.main_mode = PX4_CUSTOM_MAIN_MODE_MANUAL;
|
|
|
|
|
} else if (status->main_state == MAIN_STATE_SEATBELT) {
|
|
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_MANUAL_INPUT_ENABLED | MAV_MODE_FLAG_STABILIZE_ENABLED;
|
|
|
|
|
custom_mode.main_mode = PX4_CUSTOM_MAIN_MODE_SEATBELT;
|
|
|
|
|
} else if (status->main_state == MAIN_STATE_EASY) {
|
|
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_MANUAL_INPUT_ENABLED | MAV_MODE_FLAG_STABILIZE_ENABLED | MAV_MODE_FLAG_GUIDED_ENABLED;
|
|
|
|
|
custom_mode.main_mode = PX4_CUSTOM_MAIN_MODE_EASY;
|
|
|
|
|
} else if (status->main_state == MAIN_STATE_AUTO) {
|
|
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_AUTO_ENABLED | MAV_MODE_FLAG_STABILIZE_ENABLED | MAV_MODE_FLAG_GUIDED_ENABLED;
|
|
|
|
|
custom_mode.main_mode = PX4_CUSTOM_MAIN_MODE_AUTO;
|
|
|
|
|
custom_mode.sub_mode = PX4_CUSTOM_SUB_MODE_AUTO_READY;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
/* use navigation state when navigator is active */
|
2014-02-26 00:24:14 +04:00
|
|
|
mavlink_base_mode |= MAV_MODE_FLAG_AUTO_ENABLED | MAV_MODE_FLAG_STABILIZE_ENABLED | MAV_MODE_FLAG_GUIDED_ENABLED;
|
|
|
|
|
custom_mode.main_mode = PX4_CUSTOM_MAIN_MODE_AUTO;
|
2014-02-26 21:28:35 +04:00
|
|
|
if (pos_sp_triplet->nav_state == NAV_STATE_READY) {
|
|
|
|
|
custom_mode.sub_mode = PX4_CUSTOM_SUB_MODE_AUTO_READY;
|
|
|
|
|
} else if (pos_sp_triplet->nav_state == NAV_STATE_LOITER) {
|
|
|
|
|
custom_mode.sub_mode = PX4_CUSTOM_SUB_MODE_AUTO_LOITER;
|
|
|
|
|
} else if (pos_sp_triplet->nav_state == NAV_STATE_MISSION) {
|
|
|
|
|
custom_mode.sub_mode = PX4_CUSTOM_SUB_MODE_AUTO_MISSION;
|
|
|
|
|
} else if (pos_sp_triplet->nav_state == NAV_STATE_RTL) {
|
|
|
|
|
custom_mode.sub_mode = PX4_CUSTOM_SUB_MODE_AUTO_RTL;
|
|
|
|
|
} else if (pos_sp_triplet->nav_state == NAV_STATE_LAND) {
|
|
|
|
|
custom_mode.sub_mode = PX4_CUSTOM_SUB_MODE_AUTO_LAND;
|
|
|
|
|
}
|
2014-02-26 00:24:14 +04:00
|
|
|
}
|
2014-02-26 21:28:35 +04:00
|
|
|
|
|
|
|
|
/* set system state */
|
|
|
|
|
if (status->arming_state == ARMING_STATE_INIT
|
|
|
|
|
|| status->arming_state == ARMING_STATE_IN_AIR_RESTORE
|
|
|
|
|
|| status->arming_state == ARMING_STATE_STANDBY_ERROR) { // TODO review
|
|
|
|
|
mavlink_state = MAV_STATE_UNINIT;
|
|
|
|
|
} else if (status->arming_state == ARMING_STATE_ARMED) {
|
|
|
|
|
mavlink_state = MAV_STATE_ACTIVE;
|
|
|
|
|
} else if (status->arming_state == ARMING_STATE_ARMED_ERROR) {
|
|
|
|
|
mavlink_state = MAV_STATE_CRITICAL;
|
|
|
|
|
} else if (status->arming_state == ARMING_STATE_STANDBY) {
|
|
|
|
|
mavlink_state = MAV_STATE_STANDBY;
|
|
|
|
|
} else if (status->arming_state == ARMING_STATE_REBOOT) {
|
|
|
|
|
mavlink_state = MAV_STATE_POWEROFF;
|
|
|
|
|
} else {
|
|
|
|
|
mavlink_state = MAV_STATE_CRITICAL;
|
2013-11-29 02:05:15 +09:00
|
|
|
}
|
2014-02-26 21:28:35 +04:00
|
|
|
|
|
|
|
|
mavlink_msg_heartbeat_send(_channel,
|
|
|
|
|
mavlink_system.type,
|
|
|
|
|
MAV_AUTOPILOT_PX4,
|
|
|
|
|
mavlink_base_mode,
|
2014-02-26 22:13:49 +04:00
|
|
|
custom_mode.data,
|
2014-02-26 21:28:35 +04:00
|
|
|
mavlink_state);
|
|
|
|
|
|
2013-11-13 22:30:39 +04:00
|
|
|
}
|
2014-02-26 21:28:35 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MavlinkStreamSysStatus : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "SYS_STATUS";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamSysStatus();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *status_sub;
|
|
|
|
|
|
|
|
|
|
struct vehicle_status_s *status;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
status_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_status), sizeof(struct vehicle_status_s));
|
|
|
|
|
status = (struct vehicle_status_s *)status_sub->get_data();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
status_sub->update(t);
|
|
|
|
|
|
|
|
|
|
mavlink_msg_sys_status_send(_channel,
|
|
|
|
|
status->onboard_control_sensors_present,
|
|
|
|
|
status->onboard_control_sensors_enabled,
|
|
|
|
|
status->onboard_control_sensors_health,
|
|
|
|
|
status->load * 1000.0f,
|
|
|
|
|
status->battery_voltage * 1000.0f,
|
|
|
|
|
status->battery_current * 1000.0f,
|
|
|
|
|
status->battery_remaining,
|
|
|
|
|
status->drop_rate_comm,
|
|
|
|
|
status->errors_comm,
|
|
|
|
|
status->errors_count1,
|
|
|
|
|
status->errors_count2,
|
|
|
|
|
status->errors_count3,
|
|
|
|
|
status->errors_count4);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MavlinkStreamHighresIMU : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "HIGHRES_IMU";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamHighresIMU();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *sensor_sub;
|
|
|
|
|
|
|
|
|
|
struct sensor_combined_s *sensor;
|
|
|
|
|
|
|
|
|
|
uint32_t accel_counter = 0;
|
|
|
|
|
uint32_t gyro_counter = 0;
|
|
|
|
|
uint32_t mag_counter = 0;
|
|
|
|
|
uint32_t baro_counter = 0;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
sensor_sub = mavlink->add_orb_subscription(ORB_ID(sensor_combined), sizeof(struct sensor_combined_s));
|
|
|
|
|
sensor = (struct sensor_combined_s *)sensor_sub->get_data();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
sensor_sub->update(t);
|
|
|
|
|
|
|
|
|
|
uint16_t fields_updated = 0;
|
|
|
|
|
|
|
|
|
|
if (accel_counter != sensor->accelerometer_counter) {
|
|
|
|
|
/* mark first three dimensions as changed */
|
|
|
|
|
fields_updated |= (1 << 0) | (1 << 1) | (1 << 2);
|
|
|
|
|
accel_counter = sensor->accelerometer_counter;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (gyro_counter != sensor->gyro_counter) {
|
|
|
|
|
/* mark second group dimensions as changed */
|
|
|
|
|
fields_updated |= (1 << 3) | (1 << 4) | (1 << 5);
|
|
|
|
|
gyro_counter = sensor->gyro_counter;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (mag_counter != sensor->magnetometer_counter) {
|
|
|
|
|
/* mark third group dimensions as changed */
|
|
|
|
|
fields_updated |= (1 << 6) | (1 << 7) | (1 << 8);
|
|
|
|
|
mag_counter = sensor->magnetometer_counter;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (baro_counter != sensor->baro_counter) {
|
|
|
|
|
/* mark last group dimensions as changed */
|
|
|
|
|
fields_updated |= (1 << 9) | (1 << 11) | (1 << 12);
|
|
|
|
|
baro_counter = sensor->baro_counter;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
mavlink_msg_highres_imu_send(_channel,
|
|
|
|
|
sensor->timestamp,
|
|
|
|
|
sensor->accelerometer_m_s2[0], sensor->accelerometer_m_s2[1], sensor->accelerometer_m_s2[2],
|
|
|
|
|
sensor->gyro_rad_s[0], sensor->gyro_rad_s[1], sensor->gyro_rad_s[2],
|
|
|
|
|
sensor->magnetometer_ga[0], sensor->magnetometer_ga[1], sensor->magnetometer_ga[2],
|
|
|
|
|
sensor->baro_pres_mbar, sensor->differential_pressure_pa,
|
|
|
|
|
sensor->baro_alt_meter, sensor->baro_temp_celcius,
|
|
|
|
|
fields_updated);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MavlinkStreamAttitude : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "ATTITUDE";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamAttitude();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *att_sub;
|
|
|
|
|
|
|
|
|
|
struct vehicle_attitude_s *att;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
att_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_attitude), sizeof(struct vehicle_attitude_s));
|
|
|
|
|
att = (struct vehicle_attitude_s *)att_sub->get_data();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
att_sub->update(t);
|
|
|
|
|
|
|
|
|
|
mavlink_msg_attitude_send(_channel,
|
|
|
|
|
att->timestamp / 1000,
|
|
|
|
|
att->roll, att->pitch, att->yaw,
|
|
|
|
|
att->rollspeed, att->pitchspeed, att->yawspeed);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2014-02-26 22:47:19 +04:00
|
|
|
class MavlinkStreamGPSRawInt : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "GPS_RAW_INT";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamGPSRawInt();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *gps_sub;
|
|
|
|
|
|
|
|
|
|
struct vehicle_gps_position_s *gps;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
gps_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_gps_position), sizeof(struct vehicle_gps_position_s));
|
|
|
|
|
gps = (struct vehicle_gps_position_s *)gps_sub->get_data();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
gps_sub->update(t);
|
|
|
|
|
|
|
|
|
|
mavlink_msg_gps_raw_int_send(_channel,
|
|
|
|
|
gps->timestamp_position,
|
|
|
|
|
gps->fix_type,
|
|
|
|
|
gps->lat,
|
|
|
|
|
gps->lon,
|
|
|
|
|
gps->alt,
|
|
|
|
|
cm_uint16_from_m_float(gps->eph_m),
|
|
|
|
|
cm_uint16_from_m_float(gps->epv_m),
|
|
|
|
|
gps->vel_m_s * 100.0f,
|
|
|
|
|
_wrap_2pi(gps->cog_rad) * M_RAD_TO_DEG_F * 1e2f,
|
|
|
|
|
gps->satellites_visible);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MavlinkStreamGlobalPositionInt : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "GLOBAL_POSITION_INT";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamGlobalPositionInt();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *pos_sub;
|
|
|
|
|
MavlinkOrbSubscription *home_sub;
|
|
|
|
|
|
|
|
|
|
struct vehicle_global_position_s *pos;
|
|
|
|
|
struct home_position_s *home;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
pos_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_global_position), sizeof(struct vehicle_global_position_s));
|
|
|
|
|
pos = (struct vehicle_global_position_s *)pos_sub->get_data();
|
|
|
|
|
|
|
|
|
|
home_sub = mavlink->add_orb_subscription(ORB_ID(home_position), sizeof(struct home_position_s));
|
|
|
|
|
home = (struct home_position_s *)home_sub->get_data();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
pos_sub->update(t);
|
|
|
|
|
home_sub->update(t);
|
|
|
|
|
|
|
|
|
|
mavlink_msg_global_position_int_send(_channel,
|
|
|
|
|
pos->timestamp / 1000,
|
|
|
|
|
pos->lat * 1e7,
|
|
|
|
|
pos->lon * 1e7,
|
|
|
|
|
pos->alt * 1000.0f,
|
|
|
|
|
(pos->alt - home->alt) * 1000.0f,
|
|
|
|
|
pos->vel_n * 100.0f,
|
|
|
|
|
pos->vel_e * 100.0f,
|
|
|
|
|
pos->vel_d * 100.0f,
|
|
|
|
|
_wrap_2pi(pos->yaw) * M_RAD_TO_DEG_F * 100.0f);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class MavlinkStreamLocalPositionNED : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "LOCAL_POSITION_NED";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamLocalPositionNED();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *pos_sub;
|
|
|
|
|
|
|
|
|
|
struct vehicle_local_position_s *pos;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
pos_sub = mavlink->add_orb_subscription(ORB_ID(vehicle_local_position), sizeof(struct vehicle_local_position_s));
|
|
|
|
|
pos = (struct vehicle_local_position_s *)pos_sub->get_data();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
pos_sub->update(t);
|
|
|
|
|
|
|
|
|
|
mavlink_msg_local_position_ned_send(_channel,
|
|
|
|
|
pos->timestamp / 1000,
|
|
|
|
|
pos->x,
|
|
|
|
|
pos->y,
|
|
|
|
|
pos->z,
|
|
|
|
|
pos->vx,
|
|
|
|
|
pos->vy,
|
|
|
|
|
pos->vz);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2014-02-26 23:02:53 +04:00
|
|
|
class MavlinkStreamGPSGlobalOrigin : public MavlinkStream {
|
|
|
|
|
public:
|
|
|
|
|
const char *get_name()
|
|
|
|
|
{
|
|
|
|
|
return "GPS_GLOBAL_ORIGIN";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
MavlinkStream *new_instance()
|
|
|
|
|
{
|
|
|
|
|
return new MavlinkStreamGPSGlobalOrigin();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
MavlinkOrbSubscription *home_sub;
|
|
|
|
|
|
|
|
|
|
struct home_position_s *home;
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
|
void subscribe(Mavlink *mavlink)
|
|
|
|
|
{
|
|
|
|
|
home_sub = mavlink->add_orb_subscription(ORB_ID(home_position), sizeof(struct home_position_s));
|
|
|
|
|
home = (struct home_position_s *)home_sub->get_data();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void send(const hrt_abstime t) {
|
|
|
|
|
home_sub->update(t);
|
|
|
|
|
|
|
|
|
|
mavlink_msg_gps_global_origin_send(_channel,
|
|
|
|
|
(int32_t)(home->lat * 1e7),
|
|
|
|
|
(int32_t)(home->lon * 1e7),
|
|
|
|
|
(int32_t)(home->alt) * 1000.0f);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
2014-02-26 21:28:35 +04:00
|
|
|
MavlinkStream *streams_list[] = {
|
|
|
|
|
new MavlinkStreamHeartbeat(),
|
|
|
|
|
new MavlinkStreamSysStatus(),
|
|
|
|
|
new MavlinkStreamHighresIMU(),
|
|
|
|
|
new MavlinkStreamAttitude(),
|
2014-02-26 22:47:19 +04:00
|
|
|
new MavlinkStreamGPSRawInt(),
|
|
|
|
|
new MavlinkStreamGlobalPositionInt(),
|
|
|
|
|
new MavlinkStreamLocalPositionNED(),
|
2014-02-26 23:02:53 +04:00
|
|
|
new MavlinkStreamGPSGlobalOrigin(),
|
2014-02-26 21:28:35 +04:00
|
|
|
nullptr
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-10-14 17:59:15 -07:00
|
|
|
|
2014-02-24 23:46:58 +04:00
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_vehicle_attitude(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// /* copy attitude data into local buffer */
|
|
|
|
|
// orb_copy(ORB_ID(vehicle_attitude), l->mavlink->get_subs()->att_sub, &l->listener->att);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD) {
|
|
|
|
|
// /* send sensor values */
|
|
|
|
|
// mavlink_msg_attitude_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// l->listener->att.roll,
|
|
|
|
|
// l->listener->att.pitch,
|
|
|
|
|
// l->listener->att.yaw,
|
|
|
|
|
// l->listener->att.rollspeed,
|
|
|
|
|
// l->listener->att.pitchspeed,
|
|
|
|
|
// l->listener->att.yawspeed);
|
|
|
|
|
//
|
|
|
|
|
// /* limit VFR message rate to 10Hz */
|
|
|
|
|
// hrt_abstime t = hrt_absolute_time();
|
|
|
|
|
// if (t >= l->listener->last_sent_vfr + 100000) {
|
|
|
|
|
// l->listener->last_sent_vfr = t;
|
|
|
|
|
// float groundspeed = sqrtf(l->listener->global_pos.vel_n * l->listener->global_pos.vel_n + l->listener->global_pos.vel_e * l->listener->global_pos.vel_e);
|
|
|
|
|
// uint16_t heading = _wrap_2pi(l->listener->att.yaw) * M_RAD_TO_DEG_F;
|
|
|
|
|
// float throttle = l->listener->armed.armed ? l->listener->actuators_0.control[3] * 100.0f : 0.0f;
|
|
|
|
|
// mavlink_msg_vfr_hud_send(l->mavlink->get_chan(), l->listener->airspeed.true_airspeed_m_s, groundspeed, heading, throttle, l->listener->global_pos.alt, -l->listener->global_pos.vel_d);
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// /* send quaternion values if it exists */
|
|
|
|
|
// if(l->listener->att.q_valid) {
|
|
|
|
|
// mavlink_msg_attitude_quaternion_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// l->listener->att.q[0],
|
|
|
|
|
// l->listener->att.q[1],
|
|
|
|
|
// l->listener->att.q[2],
|
|
|
|
|
// l->listener->att.q[3],
|
|
|
|
|
// l->listener->att.rollspeed,
|
|
|
|
|
// l->listener->att.pitchspeed,
|
|
|
|
|
// l->listener->att.yawspeed);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// l->listener->attitude_counter++;
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_vehicle_gps_position(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct vehicle_gps_position_s gps;
|
|
|
|
|
//
|
|
|
|
|
// /* copy gps data into local buffer */
|
|
|
|
|
// orb_copy(ORB_ID(vehicle_gps_position), l->mavlink->get_subs()->gps_sub, &gps);
|
|
|
|
|
//
|
|
|
|
|
// /* update SAT info every 10 seconds */
|
|
|
|
|
// if (gps.satellite_info_available && (l->listener->gps_counter % 50 == 0)) {
|
|
|
|
|
// mavlink_msg_gps_status_send(l->mavlink->get_chan(),
|
|
|
|
|
// gps.satellites_visible,
|
|
|
|
|
// gps.satellite_prn,
|
|
|
|
|
// gps.satellite_used,
|
|
|
|
|
// gps.satellite_elevation,
|
|
|
|
|
// gps.satellite_azimuth,
|
|
|
|
|
// gps.satellite_snr);
|
|
|
|
|
// }
|
|
|
|
|
//
|
|
|
|
|
// l->listener->gps_counter++;
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_input_rc(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// /* copy rc _mavlink->get_chan()nels into local buffer */
|
|
|
|
|
// orb_copy(ORB_ID(input_rc), l->mavlink->get_subs()->input_rc_sub, &l->listener->rc_raw);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD) {
|
|
|
|
|
//
|
|
|
|
|
// const unsigned port_width = 8;
|
|
|
|
|
//
|
|
|
|
|
// for (unsigned i = 0; (i * port_width) < l->listener->rc_raw.channel_count; i++) {
|
|
|
|
|
// /* Channels are sent in MAVLink main loop at a fixed interval */
|
|
|
|
|
// mavlink_msg_rc_channels_raw_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->rc_raw.timestamp_publication / 1000,
|
|
|
|
|
// i,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 0) ? l->listener->rc_raw.values[(i * port_width) + 0] : UINT16_MAX,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 1) ? l->listener->rc_raw.values[(i * port_width) + 1] : UINT16_MAX,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 2) ? l->listener->rc_raw.values[(i * port_width) + 2] : UINT16_MAX,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 3) ? l->listener->rc_raw.values[(i * port_width) + 3] : UINT16_MAX,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 4) ? l->listener->rc_raw.values[(i * port_width) + 4] : UINT16_MAX,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 5) ? l->listener->rc_raw.values[(i * port_width) + 5] : UINT16_MAX,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 6) ? l->listener->rc_raw.values[(i * port_width) + 6] : UINT16_MAX,
|
|
|
|
|
// (l->listener->rc_raw.channel_count > (i * port_width) + 7) ? l->listener->rc_raw.values[(i * port_width) + 7] : UINT16_MAX,
|
|
|
|
|
// l->listener->rc_raw.rssi);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_global_position_setpoint(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct position_setpoint_triplet_s triplet;
|
|
|
|
|
// orb_copy(ORB_ID(position_setpoint_triplet), l->mavlink->get_subs()->triplet_sub, &triplet);
|
|
|
|
|
//
|
|
|
|
|
// if (!triplet.current.valid)
|
|
|
|
|
// return;
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD)
|
|
|
|
|
// mavlink_msg_global_position_setpoint_int_send(l->mavlink->get_chan(),
|
|
|
|
|
// MAV_FRAME_GLOBAL,
|
|
|
|
|
// (int32_t)(triplet.current.lat * 1e7d),
|
|
|
|
|
// (int32_t)(triplet.current.lon * 1e7d),
|
|
|
|
|
// (int32_t)(triplet.current.alt * 1e3f),
|
|
|
|
|
// (int16_t)(triplet.current.yaw * M_RAD_TO_DEG_F * 1e2f));
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_local_position_setpoint(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct vehicle_local_position_setpoint_s local_sp;
|
|
|
|
|
//
|
|
|
|
|
// /* copy local position data into local buffer */
|
|
|
|
|
// orb_copy(ORB_ID(vehicle_local_position_setpoint), l->mavlink->get_subs()->spl_sub, &local_sp);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD)
|
|
|
|
|
// mavlink_msg_local_position_setpoint_send(l->mavlink->get_chan(),
|
|
|
|
|
// MAV_FRAME_LOCAL_NED,
|
|
|
|
|
// local_sp.x,
|
|
|
|
|
// local_sp.y,
|
|
|
|
|
// local_sp.z,
|
|
|
|
|
// local_sp.yaw);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_attitude_setpoint(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct vehicle_attitude_setpoint_s att_sp;
|
|
|
|
|
//
|
|
|
|
|
// /* copy local position data into local buffer */
|
|
|
|
|
// orb_copy(ORB_ID(vehicle_attitude_setpoint), l->mavlink->get_subs()->spa_sub, &att_sp);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD)
|
|
|
|
|
// mavlink_msg_roll_pitch_yaw_thrust_setpoint_send(l->mavlink->get_chan(),
|
|
|
|
|
// att_sp.timestamp / 1000,
|
|
|
|
|
// att_sp.roll_body,
|
|
|
|
|
// att_sp.pitch_body,
|
|
|
|
|
// att_sp.yaw_body,
|
|
|
|
|
// att_sp.thrust);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_vehicle_rates_setpoint(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct vehicle_rates_setpoint_s rates_sp;
|
|
|
|
|
//
|
|
|
|
|
// /* copy local position data into local buffer */
|
|
|
|
|
// orb_copy(ORB_ID(vehicle_rates_setpoint), l->mavlink->get_subs()->rates_setpoint_sub, &rates_sp);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD)
|
|
|
|
|
// mavlink_msg_roll_pitch_yaw_rates_thrust_setpoint_send(l->mavlink->get_chan(),
|
|
|
|
|
// rates_sp.timestamp / 1000,
|
|
|
|
|
// rates_sp.roll,
|
|
|
|
|
// rates_sp.pitch,
|
|
|
|
|
// rates_sp.yaw,
|
|
|
|
|
// rates_sp.thrust);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_actuator_outputs(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct actuator_outputs_s act_outputs;
|
|
|
|
|
//
|
|
|
|
|
// orb_id_t ids[] = {
|
|
|
|
|
// ORB_ID(actuator_outputs_0),
|
|
|
|
|
// ORB_ID(actuator_outputs_1),
|
|
|
|
|
// ORB_ID(actuator_outputs_2),
|
|
|
|
|
// ORB_ID(actuator_outputs_3)
|
|
|
|
|
// };
|
|
|
|
|
//
|
|
|
|
|
// /* copy actuator data into local buffer */
|
|
|
|
|
// orb_copy(ids[l->arg], *l->subp, &act_outputs);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD) {
|
|
|
|
|
// mavlink_msg_servo_output_raw_send(l->mavlink->get_chan(), l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// l->arg /* port number - needs GCS support */,
|
|
|
|
|
// /* QGC has port number support already */
|
|
|
|
|
// act_outputs.output[0],
|
|
|
|
|
// act_outputs.output[1],
|
|
|
|
|
// act_outputs.output[2],
|
|
|
|
|
// act_outputs.output[3],
|
|
|
|
|
// act_outputs.output[4],
|
|
|
|
|
// act_outputs.output[5],
|
|
|
|
|
// act_outputs.output[6],
|
|
|
|
|
// act_outputs.output[7]);
|
|
|
|
|
//
|
|
|
|
|
// /* only send in HIL mode and only send first group for HIL */
|
|
|
|
|
// if (l->mavlink->get_hil_enabled() && l->listener->armed.armed && ids[l->arg] == ORB_ID(actuator_outputs_0)) {
|
|
|
|
|
//
|
|
|
|
|
// /* translate the current syste state to mavlink state and mode */
|
|
|
|
|
// uint8_t mavlink_state = 0;
|
|
|
|
|
// uint8_t mavlink_base_mode = 0;
|
|
|
|
|
// uint32_t mavlink_custom_mode = 0;
|
|
|
|
|
// l->mavlink->get_mavlink_mode_and_state(&mavlink_state, &mavlink_base_mode, &mavlink_custom_mode);
|
|
|
|
|
//
|
|
|
|
|
// /* HIL message as per MAVLink spec */
|
|
|
|
|
//
|
|
|
|
|
// /* scale / assign outputs depending on system type */
|
|
|
|
|
//
|
|
|
|
|
// if (mavlink_system.type == MAV_TYPE_QUADROTOR) {
|
|
|
|
|
// mavlink_msg_hil_controls_send(l->mavlink->get_chan(),
|
|
|
|
|
// hrt_absolute_time(),
|
|
|
|
|
// ((act_outputs.output[0] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[1] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[2] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[3] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// -1,
|
|
|
|
|
// -1,
|
|
|
|
|
// -1,
|
|
|
|
|
// -1,
|
|
|
|
|
// mavlink_base_mode,
|
|
|
|
|
// 0);
|
|
|
|
|
//
|
|
|
|
|
// } else if (mavlink_system.type == MAV_TYPE_HEXAROTOR) {
|
|
|
|
|
// mavlink_msg_hil_controls_send(l->mavlink->get_chan(),
|
|
|
|
|
// hrt_absolute_time(),
|
|
|
|
|
// ((act_outputs.output[0] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[1] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[2] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[3] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[4] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[5] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// -1,
|
|
|
|
|
// -1,
|
|
|
|
|
// mavlink_base_mode,
|
|
|
|
|
// 0);
|
|
|
|
|
//
|
|
|
|
|
// } else if (mavlink_system.type == MAV_TYPE_OCTOROTOR) {
|
|
|
|
|
// mavlink_msg_hil_controls_send(l->mavlink->get_chan(),
|
|
|
|
|
// hrt_absolute_time(),
|
|
|
|
|
// ((act_outputs.output[0] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[1] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[2] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[3] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[4] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[5] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[6] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// ((act_outputs.output[7] - 900.0f) / 600.0f) / 2.0f,
|
|
|
|
|
// mavlink_base_mode,
|
|
|
|
|
// 0);
|
|
|
|
|
//
|
|
|
|
|
// } else {
|
|
|
|
|
// mavlink_msg_hil_controls_send(l->mavlink->get_chan(),
|
|
|
|
|
// hrt_absolute_time(),
|
|
|
|
|
// (act_outputs.output[0] - 1500.0f) / 500.0f,
|
|
|
|
|
// (act_outputs.output[1] - 1500.0f) / 500.0f,
|
|
|
|
|
// (act_outputs.output[2] - 1500.0f) / 500.0f,
|
|
|
|
|
// (act_outputs.output[3] - 1000.0f) / 1000.0f,
|
|
|
|
|
// (act_outputs.output[4] - 1500.0f) / 500.0f,
|
|
|
|
|
// (act_outputs.output[5] - 1500.0f) / 500.0f,
|
|
|
|
|
// (act_outputs.output[6] - 1500.0f) / 500.0f,
|
|
|
|
|
// (act_outputs.output[7] - 1500.0f) / 500.0f,
|
|
|
|
|
// mavlink_base_mode,
|
|
|
|
|
// 0);
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_actuator_armed(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// orb_copy(ORB_ID(actuator_armed), l->mavlink->get_subs()->armed_sub, &l->listener->armed);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_manual_control_setpoint(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct manual_control_setpoint_s man_control;
|
|
|
|
|
//
|
|
|
|
|
// /* copy manual control data into local buffer */
|
|
|
|
|
// orb_copy(ORB_ID(manual_control_setpoint), l->mavlink->get_subs()->man_control_sp_sub, &man_control);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD)
|
|
|
|
|
// mavlink_msg_manual_control_send(l->mavlink->get_chan(),
|
|
|
|
|
// mavlink_system.sysid,
|
|
|
|
|
// man_control.roll * 1000,
|
|
|
|
|
// man_control.pitch * 1000,
|
|
|
|
|
// man_control.yaw * 1000,
|
|
|
|
|
// man_control.throttle * 1000,
|
|
|
|
|
// 0);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_vehicle_attitude_controls(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// orb_copy(ORB_ID_VEHICLE_ATTITUDE_CONTROLS, l->mavlink->get_subs()->actuators_sub, &l->listener->actuators_0);
|
|
|
|
|
//
|
|
|
|
|
// if (l->mavlink->get_mode() == Mavlink::MODE_OFFBOARD) {
|
|
|
|
|
// /* send, add spaces so that string buffer is at least 10 chars long */
|
|
|
|
|
// mavlink_msg_named_value_float_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// "ctrl0 ",
|
|
|
|
|
// l->listener->actuators_0.control[0]);
|
|
|
|
|
// mavlink_msg_named_value_float_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// "ctrl1 ",
|
|
|
|
|
// l->listener->actuators_0.control[1]);
|
|
|
|
|
// mavlink_msg_named_value_float_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// "ctrl2 ",
|
|
|
|
|
// l->listener->actuators_0.control[2]);
|
|
|
|
|
// mavlink_msg_named_value_float_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// "ctrl3 ",
|
|
|
|
|
// l->listener->actuators_0.control[3]);
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_debug_key_value(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct debug_key_value_s debug;
|
|
|
|
|
//
|
|
|
|
|
// orb_copy(ORB_ID(debug_key_value), l->mavlink->get_subs()->debug_key_value, &debug);
|
|
|
|
|
//
|
|
|
|
|
// /* Enforce null termination */
|
|
|
|
|
// debug.key[sizeof(debug.key) - 1] = '\0';
|
|
|
|
|
//
|
|
|
|
|
// mavlink_msg_named_value_float_send(l->mavlink->get_chan(),
|
|
|
|
|
// l->listener->last_sensor_timestamp / 1000,
|
|
|
|
|
// debug.key,
|
|
|
|
|
// debug.value);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_optical_flow(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// struct optical_flow_s flow;
|
|
|
|
|
//
|
|
|
|
|
// orb_copy(ORB_ID(optical_flow), l->mavlink->get_subs()->optical_flow, &flow);
|
|
|
|
|
//
|
|
|
|
|
// mavlink_msg_optical_flow_send(l->mavlink->get_chan(), flow.timestamp, flow.sensor_id, flow.flow_raw_x, flow.flow_raw_y,
|
|
|
|
|
// flow.flow_comp_x_m, flow.flow_comp_y_m, flow.quality, flow.ground_distance_m);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_airspeed(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
// orb_copy(ORB_ID(airspeed), l->mavlink->get_subs()->airspeed_sub, &l->listener->airspeed);
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//void
|
|
|
|
|
//MavlinkOrbListener::l_nav_cap(const struct listener *l)
|
|
|
|
|
//{
|
|
|
|
|
//
|
|
|
|
|
// orb_copy(ORB_ID(navigation_capabilities), l->mavlink->get_subs()->navigation_capabilities_sub, &l->listener->nav_cap);
|
|
|
|
|
//
|
|
|
|
|
// mavlink_msg_named_value_float_send(l->mavlink->get_chan(),
|
|
|
|
|
// hrt_absolute_time() / 1000,
|
|
|
|
|
// "turn dist",
|
|
|
|
|
// l->listener->nav_cap.turn_distance);
|
|
|
|
|
//
|
|
|
|
|
//}
|