diff options
Diffstat (limited to 'aoview')
-rw-r--r-- | aoview/aoview_state.c | 44 | ||||
-rw-r--r-- | aoview/aoview_table.c | 2 |
2 files changed, 32 insertions, 14 deletions
diff --git a/aoview/aoview_state.c b/aoview/aoview_state.c index 046ccc92..6530847e 100644 --- a/aoview/aoview_state.c +++ b/aoview/aoview_state.c @@ -45,16 +45,33 @@ aoview_great_circle (double start_lat, double start_lon, { double rad = M_PI / 180; double earth_radius = 6371.2; - double a = (90 - start_lat) * rad; - double b = (90 - end_lat) * rad; - double phi = (end_lon - start_lon) * rad; - double cosr = cos(a) * cos(b) + sin(a) * sin(b) * cos(phi); - double r = acos(cosr); - double rdist = earth_radius * r; - double sinth = sin(phi) * sin(b) / sin(r); - double th = asin(sinth) / rad; - *dist = rdist; - *bearing = th; + double lat1 = rad * start_lat; + double lon1 = -rad * start_lon; + double lat2 = rad * end_lat; + double lon2 = -rad * end_lon; + + double d = acos(sin(lat1)*sin(lat2)+cos(lat1)*cos(lat2)*cos(lon1-lon2)); + double argacos = (sin(lat2)-sin(lat1)*cos(d))/(sin(d)*cos(lat1)); + double crs; + if (sin(lon2-lon1) < 0) + crs = acos(argacos); + else + crs = 2 * M_PI - acos(argacos); + *dist = d * earth_radius; + *bearing = crs * 180/M_PI; +} + +static void +aoview_state_add_deg(char *label, double deg) +{ + double int_part; + double min; + + int_part = floor (deg); + min = (deg - int_part) * 60.0; + aoview_table_add_row(label, "%d°%lf'", + (int) int_part, min); + } void @@ -112,8 +129,8 @@ aoview_state_notify(struct aostate *state) aoview_table_add_row("Pad altitude", "%dm", aoview_pres_to_altitude(pad_pres)); aoview_table_add_row("Satellites", "%d", state->nsat); if (state->locked) { - aoview_table_add_row("Lat", "%g", state->lat); - aoview_table_add_row("Lon", "%g", state->lon); + aoview_state_add_deg("Latitude", state->lat); + aoview_state_add_deg("Longitude", state->lon); aoview_table_add_row("GPS alt", "%d", state->alt); aoview_table_add_row("GPS time", "%02d:%02d:%02d", state->gps_time.hour, @@ -121,7 +138,8 @@ aoview_state_notify(struct aostate *state) state->gps_time.second); aoview_great_circle(pad_lat, pad_lon, state->lat, state->lon, &dist, &bearing); - aoview_table_add_row("Course", "%gkm %g°", dist, bearing); + aoview_table_add_row("Distance from pad", "%gm", dist * 1000); + aoview_table_add_row("Direction from pad", "%g°", bearing); } else { aoview_table_add_row("GPS", "unlocked"); } diff --git a/aoview/aoview_table.c b/aoview/aoview_table.c index 90deeb91..e55f8f50 100644 --- a/aoview/aoview_table.c +++ b/aoview/aoview_table.c @@ -57,6 +57,6 @@ aoview_table_init(GladeXML *xml) dataview = GTK_TREE_VIEW(glade_xml_get_widget(xml, "dataview")); assert(dataview); - aoview_add_plain_text_column(dataview, "Field", 0, 16); + aoview_add_plain_text_column(dataview, "Field", 0, 20); aoview_add_plain_text_column(dataview, "Value", 1, 32); } |