mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-24 09:38:29 -04:00
DataFlash: added GPSAlt to CAM and TRIG log messages
useful for people with RTK GPS
This commit is contained in:
parent
8dba91658c
commit
6f59c4ae53
@ -109,6 +109,7 @@ public:
|
|||||||
bool Log_Write_MavCmd(uint16_t cmd_total, const mavlink_mission_item_t& mav_cmd);
|
bool Log_Write_MavCmd(uint16_t cmd_total, const mavlink_mission_item_t& mav_cmd);
|
||||||
void Log_Write_Radio(const mavlink_radio_t &packet);
|
void Log_Write_Radio(const mavlink_radio_t &packet);
|
||||||
void Log_Write_Message(const char *message);
|
void Log_Write_Message(const char *message);
|
||||||
|
void Log_Write_CameraInfo(enum LogMessages msg, const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc);
|
||||||
void Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc);
|
void Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc);
|
||||||
void Log_Write_Trigger(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc);
|
void Log_Write_Trigger(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc);
|
||||||
void Log_Write_ESC(void);
|
void Log_Write_ESC(void);
|
||||||
|
@ -1538,9 +1538,9 @@ void DataFlash_Class::Log_Write_Radio(const mavlink_radio_t &packet)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Write a Camera packet
|
// Write a Camera packet
|
||||||
void DataFlash_Class::Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc)
|
void DataFlash_Class::Log_Write_CameraInfo(enum LogMessages msg, const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc)
|
||||||
{
|
{
|
||||||
int32_t altitude, altitude_rel;
|
int32_t altitude, altitude_rel, altitude_gps;
|
||||||
if (current_loc.flags.relative_alt) {
|
if (current_loc.flags.relative_alt) {
|
||||||
altitude = current_loc.alt+ahrs.get_home().alt;
|
altitude = current_loc.alt+ahrs.get_home().alt;
|
||||||
altitude_rel = current_loc.alt;
|
altitude_rel = current_loc.alt;
|
||||||
@ -1548,9 +1548,14 @@ void DataFlash_Class::Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, c
|
|||||||
altitude = current_loc.alt;
|
altitude = current_loc.alt;
|
||||||
altitude_rel = current_loc.alt - ahrs.get_home().alt;
|
altitude_rel = current_loc.alt - ahrs.get_home().alt;
|
||||||
}
|
}
|
||||||
|
if (gps.status() >= AP_GPS::GPS_OK_FIX_3D) {
|
||||||
|
altitude_gps = gps.location().alt;
|
||||||
|
} else {
|
||||||
|
altitude_gps = 0;
|
||||||
|
}
|
||||||
|
|
||||||
struct log_Camera pkt = {
|
struct log_Camera pkt = {
|
||||||
LOG_PACKET_HEADER_INIT(LOG_CAMERA_MSG),
|
LOG_PACKET_HEADER_INIT(msg),
|
||||||
time_us : AP_HAL::micros64(),
|
time_us : AP_HAL::micros64(),
|
||||||
gps_time : gps.time_week_ms(),
|
gps_time : gps.time_week_ms(),
|
||||||
gps_week : gps.time_week(),
|
gps_week : gps.time_week(),
|
||||||
@ -1558,6 +1563,7 @@ void DataFlash_Class::Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, c
|
|||||||
longitude : current_loc.lng,
|
longitude : current_loc.lng,
|
||||||
altitude : altitude,
|
altitude : altitude,
|
||||||
altitude_rel: altitude_rel,
|
altitude_rel: altitude_rel,
|
||||||
|
altitude_gps: altitude_gps,
|
||||||
roll : (int16_t)ahrs.roll_sensor,
|
roll : (int16_t)ahrs.roll_sensor,
|
||||||
pitch : (int16_t)ahrs.pitch_sensor,
|
pitch : (int16_t)ahrs.pitch_sensor,
|
||||||
yaw : (uint16_t)ahrs.yaw_sensor
|
yaw : (uint16_t)ahrs.yaw_sensor
|
||||||
@ -1565,32 +1571,16 @@ void DataFlash_Class::Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, c
|
|||||||
WriteCriticalBlock(&pkt, sizeof(pkt));
|
WriteCriticalBlock(&pkt, sizeof(pkt));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Write a Camera packet
|
||||||
|
void DataFlash_Class::Log_Write_Camera(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc)
|
||||||
|
{
|
||||||
|
Log_Write_CameraInfo(LOG_CAMERA_MSG, ahrs, gps, current_loc);
|
||||||
|
}
|
||||||
|
|
||||||
// Write a Trigger packet
|
// Write a Trigger packet
|
||||||
void DataFlash_Class::Log_Write_Trigger(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc)
|
void DataFlash_Class::Log_Write_Trigger(const AP_AHRS &ahrs, const AP_GPS &gps, const Location ¤t_loc)
|
||||||
{
|
{
|
||||||
int32_t altitude, altitude_rel;
|
Log_Write_CameraInfo(LOG_TRIGGER_MSG, ahrs, gps, current_loc);
|
||||||
if (current_loc.flags.relative_alt) {
|
|
||||||
altitude = current_loc.alt+ahrs.get_home().alt;
|
|
||||||
altitude_rel = current_loc.alt;
|
|
||||||
} else {
|
|
||||||
altitude = current_loc.alt;
|
|
||||||
altitude_rel = current_loc.alt - ahrs.get_home().alt;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct log_Trigger pkt = {
|
|
||||||
LOG_PACKET_HEADER_INIT(LOG_TRIGGER_MSG),
|
|
||||||
time_us : AP_HAL::micros64(),
|
|
||||||
gps_time : gps.time_week_ms(),
|
|
||||||
gps_week : gps.time_week(),
|
|
||||||
latitude : current_loc.lat,
|
|
||||||
longitude : current_loc.lng,
|
|
||||||
altitude : altitude,
|
|
||||||
altitude_rel: altitude_rel,
|
|
||||||
roll : (int16_t)ahrs.roll_sensor,
|
|
||||||
pitch : (int16_t)ahrs.pitch_sensor,
|
|
||||||
yaw : (uint16_t)ahrs.yaw_sensor
|
|
||||||
};
|
|
||||||
WriteBlock(&pkt, sizeof(pkt));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Write an attitude packet
|
// Write an attitude packet
|
||||||
|
@ -385,20 +385,7 @@ struct PACKED log_Camera {
|
|||||||
int32_t longitude;
|
int32_t longitude;
|
||||||
int32_t altitude;
|
int32_t altitude;
|
||||||
int32_t altitude_rel;
|
int32_t altitude_rel;
|
||||||
int16_t roll;
|
int32_t altitude_gps;
|
||||||
int16_t pitch;
|
|
||||||
uint16_t yaw;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct PACKED log_Trigger {
|
|
||||||
LOG_PACKET_HEADER;
|
|
||||||
uint64_t time_us;
|
|
||||||
uint32_t gps_time;
|
|
||||||
uint16_t gps_week;
|
|
||||||
int32_t latitude;
|
|
||||||
int32_t longitude;
|
|
||||||
int32_t altitude;
|
|
||||||
int32_t altitude_rel;
|
|
||||||
int16_t roll;
|
int16_t roll;
|
||||||
int16_t pitch;
|
int16_t pitch;
|
||||||
uint16_t yaw;
|
uint16_t yaw;
|
||||||
@ -735,7 +722,9 @@ Format characters in the format string for binary log messages
|
|||||||
{ LOG_RADIO_MSG, sizeof(log_Radio), \
|
{ LOG_RADIO_MSG, sizeof(log_Radio), \
|
||||||
"RAD", "QBBBBBHH", "TimeUS,RSSI,RemRSSI,TxBuf,Noise,RemNoise,RxErrors,Fixed" }, \
|
"RAD", "QBBBBBHH", "TimeUS,RSSI,RemRSSI,TxBuf,Noise,RemNoise,RxErrors,Fixed" }, \
|
||||||
{ LOG_CAMERA_MSG, sizeof(log_Camera), \
|
{ LOG_CAMERA_MSG, sizeof(log_Camera), \
|
||||||
"CAM", "QIHLLeeccC","TimeUS,GPSTime,GPSWeek,Lat,Lng,Alt,RelAlt,Roll,Pitch,Yaw" }, \
|
"CAM", "QIHLLeeeccC","TimeUS,GPSTime,GPSWeek,Lat,Lng,Alt,RelAlt,GPSAlt,Roll,Pitch,Yaw" }, \
|
||||||
|
{ LOG_TRIGGER_MSG, sizeof(log_Camera), \
|
||||||
|
"TRIG", "QIHLLeeeccC","TimeUS,GPSTime,GPSWeek,Lat,Lng,Alt,RelAlt,GPSAlt,Roll,Pitch,Yaw" }, \
|
||||||
{ LOG_ARSP_MSG, sizeof(log_AIRSPEED), \
|
{ LOG_ARSP_MSG, sizeof(log_AIRSPEED), \
|
||||||
"ARSP", "Qffcff", "TimeUS,Airspeed,DiffPress,Temp,RawPress,Offset" }, \
|
"ARSP", "Qffcff", "TimeUS,Airspeed,DiffPress,Temp,RawPress,Offset" }, \
|
||||||
{ LOG_CURRENT_MSG, sizeof(log_Current), \
|
{ LOG_CURRENT_MSG, sizeof(log_Current), \
|
||||||
@ -749,9 +738,7 @@ Format characters in the format string for binary log messages
|
|||||||
{ LOG_RFND_MSG, sizeof(log_RFND), \
|
{ LOG_RFND_MSG, sizeof(log_RFND), \
|
||||||
"RFND", "QCC", "TimeUS,Dist1,Dist2" }, \
|
"RFND", "QCC", "TimeUS,Dist1,Dist2" }, \
|
||||||
{ LOG_DF_MAV_STATS, sizeof(log_DF_MAV_Stats), \
|
{ LOG_DF_MAV_STATS, sizeof(log_DF_MAV_Stats), \
|
||||||
"DMS", "IIIIIBBBBBBBBBB", "TimeMS,N,Dp,RT,RS,Er,Fa,Fmn,Fmx,Pa,Pmn,Pmx,Sa,Smn,Smx" }, \
|
"DMS", "IIIIIBBBBBBBBBB", "TimeMS,N,Dp,RT,RS,Er,Fa,Fmn,Fmx,Pa,Pmn,Pmx,Sa,Smn,Smx" }
|
||||||
{ LOG_TRIGGER_MSG, sizeof(log_Trigger), \
|
|
||||||
"TRIG", "QIHLLeeccC","TimeUS,GPSTime,GPSWeek,Lat,Lng,Alt,RelAlt,Roll,Pitch,Yaw" }
|
|
||||||
|
|
||||||
// messages for more advanced boards
|
// messages for more advanced boards
|
||||||
#define LOG_EXTRA_STRUCTURES \
|
#define LOG_EXTRA_STRUCTURES \
|
||||||
|
Loading…
Reference in New Issue
Block a user