2022-10-16 12:28:49 +02:00
|
|
|
#include "NMEAWPL.h"
|
|
|
|
|
|
|
|
|
|
/* -------------------------------------------
|
|
|
|
|
* 1 2 3 4 5 6
|
|
|
|
|
* | | | | | |
|
|
|
|
|
* $--WPL,llll.ll,a,yyyyy.yy,a,c--c*hh<CR><LF>
|
|
|
|
|
*
|
|
|
|
|
* Field Number:
|
|
|
|
|
* 1 Latitude
|
|
|
|
|
* 2 N or S (North or South)
|
|
|
|
|
* 3 Longitude
|
|
|
|
|
* 4 E or W (East or West)
|
|
|
|
|
* 5 Waypoint name
|
|
|
|
|
* 6 Checksum
|
2022-10-16 16:37:38 +02:00
|
|
|
* -------------------------------------------
|
2022-10-16 12:28:49 +02:00
|
|
|
*/
|
|
|
|
|
|
2022-11-05 15:11:11 -05:00
|
|
|
uint32_t printWPL(char *buf, const Position &pos, const char *name)
|
2022-10-16 12:28:49 +02:00
|
|
|
{
|
2022-11-09 23:42:52 +01:00
|
|
|
uint32_t len = sprintf(buf, "$GNWPL,%07.2f,%c,%08.2f,%c,%s",
|
|
|
|
|
abs(pos.latitude_i) * 1e-5, pos.latitude_i < 0 ? 'S' : 'N',
|
|
|
|
|
abs(pos.longitude_i) * 1e-5, pos.longitude_i < 0 ? 'W' : 'E',
|
|
|
|
|
name);
|
2022-11-05 15:14:08 -05:00
|
|
|
uint32_t chk = 0;
|
2022-11-05 15:34:54 -05:00
|
|
|
for (uint32_t i = 1; i < len; i++) {
|
2022-10-16 12:28:49 +02:00
|
|
|
chk ^= buf[i];
|
|
|
|
|
}
|
|
|
|
|
len += sprintf(buf + len, "*%02X\r\n", chk);
|
|
|
|
|
return len;
|
|
|
|
|
}
|
2022-10-16 16:37:38 +02:00
|
|
|
|
|
|
|
|
/* -------------------------------------------
|
|
|
|
|
* 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
|
|
|
|
|
* | | | | | | | | | | | | | | |
|
|
|
|
|
* $--GGA,hhmmss.ss,ddmm.mm,a,ddmm.mm,a,x,xx,x.x,x.x,M,x.x,M,x.x,xxxx*hh<CR><LF>
|
|
|
|
|
*
|
|
|
|
|
* Field Number:
|
|
|
|
|
* 1 UTC of this position report, hh is hours, mm is minutes, ss.ss is seconds.
|
|
|
|
|
* 2 Latitude
|
|
|
|
|
* 3 N or S (North or South)
|
|
|
|
|
* 4 Longitude
|
|
|
|
|
* 5 E or W (East or West)
|
|
|
|
|
* 6 GPS Quality Indicator (non null)
|
|
|
|
|
* 7 Number of satellites in use, 00 - 12
|
|
|
|
|
* 8 Horizontal Dilution of precision (meters)
|
|
|
|
|
* 9 Antenna Altitude above/below mean-sea-level (geoid) (in meters)
|
|
|
|
|
* 10 Units of antenna altitude, meters
|
|
|
|
|
* 11 Geoidal separation, the difference between the WGS-84 earth ellipsoid and mean-sea-level (geoid), "-" means mean-sea-level below ellipsoid
|
|
|
|
|
* 12 Units of geoidal separation, meters
|
|
|
|
|
* 13 Age of differential GPS data, time in seconds since last SC104 type 1 or 9 update, null field when DGPS is not used
|
|
|
|
|
* 14 Differential reference station ID, 0000-1023
|
|
|
|
|
* 15 Checksum
|
|
|
|
|
* -------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
|
2022-11-05 15:11:11 -05:00
|
|
|
uint32_t printGGA(char *buf, const Position &pos)
|
2022-10-16 16:37:38 +02:00
|
|
|
{
|
2022-11-05 15:11:11 -05:00
|
|
|
uint32_t len = sprintf(buf, "$GNGGA,%06u.%03u,%07.2f,%c,%08.2f,%c,%u,%02u,%04u,%04d,%c,%04d,%c,%d,%04d",
|
2022-10-16 16:37:38 +02:00
|
|
|
pos.time / 1000,
|
|
|
|
|
pos.time % 1000,
|
2022-11-09 23:42:52 +01:00
|
|
|
abs(pos.latitude_i) * 1e-5, pos.latitude_i < 0 ? 'S' : 'N',
|
|
|
|
|
abs(pos.longitude_i) * 1e-5, pos.longitude_i < 0 ? 'W' : 'E',
|
2022-10-16 16:37:38 +02:00
|
|
|
pos.fix_type,
|
|
|
|
|
pos.sats_in_view,
|
|
|
|
|
pos.HDOP,
|
|
|
|
|
pos.altitude,
|
|
|
|
|
'M',
|
|
|
|
|
pos.altitude_geoidal_separation,
|
|
|
|
|
'M',
|
|
|
|
|
0,
|
|
|
|
|
0);
|
|
|
|
|
|
2022-11-05 15:11:11 -05:00
|
|
|
uint32_t chk = 0;
|
|
|
|
|
for (uint32_t i = 1; i < len; i++) {
|
2022-10-16 16:37:38 +02:00
|
|
|
chk ^= buf[i];
|
|
|
|
|
}
|
|
|
|
|
len += sprintf(buf + len, "*%02X\r\n", chk);
|
|
|
|
|
return len;
|
2022-11-05 15:11:11 -05:00
|
|
|
}
|