48 lines
1.6 KiB
C
48 lines
1.6 KiB
C
|
/**
|
||
|
* This example uses direct processing function
|
||
|
* to process dummy NMEA data from GPS receiver
|
||
|
*/
|
||
|
#include <string.h>
|
||
|
#include <stdio.h>
|
||
|
#include "lwgps/lwgps.h"
|
||
|
|
||
|
/* GPS handle */
|
||
|
lwgps_t hgps;
|
||
|
|
||
|
/**
|
||
|
* \brief Dummy data from GPS receiver
|
||
|
*/
|
||
|
const char
|
||
|
gps_rx_data[] = ""
|
||
|
"$GPRMC,183729,A,3907.356,N,12102.482,W,000.0,360.0,080301,015.5,E*6F\r\n"
|
||
|
"$GPRMB,A,,,,,,,,,,,,V*71\r\n"
|
||
|
"$GPGGA,183730,3907.356,N,12102.482,W,1,05,1.6,646.4,M,-24.1,M,,*75\r\n"
|
||
|
"$GPGSA,A,3,02,,,07,,09,24,26,,,,,1.6,1.6,1.0*3D\r\n"
|
||
|
"$GPGSV,2,1,08,02,43,088,38,04,42,145,00,05,11,291,00,07,60,043,35*71\r\n"
|
||
|
"$GPGSV,2,2,08,08,02,145,00,09,46,303,47,24,16,178,32,26,18,231,43*77\r\n"
|
||
|
"$PGRME,22.0,M,52.9,M,51.0,M*14\r\n"
|
||
|
"$GPGLL,3907.360,N,12102.481,W,183730,A*33\r\n"
|
||
|
"$PGRMZ,2062,f,3*2D\r\n"
|
||
|
"$PGRMM,WGS84*06\r\n"
|
||
|
"$GPBOD,,T,,M,,*47\r\n"
|
||
|
"$GPRTE,1,1,c,0*07\r\n"
|
||
|
"$GPRMC,183731,A,3907.482,N,12102.436,W,000.0,360.0,080301,015.5,E*67\r\n"
|
||
|
"$GPRMB,A,,,,,,,,,,,,V*71\r\n";
|
||
|
|
||
|
int
|
||
|
main() {
|
||
|
/* Init GPS */
|
||
|
lwgps_init(&hgps);
|
||
|
|
||
|
/* Process all input data */
|
||
|
lwgps_process(&hgps, gps_rx_data, strlen(gps_rx_data));
|
||
|
|
||
|
/* Print messages */
|
||
|
printf("Valid status: %d\r\n", hgps.is_valid);
|
||
|
printf("Latitude: %f degrees\r\n", hgps.latitude);
|
||
|
printf("Longitude: %f degrees\r\n", hgps.longitude);
|
||
|
printf("Altitude: %f meters\r\n", hgps.altitude);
|
||
|
|
||
|
return 0;
|
||
|
}
|