]>
Commit | Line | Data |
---|---|---|
50a14534 EB |
1 | /* |
2 | * viking -- GPS Data and Topo Analyzer, Explorer, and Manager | |
3 | * | |
4 | * Copyright (C) 2003-2005, Evan Battaglia <gtoevan@gmx.net> | |
5 | * | |
6 | * This program is free software; you can redistribute it and/or modify | |
7 | * it under the terms of the GNU General Public License as published by | |
8 | * the Free Software Foundation; either version 2 of the License, or | |
9 | * (at your option) any later version. | |
10 | * | |
11 | * This program is distributed in the hope that it will be useful, | |
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 | * GNU General Public License for more details. | |
15 | * | |
16 | * You should have received a copy of the GNU General Public License | |
17 | * along with this program; if not, write to the Free Software | |
18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
19 | * | |
20 | */ | |
21 | ||
4c77d5e0 GB |
22 | #ifdef HAVE_CONFIG_H |
23 | #include "config.h" | |
24 | #endif | |
25 | ||
50a14534 | 26 | #include <gtk/gtk.h> |
4c77d5e0 | 27 | #include <glib/gi18n.h> |
50a14534 | 28 | #include <time.h> |
86f7d733 | 29 | #include <math.h> |
50a14534 EB |
30 | |
31 | #include "coords.h" | |
32 | #include "vikcoord.h" | |
33 | #include "viktrack.h" | |
34 | #include "viktrwlayer_tpwin.h" | |
35 | #include "vikwaypoint.h" | |
36 | #include "dialog.h" | |
6f9336aa | 37 | #include "globals.h" |
50a14534 | 38 | |
50a14534 EB |
39 | struct _VikTrwLayerTpwin { |
40 | GtkDialog parent; | |
41 | GtkSpinButton *lat, *lon, *alt; | |
86f7d733 | 42 | GtkLabel *track_name, *course, *ts, *localtime, *diff_dist, *diff_time, *diff_speed, *speed, *hdop, *vdop, *pdop, *sat; |
2cada010 RN |
43 | // Previously these buttons were in a glist, however I think the ordering behaviour is implicit |
44 | // thus control manually to ensure operating on the correct button | |
45 | GtkWidget *button_close; | |
46 | GtkWidget *button_delete; | |
47 | GtkWidget *button_insert; | |
48 | GtkWidget *button_split; | |
49 | GtkWidget *button_back; | |
50 | GtkWidget *button_forward; | |
50a14534 | 51 | VikTrackpoint *cur_tp; |
50a14534 EB |
52 | gboolean sync_to_tp_block; |
53 | }; | |
54 | ||
55 | GType vik_trw_layer_tpwin_get_type (void) | |
56 | { | |
57 | static GType tpwin_type = 0; | |
58 | ||
59 | if (!tpwin_type) | |
60 | { | |
61 | static const GTypeInfo tpwin_info = | |
62 | { | |
63 | sizeof (VikTrwLayerTpwinClass), | |
64 | NULL, /* base_init */ | |
65 | NULL, /* base_finalize */ | |
66 | NULL, /* class init */ | |
67 | NULL, /* class_finalize */ | |
68 | NULL, /* class_data */ | |
69 | sizeof (VikTrwLayerTpwin), | |
70 | 0, | |
71 | NULL /* instance init */ | |
72 | }; | |
73 | tpwin_type = g_type_register_static ( GTK_TYPE_DIALOG, "VikTrwLayerTpwin", &tpwin_info, 0 ); | |
74 | } | |
75 | ||
76 | return tpwin_type; | |
77 | } | |
78 | ||
79 | static void tpwin_sync_ll_to_tp ( VikTrwLayerTpwin *tpwin ) | |
80 | { | |
81 | if ( tpwin->cur_tp && (!tpwin->sync_to_tp_block) ) | |
82 | { | |
83 | struct LatLon ll; | |
84 | VikCoord coord; | |
85 | ll.lat = gtk_spin_button_get_value ( tpwin->lat ); | |
86 | ll.lon = gtk_spin_button_get_value ( tpwin->lon ); | |
87 | vik_coord_load_from_latlon ( &coord, tpwin->cur_tp->coord.mode, &ll ); | |
88 | ||
89 | /* don't redraw unless we really have to */ | |
90 | if ( vik_coord_diff(&(tpwin->cur_tp->coord), &coord) > 0.05 ) /* may not be exact due to rounding */ | |
91 | { | |
92 | tpwin->cur_tp->coord = coord; | |
93 | gtk_dialog_response ( GTK_DIALOG(tpwin), VIK_TRW_LAYER_TPWIN_DATA_CHANGED ); | |
94 | } | |
95 | } | |
96 | } | |
97 | ||
98 | static void tpwin_sync_alt_to_tp ( VikTrwLayerTpwin *tpwin ) | |
99 | { | |
6027a9c5 RN |
100 | if ( tpwin->cur_tp && (!tpwin->sync_to_tp_block) ) { |
101 | // Always store internally in metres | |
102 | vik_units_height_t height_units = a_vik_get_units_height (); | |
103 | switch (height_units) { | |
104 | case VIK_UNITS_HEIGHT_METRES: | |
105 | tpwin->cur_tp->altitude = gtk_spin_button_get_value ( tpwin->alt ); | |
106 | break; | |
107 | case VIK_UNITS_HEIGHT_FEET: | |
ab1e0693 | 108 | tpwin->cur_tp->altitude = VIK_FEET_TO_METERS(gtk_spin_button_get_value ( tpwin->alt )); |
6027a9c5 RN |
109 | break; |
110 | default: | |
111 | tpwin->cur_tp->altitude = gtk_spin_button_get_value ( tpwin->alt ); | |
112 | g_critical("Houston, we've had a problem. height=%d", height_units); | |
113 | } | |
114 | } | |
50a14534 EB |
115 | } |
116 | ||
117 | VikTrwLayerTpwin *vik_trw_layer_tpwin_new ( GtkWindow *parent ) | |
118 | { | |
4c77d5e0 | 119 | static gchar *left_label_texts[] = { N_("<b>Part of Track:</b>"), |
86f7d733 | 120 | N_("<b>Latitude:</b>"), |
4c77d5e0 | 121 | N_("<b>Longitude:</b>"), |
86f7d733 RN |
122 | N_("<b>Altitude:</b>"), |
123 | N_("<b>Course:</b>"), | |
124 | N_("<b>Timestamp:</b>"), | |
125 | N_("<b>Time:</b>") }; | |
4c77d5e0 GB |
126 | static gchar *right_label_texts[] = { N_("<b>Distance Difference:</b>"), |
127 | N_("<b>Time Difference:</b>"), | |
86f7d733 RN |
128 | N_("<b>\"Speed\" Between:</b>"), |
129 | N_("<b>Speed:</b>"), | |
130 | N_("<b>VDOP:</b>"), | |
131 | N_("<b>HDOP:</b>"), | |
132 | N_("<b>PDOP:</b>"), | |
133 | N_("<b>SAT/FIX:</b>") }; | |
50a14534 EB |
134 | |
135 | VikTrwLayerTpwin *tpwin = VIK_TRW_LAYER_TPWIN ( g_object_new ( VIK_TRW_LAYER_TPWIN_TYPE, NULL ) ); | |
136 | GtkWidget *main_hbox, *left_vbox, *right_vbox; | |
137 | GtkWidget *diff_left_vbox, *diff_right_vbox; | |
138 | ||
139 | ||
140 | gtk_window_set_transient_for ( GTK_WINDOW(tpwin), parent ); | |
4c77d5e0 | 141 | gtk_window_set_title ( GTK_WINDOW(tpwin), _("Trackpoint") ); |
50a14534 | 142 | |
2cada010 RN |
143 | tpwin->button_close = gtk_dialog_add_button ( GTK_DIALOG(tpwin), GTK_STOCK_CLOSE, VIK_TRW_LAYER_TPWIN_CLOSE); |
144 | tpwin->button_insert = gtk_dialog_add_button ( GTK_DIALOG(tpwin), _("_Insert After"), VIK_TRW_LAYER_TPWIN_INSERT); | |
145 | tpwin->button_delete = gtk_dialog_add_button ( GTK_DIALOG(tpwin), GTK_STOCK_DELETE, VIK_TRW_LAYER_TPWIN_DELETE); | |
146 | tpwin->button_split = gtk_dialog_add_button ( GTK_DIALOG(tpwin), _("Split Here"), VIK_TRW_LAYER_TPWIN_SPLIT); | |
147 | tpwin->button_back = gtk_dialog_add_button ( GTK_DIALOG(tpwin), GTK_STOCK_GO_BACK, VIK_TRW_LAYER_TPWIN_BACK); | |
148 | tpwin->button_forward = gtk_dialog_add_button ( GTK_DIALOG(tpwin), GTK_STOCK_GO_FORWARD, VIK_TRW_LAYER_TPWIN_FORWARD); | |
149 | ||
150 | /* | |
50a14534 EB |
151 | gtk_dialog_add_buttons ( GTK_DIALOG(tpwin), |
152 | GTK_STOCK_CLOSE, VIK_TRW_LAYER_TPWIN_CLOSE, | |
2880a1de | 153 | _("_Insert After"), VIK_TRW_LAYER_TPWIN_INSERT, |
50a14534 | 154 | GTK_STOCK_DELETE, VIK_TRW_LAYER_TPWIN_DELETE, |
4c77d5e0 | 155 | _("Split Here"), VIK_TRW_LAYER_TPWIN_SPLIT, |
50a14534 EB |
156 | GTK_STOCK_GO_BACK, VIK_TRW_LAYER_TPWIN_BACK, |
157 | GTK_STOCK_GO_FORWARD, VIK_TRW_LAYER_TPWIN_FORWARD, | |
158 | NULL ); | |
159 | tpwin->buttons = gtk_container_get_children(GTK_CONTAINER(GTK_DIALOG(tpwin)->action_area)); | |
2cada010 | 160 | */ |
50a14534 EB |
161 | |
162 | /* main track info */ | |
86f7d733 | 163 | left_vbox = a_dialog_create_label_vbox ( left_label_texts, G_N_ELEMENTS(left_label_texts), 1, 3 ); |
50a14534 EB |
164 | |
165 | tpwin->track_name = GTK_LABEL(gtk_label_new(NULL)); | |
86f7d733 | 166 | tpwin->course = GTK_LABEL(gtk_label_new(NULL)); |
50a14534 EB |
167 | tpwin->ts = GTK_LABEL(gtk_label_new(NULL)); |
168 | tpwin->localtime = GTK_LABEL(gtk_label_new(NULL)); | |
169 | ||
170 | tpwin->lat = GTK_SPIN_BUTTON(gtk_spin_button_new( GTK_ADJUSTMENT(gtk_adjustment_new ( | |
171 | 0, -90, 90, 0.00005, 0.01, 0 )), 0.00005, 6)); | |
172 | tpwin->lon = GTK_SPIN_BUTTON(gtk_spin_button_new( GTK_ADJUSTMENT(gtk_adjustment_new ( | |
173 | 0, -180, 180, 0.00005, 0.01, 0 )), 0.00005, 6)); | |
174 | ||
175 | g_signal_connect_swapped ( G_OBJECT(tpwin->lat), "value-changed", G_CALLBACK(tpwin_sync_ll_to_tp), tpwin ); | |
176 | g_signal_connect_swapped ( G_OBJECT(tpwin->lon), "value-changed", G_CALLBACK(tpwin_sync_ll_to_tp), tpwin ); | |
177 | ||
178 | tpwin->alt = GTK_SPIN_BUTTON(gtk_spin_button_new( GTK_ADJUSTMENT(gtk_adjustment_new ( | |
179 | 0, -1000, 25000, 10, 100, 0 )), 10, 2)); | |
180 | ||
181 | g_signal_connect_swapped ( G_OBJECT(tpwin->alt), "value-changed", G_CALLBACK(tpwin_sync_alt_to_tp), tpwin ); | |
182 | ||
86f7d733 RN |
183 | right_vbox = gtk_vbox_new ( TRUE, 1 ); |
184 | gtk_box_pack_start ( GTK_BOX(right_vbox), GTK_WIDGET(tpwin->track_name), FALSE, FALSE, 3 ); | |
185 | gtk_box_pack_start ( GTK_BOX(right_vbox), GTK_WIDGET(tpwin->lat), FALSE, FALSE, 3 ); | |
186 | gtk_box_pack_start ( GTK_BOX(right_vbox), GTK_WIDGET(tpwin->lon), FALSE, FALSE, 3 ); | |
187 | gtk_box_pack_start ( GTK_BOX(right_vbox), GTK_WIDGET(tpwin->alt), FALSE, FALSE, 3 ); | |
188 | gtk_box_pack_start ( GTK_BOX(right_vbox), GTK_WIDGET(tpwin->course), FALSE, FALSE, 3 ); | |
189 | gtk_box_pack_start ( GTK_BOX(right_vbox), GTK_WIDGET(tpwin->ts), FALSE, FALSE, 3 ); | |
190 | gtk_box_pack_start ( GTK_BOX(right_vbox), GTK_WIDGET(tpwin->localtime), FALSE, FALSE, 3 ); | |
50a14534 EB |
191 | |
192 | /* diff info */ | |
86f7d733 | 193 | diff_left_vbox = a_dialog_create_label_vbox ( right_label_texts, G_N_ELEMENTS(right_label_texts), 1, 3 ); |
50a14534 EB |
194 | |
195 | tpwin->diff_dist = GTK_LABEL(gtk_label_new(NULL)); | |
196 | tpwin->diff_time = GTK_LABEL(gtk_label_new(NULL)); | |
197 | tpwin->diff_speed = GTK_LABEL(gtk_label_new(NULL)); | |
86f7d733 | 198 | tpwin->speed = GTK_LABEL(gtk_label_new(NULL)); |
50a14534 | 199 | |
4a42b254 T |
200 | tpwin->vdop = GTK_LABEL(gtk_label_new(NULL)); |
201 | tpwin->hdop = GTK_LABEL(gtk_label_new(NULL)); | |
202 | tpwin->pdop = GTK_LABEL(gtk_label_new(NULL)); | |
203 | tpwin->sat = GTK_LABEL(gtk_label_new(NULL)); | |
204 | ||
86f7d733 RN |
205 | diff_right_vbox = gtk_vbox_new ( TRUE, 1 ); |
206 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->diff_dist), FALSE, FALSE, 3 ); | |
207 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->diff_time), FALSE, FALSE, 3 ); | |
208 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->diff_speed), FALSE, FALSE, 3 ); | |
209 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->speed), FALSE, FALSE, 3 ); | |
50a14534 | 210 | |
86f7d733 RN |
211 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->vdop), FALSE, FALSE, 3 ); |
212 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->hdop), FALSE, FALSE, 3 ); | |
213 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->pdop), FALSE, FALSE, 3 ); | |
214 | gtk_box_pack_start ( GTK_BOX(diff_right_vbox), GTK_WIDGET(tpwin->sat), FALSE, FALSE, 3 ); | |
4a42b254 | 215 | |
bc748ef1 | 216 | main_hbox = gtk_hbox_new( FALSE, 0 ); |
50a14534 EB |
217 | gtk_box_pack_start ( GTK_BOX(main_hbox), left_vbox, TRUE, TRUE, 0 ); |
218 | gtk_box_pack_start ( GTK_BOX(main_hbox), right_vbox, TRUE, TRUE, 0 ); | |
219 | gtk_box_pack_start ( GTK_BOX(main_hbox), diff_left_vbox, TRUE, TRUE, 0 ); | |
220 | gtk_box_pack_start ( GTK_BOX(main_hbox), diff_right_vbox, TRUE, TRUE, 0 ); | |
221 | ||
9b082b39 | 222 | gtk_box_pack_start ( GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(tpwin))), main_hbox, FALSE, FALSE, 0 ); |
50a14534 EB |
223 | |
224 | tpwin->cur_tp = NULL; | |
225 | ||
226 | return tpwin; | |
227 | } | |
228 | ||
229 | void vik_trw_layer_tpwin_set_empty ( VikTrwLayerTpwin *tpwin ) | |
230 | { | |
231 | gtk_label_set_text ( tpwin->track_name, NULL ); | |
232 | gtk_label_set_text ( tpwin->ts, NULL ); | |
233 | gtk_label_set_text ( tpwin->localtime, NULL ); | |
86f7d733 | 234 | gtk_label_set_text ( tpwin->course, NULL ); |
50a14534 EB |
235 | |
236 | gtk_widget_set_sensitive ( GTK_WIDGET(tpwin->lat), FALSE ); | |
237 | gtk_widget_set_sensitive ( GTK_WIDGET(tpwin->lon), FALSE ); | |
238 | gtk_widget_set_sensitive ( GTK_WIDGET(tpwin->alt), FALSE ); | |
239 | ||
2cada010 RN |
240 | // Only keep close button enabled |
241 | gtk_widget_set_sensitive ( tpwin->button_insert, FALSE ); | |
242 | gtk_widget_set_sensitive ( tpwin->button_split, FALSE ); | |
243 | gtk_widget_set_sensitive ( tpwin->button_delete, FALSE ); | |
244 | gtk_widget_set_sensitive ( tpwin->button_back, FALSE ); | |
245 | gtk_widget_set_sensitive ( tpwin->button_forward, FALSE ); | |
246 | ||
50a14534 EB |
247 | gtk_label_set_text ( tpwin->diff_dist, NULL ); |
248 | gtk_label_set_text ( tpwin->diff_time, NULL ); | |
249 | gtk_label_set_text ( tpwin->diff_speed, NULL ); | |
86f7d733 | 250 | gtk_label_set_text ( tpwin->speed, NULL ); |
4a42b254 T |
251 | gtk_label_set_text ( tpwin->vdop, NULL ); |
252 | gtk_label_set_text ( tpwin->hdop, NULL ); | |
253 | gtk_label_set_text ( tpwin->pdop, NULL ); | |
254 | gtk_label_set_text ( tpwin->sat, NULL ); | |
50a14534 EB |
255 | } |
256 | ||
50a14534 EB |
257 | void vik_trw_layer_tpwin_set_tp ( VikTrwLayerTpwin *tpwin, GList *tpl, gchar *track_name ) |
258 | { | |
fff4e5e3 | 259 | static char tmp_str[64]; |
50a14534 EB |
260 | static struct LatLon ll; |
261 | VikTrackpoint *tp = VIK_TRACKPOINT(tpl->data); | |
262 | ||
2880a1de | 263 | /* Only can insert if not at the end (otherwise use extend track) */ |
2cada010 RN |
264 | gtk_widget_set_sensitive ( tpwin->button_insert, (gboolean) GPOINTER_TO_INT (tpl->next) ); |
265 | gtk_widget_set_sensitive ( tpwin->button_delete, TRUE ); | |
50a14534 EB |
266 | |
267 | /* We can only split up a track if it's not an endpoint. Makes sense to me. */ | |
2cada010 | 268 | gtk_widget_set_sensitive ( tpwin->button_split, tpl->next && tpl->prev ); |
50a14534 | 269 | |
2cada010 RN |
270 | gtk_widget_set_sensitive ( tpwin->button_forward, (gboolean) GPOINTER_TO_INT (tpl->next) ); |
271 | gtk_widget_set_sensitive ( tpwin->button_back, (gboolean) GPOINTER_TO_INT (tpl->prev) ); | |
50a14534 | 272 | |
50a14534 EB |
273 | gtk_widget_set_sensitive ( GTK_WIDGET(tpwin->lat), TRUE ); |
274 | gtk_widget_set_sensitive ( GTK_WIDGET(tpwin->lon), TRUE ); | |
21a4eb5f | 275 | gtk_widget_set_sensitive ( GTK_WIDGET(tpwin->alt), TRUE ); |
50a14534 EB |
276 | |
277 | gtk_label_set_text ( tpwin->track_name, track_name ); | |
278 | ||
279 | tpwin->sync_to_tp_block = TRUE; /* don't update while setting data. */ | |
280 | ||
281 | vik_coord_to_latlon ( &(tp->coord), &ll ); | |
282 | gtk_spin_button_set_value ( tpwin->lat, ll.lat ); | |
283 | gtk_spin_button_set_value ( tpwin->lon, ll.lon ); | |
6027a9c5 RN |
284 | vik_units_height_t height_units = a_vik_get_units_height (); |
285 | switch (height_units) { | |
286 | case VIK_UNITS_HEIGHT_METRES: | |
287 | gtk_spin_button_set_value ( tpwin->alt, tp->altitude ); | |
288 | break; | |
289 | case VIK_UNITS_HEIGHT_FEET: | |
6c20e59a | 290 | gtk_spin_button_set_value ( tpwin->alt, VIK_METERS_TO_FEET(tp->altitude) ); |
6027a9c5 RN |
291 | break; |
292 | default: | |
293 | gtk_spin_button_set_value ( tpwin->alt, tp->altitude ); | |
294 | g_critical("Houston, we've had a problem. height=%d", height_units); | |
295 | } | |
296 | ||
50a14534 EB |
297 | |
298 | tpwin->sync_to_tp_block = FALSE; /* don't update whlie setting data. */ | |
299 | ||
300 | ||
301 | if ( tp->has_timestamp ) | |
302 | { | |
303 | g_snprintf ( tmp_str, sizeof(tmp_str), "%ld", tp->timestamp ); | |
304 | gtk_label_set_text ( tpwin->ts, tmp_str ); | |
22b669cf | 305 | strftime ( tmp_str, sizeof(tmp_str), "%c", localtime(&(tp->timestamp)) ); |
50a14534 EB |
306 | gtk_label_set_text ( tpwin->localtime, tmp_str ); |
307 | } | |
308 | else | |
309 | { | |
310 | gtk_label_set_text (tpwin->ts, NULL ); | |
311 | gtk_label_set_text (tpwin->localtime, NULL ); | |
312 | } | |
313 | ||
86f7d733 | 314 | vik_units_speed_t speed_units = a_vik_get_units_speed (); |
6f9336aa | 315 | vik_units_distance_t dist_units = a_vik_get_units_distance (); |
50a14534 EB |
316 | if ( tpwin->cur_tp ) |
317 | { | |
6f9336aa RN |
318 | switch (dist_units) { |
319 | case VIK_UNITS_DISTANCE_KILOMETRES: | |
320 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f m", vik_coord_diff(&(tp->coord), &(tpwin->cur_tp->coord))); | |
321 | break; | |
322 | case VIK_UNITS_DISTANCE_MILES: | |
323 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f yards", vik_coord_diff(&(tp->coord), &(tpwin->cur_tp->coord))*1.0936133); | |
324 | break; | |
325 | default: | |
326 | g_critical("Houston, we've had a problem. distance=%d", dist_units); | |
327 | } | |
328 | ||
50a14534 EB |
329 | gtk_label_set_text ( tpwin->diff_dist, tmp_str ); |
330 | if ( tp->has_timestamp && tpwin->cur_tp->has_timestamp ) | |
331 | { | |
332 | g_snprintf ( tmp_str, sizeof(tmp_str), "%ld s", tp->timestamp - tpwin->cur_tp->timestamp); | |
333 | gtk_label_set_text ( tpwin->diff_time, tmp_str ); | |
334 | if ( tp->timestamp == tpwin->cur_tp->timestamp ) | |
335 | gtk_label_set_text ( tpwin->diff_speed, "--" ); | |
336 | else | |
337 | { | |
13bdea80 RN |
338 | switch (speed_units) { |
339 | case VIK_UNITS_SPEED_KILOMETRES_PER_HOUR: | |
ab1e0693 | 340 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f km/h", VIK_MPS_TO_KPH(vik_coord_diff(&(tp->coord), &(tpwin->cur_tp->coord)) / (ABS(tp->timestamp - tpwin->cur_tp->timestamp))) ); |
13bdea80 RN |
341 | break; |
342 | case VIK_UNITS_SPEED_MILES_PER_HOUR: | |
ab1e0693 | 343 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f mph", VIK_MPS_TO_MPH(vik_coord_diff(&(tp->coord), &(tpwin->cur_tp->coord)) / (ABS(tp->timestamp - tpwin->cur_tp->timestamp))) ); |
13bdea80 RN |
344 | break; |
345 | case VIK_UNITS_SPEED_METRES_PER_SECOND: | |
346 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f m/s", vik_coord_diff(&(tp->coord), &(tpwin->cur_tp->coord)) / ABS(tp->timestamp - tpwin->cur_tp->timestamp) ); | |
347 | break; | |
a4c92313 | 348 | case VIK_UNITS_SPEED_KNOTS: |
ab1e0693 | 349 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f knots", VIK_MPS_TO_KNOTS(vik_coord_diff(&(tp->coord), &(tpwin->cur_tp->coord)) / (ABS(tp->timestamp - tpwin->cur_tp->timestamp))) ); |
a4c92313 | 350 | break; |
13bdea80 RN |
351 | default: |
352 | g_snprintf ( tmp_str, sizeof(tmp_str), "--" ); | |
353 | g_critical("Houston, we've had a problem. speed=%d", speed_units); | |
354 | } | |
50a14534 EB |
355 | gtk_label_set_text ( tpwin->diff_speed, tmp_str ); |
356 | } | |
357 | } | |
358 | else | |
359 | { | |
360 | gtk_label_set_text ( tpwin->diff_time, NULL ); | |
361 | gtk_label_set_text ( tpwin->diff_speed, NULL ); | |
362 | } | |
363 | } | |
364 | ||
86f7d733 RN |
365 | if ( isnan(tp->course) ) |
366 | g_snprintf ( tmp_str, sizeof(tmp_str), "--" ); | |
367 | else | |
368 | g_snprintf ( tmp_str, sizeof(tmp_str), "%05.1f\302\260", tp->course ); | |
369 | gtk_label_set_text ( tpwin->course, tmp_str ); | |
370 | ||
371 | if ( isnan(tp->speed) ) | |
372 | g_snprintf ( tmp_str, sizeof(tmp_str), "--" ); | |
373 | else { | |
374 | switch (speed_units) { | |
375 | case VIK_UNITS_SPEED_MILES_PER_HOUR: | |
376 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f mph", VIK_MPS_TO_MPH(tp->speed) ); | |
377 | break; | |
378 | case VIK_UNITS_SPEED_METRES_PER_SECOND: | |
379 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f m/s", tp->speed ); | |
380 | break; | |
381 | case VIK_UNITS_SPEED_KNOTS: | |
382 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f knots", VIK_MPS_TO_KNOTS(tp->speed) ); | |
383 | break; | |
384 | default: | |
385 | // VIK_UNITS_SPEED_KILOMETRES_PER_HOUR: | |
386 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.2f km/h", VIK_MPS_TO_KPH(tp->speed) ); | |
387 | break; | |
388 | } | |
389 | } | |
390 | gtk_label_set_text ( tpwin->speed, tmp_str ); | |
391 | ||
6f9336aa RN |
392 | switch (dist_units) { |
393 | case VIK_UNITS_DISTANCE_KILOMETRES: | |
394 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.5f m", tp->hdop ); | |
395 | gtk_label_set_text ( tpwin->hdop, tmp_str ); | |
396 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.5f m", tp->pdop ); | |
397 | gtk_label_set_text ( tpwin->pdop, tmp_str ); | |
398 | break; | |
399 | case VIK_UNITS_DISTANCE_MILES: | |
400 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.5f yards", tp->hdop*1.0936133 ); | |
401 | gtk_label_set_text ( tpwin->hdop, tmp_str ); | |
402 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.5f yards", tp->pdop*1.0936133 ); | |
403 | gtk_label_set_text ( tpwin->pdop, tmp_str ); | |
404 | break; | |
405 | default: | |
406 | g_critical("Houston, we've had a problem. distance=%d", dist_units); | |
407 | } | |
6027a9c5 RN |
408 | |
409 | switch (height_units) { | |
410 | case VIK_UNITS_HEIGHT_METRES: | |
411 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.5f m", tp->vdop ); | |
412 | break; | |
413 | case VIK_UNITS_HEIGHT_FEET: | |
6c20e59a | 414 | g_snprintf ( tmp_str, sizeof(tmp_str), "%.5f feet", VIK_METERS_TO_FEET(tp->vdop) ); |
6027a9c5 RN |
415 | break; |
416 | default: | |
417 | g_snprintf ( tmp_str, sizeof(tmp_str), "--" ); | |
418 | g_critical("Houston, we've had a problem. height=%d", height_units); | |
419 | } | |
b24a25f4 | 420 | gtk_label_set_text ( tpwin->vdop, tmp_str ); |
6027a9c5 | 421 | |
b24a25f4 T |
422 | g_snprintf ( tmp_str, sizeof(tmp_str), "%d / %d", tp->nsats, tp->fix_mode ); |
423 | gtk_label_set_text ( tpwin->sat, tmp_str ); | |
eb790888 RN |
424 | |
425 | tpwin->cur_tp = tp; | |
50a14534 EB |
426 | } |
427 | ||
428 | void vik_trw_layer_tpwin_set_track_name ( VikTrwLayerTpwin *tpwin, const gchar *track_name ) | |
429 | { | |
430 | gtk_label_set_text ( tpwin->track_name, track_name ); | |
431 | } |