User | Revision | Line number | New contents of line |
joosttromp |
0:62fa44dd600b
|
1
|
/*
|
joosttromp |
0:62fa44dd600b
|
2
|
Copyright (c) 2010 Andy Kirkham
|
joosttromp |
0:62fa44dd600b
|
3
|
|
joosttromp |
0:62fa44dd600b
|
4
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
joosttromp |
0:62fa44dd600b
|
5
|
of this software and associated documentation files (the "Software"), to deal
|
joosttromp |
0:62fa44dd600b
|
6
|
in the Software without restriction, including without limitation the rights
|
joosttromp |
0:62fa44dd600b
|
7
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
joosttromp |
0:62fa44dd600b
|
8
|
copies of the Software, and to permit persons to whom the Software is
|
joosttromp |
0:62fa44dd600b
|
9
|
furnished to do so, subject to the following conditions:
|
joosttromp |
0:62fa44dd600b
|
10
|
|
joosttromp |
0:62fa44dd600b
|
11
|
The above copyright notice and this permission notice shall be included in
|
joosttromp |
0:62fa44dd600b
|
12
|
all copies or substantial portions of the Software.
|
joosttromp |
0:62fa44dd600b
|
13
|
|
joosttromp |
0:62fa44dd600b
|
14
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
joosttromp |
0:62fa44dd600b
|
15
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
joosttromp |
0:62fa44dd600b
|
16
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
joosttromp |
0:62fa44dd600b
|
17
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
joosttromp |
0:62fa44dd600b
|
18
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
joosttromp |
0:62fa44dd600b
|
19
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
joosttromp |
0:62fa44dd600b
|
20
|
THE SOFTWARE.
|
joosttromp |
0:62fa44dd600b
|
21
|
*/
|
joosttromp |
0:62fa44dd600b
|
22
|
|
joosttromp |
0:62fa44dd600b
|
23
|
#include "GPS_Geodetic.h"
|
joosttromp |
0:62fa44dd600b
|
24
|
|
joosttromp |
0:62fa44dd600b
|
25
|
void
|
joosttromp |
0:62fa44dd600b
|
26
|
GPS_Geodetic::nmea_gga(char *s) {
|
joosttromp |
0:62fa44dd600b
|
27
|
char *token;
|
joosttromp |
0:62fa44dd600b
|
28
|
int token_counter = 0;
|
joosttromp |
0:62fa44dd600b
|
29
|
char *latitude = (char *)NULL;
|
joosttromp |
0:62fa44dd600b
|
30
|
char *longitude = (char *)NULL;
|
joosttromp |
0:62fa44dd600b
|
31
|
char *lat_dir = (char *)NULL;
|
joosttromp |
0:62fa44dd600b
|
32
|
char *lon_dir = (char *)NULL;
|
joosttromp |
0:62fa44dd600b
|
33
|
char *qual = (char *)NULL;
|
joosttromp |
0:62fa44dd600b
|
34
|
char *altitude = (char *)NULL;
|
joosttromp |
0:62fa44dd600b
|
35
|
char *sats = (char *)NULL;
|
joosttromp |
0:62fa44dd600b
|
36
|
|
joosttromp |
0:62fa44dd600b
|
37
|
token = strtok(s, ",");
|
joosttromp |
0:62fa44dd600b
|
38
|
while (token) {
|
joosttromp |
0:62fa44dd600b
|
39
|
switch (token_counter) {
|
joosttromp |
0:62fa44dd600b
|
40
|
case 2: latitude = token; break;
|
joosttromp |
0:62fa44dd600b
|
41
|
case 4: longitude = token; break;
|
joosttromp |
0:62fa44dd600b
|
42
|
case 3: lat_dir = token; break;
|
joosttromp |
0:62fa44dd600b
|
43
|
case 5: lon_dir = token; break;
|
joosttromp |
0:62fa44dd600b
|
44
|
case 6: qual = token; break;
|
joosttromp |
0:62fa44dd600b
|
45
|
case 7: sats = token; break;
|
joosttromp |
0:62fa44dd600b
|
46
|
case 9: altitude = token; break;
|
joosttromp |
0:62fa44dd600b
|
47
|
}
|
joosttromp |
0:62fa44dd600b
|
48
|
token = strtok((char *)NULL, ",");
|
joosttromp |
0:62fa44dd600b
|
49
|
token_counter++;
|
joosttromp |
0:62fa44dd600b
|
50
|
}
|
joosttromp |
0:62fa44dd600b
|
51
|
|
joosttromp |
0:62fa44dd600b
|
52
|
// If the fix quality is valid set our location information.
|
joosttromp |
0:62fa44dd600b
|
53
|
if (latitude && longitude && altitude && sats) {
|
joosttromp |
0:62fa44dd600b
|
54
|
lat = convert_lat_coord(latitude, lat_dir[0]);
|
joosttromp |
0:62fa44dd600b
|
55
|
lon = convert_lon_coord(longitude, lon_dir[0]);
|
joosttromp |
0:62fa44dd600b
|
56
|
alt = convert_height(altitude);
|
joosttromp |
0:62fa44dd600b
|
57
|
num_of_gps_sats = atoi(sats);
|
joosttromp |
0:62fa44dd600b
|
58
|
gps_satellite_quality = atoi(qual);
|
joosttromp |
0:62fa44dd600b
|
59
|
}
|
joosttromp |
0:62fa44dd600b
|
60
|
else {
|
joosttromp |
0:62fa44dd600b
|
61
|
gps_satellite_quality = 0;
|
joosttromp |
0:62fa44dd600b
|
62
|
}
|
joosttromp |
0:62fa44dd600b
|
63
|
}
|
joosttromp |
0:62fa44dd600b
|
64
|
|
joosttromp |
0:62fa44dd600b
|
65
|
double
|
joosttromp |
0:62fa44dd600b
|
66
|
GPS_Geodetic::convert_lat_coord(char *s, char north_south)
|
joosttromp |
0:62fa44dd600b
|
67
|
{
|
joosttromp |
0:62fa44dd600b
|
68
|
int deg, min, sec;
|
joosttromp |
0:62fa44dd600b
|
69
|
double fsec, val;
|
joosttromp |
0:62fa44dd600b
|
70
|
|
joosttromp |
0:62fa44dd600b
|
71
|
deg = ( (s[0] - '0') * 10) + s[1] - '0';
|
joosttromp |
0:62fa44dd600b
|
72
|
min = ( (s[2] - '0') * 10) + s[3] - '0';
|
joosttromp |
0:62fa44dd600b
|
73
|
sec = ( ((s[5] - '0') * 1000) + ((s[6] - '0') * 100) + ((s[7] - '0') * 10) + (s[8] - '0'));
|
joosttromp |
0:62fa44dd600b
|
74
|
fsec = (double)((double)sec /10000.0);
|
joosttromp |
0:62fa44dd600b
|
75
|
val = (double)deg + ((double)((double)min/60.0)) + (fsec/60.0);
|
joosttromp |
0:62fa44dd600b
|
76
|
if (north_south == 'S') { val *= -1.0; }
|
joosttromp |
0:62fa44dd600b
|
77
|
lat = val;
|
joosttromp |
0:62fa44dd600b
|
78
|
return val;
|
joosttromp |
0:62fa44dd600b
|
79
|
}
|
joosttromp |
0:62fa44dd600b
|
80
|
|
joosttromp |
0:62fa44dd600b
|
81
|
double
|
joosttromp |
0:62fa44dd600b
|
82
|
GPS_Geodetic::convert_lon_coord(char *s, char east_west)
|
joosttromp |
0:62fa44dd600b
|
83
|
{
|
joosttromp |
0:62fa44dd600b
|
84
|
int deg, min, sec;
|
joosttromp |
0:62fa44dd600b
|
85
|
double fsec, val;
|
joosttromp |
0:62fa44dd600b
|
86
|
|
joosttromp |
0:62fa44dd600b
|
87
|
deg = ( (s[0] - '0') * 100) + ((s[1] - '0') * 10) + (s[2] - '0');
|
joosttromp |
0:62fa44dd600b
|
88
|
min = ( (s[3] - '0') * 10) + s[4] - '0';
|
joosttromp |
0:62fa44dd600b
|
89
|
sec = ( ((s[6] - '0') * 1000) + ((s[7] - '0') * 100) + ((s[8] - '0') * 10) + (s[9] - '0'));
|
joosttromp |
0:62fa44dd600b
|
90
|
fsec = (double)((double)sec /10000.0);
|
joosttromp |
0:62fa44dd600b
|
91
|
val = (double)deg + ((double)((double)min/60.0)) + (fsec/60.0);
|
joosttromp |
0:62fa44dd600b
|
92
|
if (east_west == 'W') { val *= -1.0; }
|
joosttromp |
0:62fa44dd600b
|
93
|
lon = val;
|
joosttromp |
0:62fa44dd600b
|
94
|
return val;
|
joosttromp |
0:62fa44dd600b
|
95
|
|
joosttromp |
0:62fa44dd600b
|
96
|
}
|
joosttromp |
0:62fa44dd600b
|
97
|
|
joosttromp |
0:62fa44dd600b
|
98
|
double
|
joosttromp |
0:62fa44dd600b
|
99
|
GPS_Geodetic::convert_height(char *s)
|
joosttromp |
0:62fa44dd600b
|
100
|
{
|
joosttromp |
0:62fa44dd600b
|
101
|
//double val = (double)(atof(s) / 1000.0);
|
joosttromp |
0:62fa44dd600b
|
102
|
double val = (double)(atof(s) * 3.2808399);
|
joosttromp |
0:62fa44dd600b
|
103
|
alt = val;
|
joosttromp |
0:62fa44dd600b
|
104
|
return val;
|
joosttromp |
0:62fa44dd600b
|
105
|
}
|
joosttromp |
0:62fa44dd600b
|
106
|
|
joosttromp |
0:62fa44dd600b
|
107
|
|