35 |
|
|
36 |
extern char *strcasestr (__const char *__haystack, __const char *__needle); |
extern char *strcasestr (__const char *__haystack, __const char *__needle); |
37 |
|
|
38 |
#ifdef USE_BREAD_CRUMB_TRAIL |
#if defined(USE_BREAD_CRUMB_TRAIL) || defined(BCT) |
39 |
static void crumb_add(appdata_t *appdata, char *name, int level, |
static void crumb_add(appdata_t *appdata, char *name, int level, |
40 |
gpointer user_data); |
gpointer user_data); |
41 |
|
|
95 |
GtkWidget *dialog = gtk_message_dialog_new( |
GtkWidget *dialog = gtk_message_dialog_new( |
96 |
GTK_WINDOW(NULL), |
GTK_WINDOW(NULL), |
97 |
GTK_DIALOG_DESTROY_WITH_PARENT, |
GTK_DIALOG_DESTROY_WITH_PARENT, |
98 |
GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, |
#if !defined(USE_MAEMO) || (MAEMO_VERSION_MAJOR < 5) |
99 |
buf); |
GTK_MESSAGE_ERROR, |
100 |
|
#else |
101 |
|
GTK_MESSAGE_OTHER, |
102 |
|
#endif |
103 |
|
GTK_BUTTONS_CLOSE, buf); |
104 |
|
|
105 |
gtk_window_set_title(GTK_WINDOW(dialog), _("ERROR")); |
gtk_window_set_title(GTK_WINDOW(dialog), _("ERROR")); |
106 |
|
|
124 |
HELP_ID_IMPORT, appdata->osso_context); |
HELP_ID_IMPORT, appdata->osso_context); |
125 |
#endif |
#endif |
126 |
#else |
#else |
127 |
dialog = gtk_file_chooser_dialog_new (whole_dir?_("Open Directory"): |
dialog = gtk_file_chooser_dialog_new (whole_dir?_("Import directory"): |
128 |
_("Open File"), |
_("Import file"), |
129 |
GTK_WINDOW(appdata->window), |
GTK_WINDOW(appdata->window), |
130 |
whole_dir?GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER : |
whole_dir?GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER : |
131 |
GTK_FILE_CHOOSER_ACTION_OPEN, |
GTK_FILE_CHOOSER_ACTION_OPEN, |
142 |
gtk_widget_show_all (GTK_WIDGET(dialog)); |
gtk_widget_show_all (GTK_WIDGET(dialog)); |
143 |
if (gtk_dialog_run (GTK_DIALOG(dialog)) == GTK_FM_OK) { |
if (gtk_dialog_run (GTK_DIALOG(dialog)) == GTK_FM_OK) { |
144 |
char *filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog)); |
char *filename = gtk_file_chooser_get_filename (GTK_FILE_CHOOSER (dialog)); |
145 |
|
|
146 |
|
if(filename) { |
147 |
|
gpx_dialog_t *dialog = gpx_busy_dialog_new(GTK_WIDGET(appdata->window)); |
148 |
|
|
149 |
gpx_dialog_t *dialog = gpx_busy_dialog_new(GTK_WIDGET(appdata->window)); |
if(!whole_dir) |
150 |
|
gpx = gpx_parse(dialog, filename); |
151 |
if(!whole_dir) |
else { |
152 |
gpx = gpx_parse(dialog, filename); |
/* cur trailing '/' if present */ |
153 |
else { |
if(strlastchr(filename) == '/') |
154 |
/* cur trailing '/' if present */ |
filename[strlen(filename)] = 0; |
155 |
if(strlastchr(filename) == '/') |
|
156 |
filename[strlen(filename)] = 0; |
gpx = gpx_parse_dir(dialog, filename); |
|
|
|
|
gpx = gpx_parse_dir(dialog, filename); |
|
|
} |
|
|
|
|
|
gpx_busy_dialog_destroy(dialog); |
|
|
|
|
|
/* save path if gpx was successfully loaded */ |
|
|
if(gpx) { |
|
|
char *r = strrchr(filename, '/'); |
|
|
|
|
|
/* there is a delimiter, use everything left of it as path */ |
|
|
if(r && !whole_dir) { |
|
|
*r = 0; |
|
|
if(appdata->path) free(appdata->path); |
|
|
appdata->path = strdup(filename); |
|
|
/* restore path ... just in case ... */ |
|
|
*r = '/'; |
|
157 |
} |
} |
158 |
|
|
159 |
|
gpx_busy_dialog_destroy(dialog); |
160 |
|
|
161 |
|
/* save path if gpx was successfully loaded */ |
162 |
|
if(gpx) { |
163 |
|
char *r = strrchr(filename, '/'); |
164 |
|
|
165 |
|
/* there is a delimiter, use everything left of it as path */ |
166 |
|
if(r && !whole_dir) { |
167 |
|
*r = 0; |
168 |
|
if(appdata->path) free(appdata->path); |
169 |
|
appdata->path = strdup(filename); |
170 |
|
/* restore path ... just in case ... */ |
171 |
|
*r = '/'; |
172 |
|
} |
173 |
|
|
174 |
|
if(whole_dir) |
175 |
|
appdata->path = strdup(filename); |
176 |
|
} else |
177 |
|
errorf(_("Load error")); |
178 |
|
|
179 |
if(whole_dir) |
g_free (filename); |
180 |
appdata->path = strdup(filename); |
} else { |
181 |
|
#ifndef USE_MAEMO |
182 |
|
errorf(_("Error accessing the file.")); |
183 |
|
#else |
184 |
|
errorf(_("Error accessing the file. This may happen if the file " |
185 |
|
"resides on a remote file system. Please copy the file onto " |
186 |
|
"the device (e.g. onto the memory card) and try again.")); |
187 |
|
#endif |
188 |
} |
} |
|
|
|
|
g_free (filename); |
|
189 |
} |
} |
190 |
|
|
191 |
gtk_widget_destroy (dialog); |
gtk_widget_destroy (dialog); |
217 |
GtkTreeIter iter; |
GtkTreeIter iter; |
218 |
GtkTreeModel *model = gtk_tree_view_get_model(treeview); |
GtkTreeModel *model = gtk_tree_view_get_model(treeview); |
219 |
|
|
220 |
|
#ifdef USE_MAEMO |
221 |
|
/* check if a cache is already selected and ignore click if yes */ |
222 |
|
/* (was probably a double click) */ |
223 |
|
if(appdata->cur_cache) return; |
224 |
|
#endif |
225 |
|
|
226 |
if(gtk_tree_model_get_iter(model, &iter, path)) { |
if(gtk_tree_model_get_iter(model, &iter, path)) { |
227 |
cache_t *cache; |
cache_t *cache; |
228 |
gtk_tree_model_get(model, &iter, CACHELIST_COL_DATA, &cache, -1); |
gtk_tree_model_get(model, &iter, CACHELIST_COL_DATA, &cache, -1); |
229 |
#ifndef USE_BREAD_CRUMB_TRAIL |
#if !defined(USE_BREAD_CRUMB_TRAIL) && !defined(BCT) |
230 |
cache_dialog(appdata, cache); |
cache_dialog(appdata, cache); |
231 |
#else |
#else |
232 |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
278 |
cache_t *sel_cache); |
cache_t *sel_cache); |
279 |
|
|
280 |
void cachelist_redraw(appdata_t *appdata) { |
void cachelist_redraw(appdata_t *appdata) { |
281 |
#ifndef USE_MAEMO |
if(!appdata->cur_view) { |
282 |
// gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
printf("cachelist redraw: no active view\n"); |
283 |
// appdata->cur_view = gpxlist_create_view_and_model(appdata, NULL); |
return; |
284 |
// gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view); |
} |
|
// gtk_widget_show_all(appdata->vbox); |
|
|
#else |
|
285 |
|
|
286 |
g_assert(!appdata->cur_cache); |
g_assert(!appdata->cur_cache); |
287 |
int redraw = 0; |
int redraw = 0; |
293 |
} |
} |
294 |
|
|
295 |
if(redraw) { |
if(redraw) { |
296 |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
GtkWidget *container = appdata->vbox; |
297 |
|
|
298 |
|
#ifdef USE_STACKABLE_WINDOW |
299 |
|
HildonWindowStack *stack = hildon_window_stack_get_default(); |
300 |
|
container = hildon_window_stack_peek(stack); |
301 |
|
#endif |
302 |
|
|
303 |
|
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
304 |
switch(redraw) { |
switch(redraw) { |
305 |
case 1: |
case 1: |
306 |
appdata->cur_view = cachelist_create(appdata, |
appdata->cur_view = cachelist_create(appdata, |
312 |
break; |
break; |
313 |
} |
} |
314 |
|
|
315 |
gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view); |
#ifdef USE_STACKABLE_WINDOW |
316 |
gtk_widget_show_all(appdata->vbox); |
if(container != appdata->vbox) |
317 |
} |
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
318 |
|
else |
319 |
#endif |
#endif |
320 |
|
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
321 |
|
|
322 |
|
gtk_widget_show_all(container); |
323 |
|
} |
324 |
} |
} |
325 |
|
|
326 |
|
|
328 |
|
|
329 |
printf("cachelist timer fired!\n"); |
printf("cachelist timer fired!\n"); |
330 |
|
|
|
#ifdef USE_MAEMO |
|
331 |
appdata_t *appdata = (appdata_t*)data; |
appdata_t *appdata = (appdata_t*)data; |
332 |
|
|
333 |
|
if(appdata->cur_cache) |
334 |
|
return TRUE; |
335 |
|
|
336 |
|
#ifdef USE_MAEMO |
337 |
if(appdata->cachelist_disable_screensaver) |
if(appdata->cachelist_disable_screensaver) |
338 |
if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK) |
if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK) |
339 |
fprintf(stderr, "error with display blank\n"); |
fprintf(stderr, "error with display blank\n"); |
340 |
|
#endif |
341 |
|
|
342 |
if(appdata->cachelist_update) |
if(appdata->cachelist_update) |
343 |
cachelist_redraw(appdata); |
cachelist_redraw(appdata); |
|
#endif |
|
344 |
|
|
345 |
return TRUE; |
return TRUE; |
346 |
} |
} |
347 |
|
|
348 |
static void cachelist_timer_reset(appdata_t *appdata) { |
static void cachelist_timer_reset(appdata_t *appdata) { |
349 |
|
printf("cachelist timer reset\n"); |
350 |
g_assert(appdata->cachelist_handler_id); |
g_assert(appdata->cachelist_handler_id); |
351 |
gtk_timeout_remove(appdata->cachelist_handler_id); |
gtk_timeout_remove(appdata->cachelist_handler_id); |
352 |
appdata->cachelist_handler_id = |
appdata->cachelist_handler_id = |
578 |
} |
} |
579 |
#else |
#else |
580 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
581 |
|
static void search_result_free(gpx_t *result); |
582 |
|
|
583 |
|
void on_cachelist_destroy(GtkWidget *widget, appdata_t *appdata) { |
584 |
|
if(appdata->search_results) { |
585 |
|
search_result_free(appdata->search_results); |
586 |
|
appdata->search_results = NULL; |
587 |
|
} |
588 |
|
appdata->cur_gpx = NULL; |
589 |
|
|
590 |
|
#ifdef ENABLE_OSM_GPS_MAP |
591 |
|
map_update(appdata); |
592 |
|
#endif |
593 |
|
|
594 |
|
/* restore cur_view */ |
595 |
|
appdata->cur_view = g_object_get_data(G_OBJECT(widget), "cur_view"); |
596 |
|
} |
597 |
|
|
598 |
void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) { |
void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) { |
599 |
GtkWidget *window = hildon_stackable_window_new(); |
GtkWidget *window = hildon_stackable_window_new(); |
600 |
|
|
601 |
gtk_window_set_title(GTK_WINDOW(window), gpx->name); |
/* store last "cur_view" in window */ |
602 |
|
g_object_set_data(G_OBJECT(window), "cur_view", appdata->cur_view); |
603 |
|
|
604 |
gtk_container_add(GTK_CONTAINER(window), |
appdata->cur_gpx = gpx; |
605 |
cachelist_create(appdata, gpx, NULL)); |
char *title = g_strdup_printf("%s - GPXView", gpx->name); |
606 |
|
gtk_window_set_title(GTK_WINDOW(window), title); |
607 |
|
g_free(title); |
608 |
|
|
609 |
|
appdata->cur_view = cachelist_create(appdata, gpx, NULL); |
610 |
|
gtk_container_add(GTK_CONTAINER(window), appdata->cur_view); |
611 |
|
|
612 |
|
|
613 |
hildon_window_set_app_menu(HILDON_WINDOW(window), |
hildon_window_set_app_menu(HILDON_WINDOW(window), |
614 |
menu_create(appdata, MENU_CACHELIST)); |
menu_create(appdata, MENU_CACHELIST)); |
615 |
|
|
616 |
|
g_signal_connect(G_OBJECT(window), "destroy", |
617 |
|
G_CALLBACK(on_cachelist_destroy), appdata); |
618 |
|
|
619 |
gtk_widget_show_all(window); |
gtk_widget_show_all(window); |
620 |
|
|
621 |
|
#ifdef ENABLE_OSM_GPS_MAP |
622 |
|
map_update(appdata); |
623 |
|
#endif |
624 |
} |
} |
625 |
#endif |
#endif |
626 |
#endif |
#endif |
732 |
GtkTreeIter iter; |
GtkTreeIter iter; |
733 |
GtkTreeModel *model = gtk_tree_view_get_model(treeview); |
GtkTreeModel *model = gtk_tree_view_get_model(treeview); |
734 |
|
|
735 |
|
#ifdef USE_MAEMO |
736 |
|
/* check if a cache is already selected and ignore click if yes */ |
737 |
|
/* (was probably a double click) */ |
738 |
|
if(appdata->cur_gpx) return; |
739 |
|
#endif |
740 |
|
|
741 |
if (gtk_tree_model_get_iter(model, &iter, path)) { |
if (gtk_tree_model_get_iter(model, &iter, path)) { |
742 |
gpx_t *gpx; |
gpx_t *gpx; |
743 |
gtk_tree_model_get(model, &iter, GPXLIST_COL_DATA, &gpx, -1); |
gtk_tree_model_get(model, &iter, GPXLIST_COL_DATA, &gpx, -1); |
754 |
GtkWidget *dialog = gtk_message_dialog_new( |
GtkWidget *dialog = gtk_message_dialog_new( |
755 |
GTK_WINDOW(appdata->window), |
GTK_WINDOW(appdata->window), |
756 |
GTK_DIALOG_DESTROY_WITH_PARENT, |
GTK_DIALOG_DESTROY_WITH_PARENT, |
757 |
GTK_MESSAGE_QUESTION, GTK_BUTTONS_CANCEL, |
/* this doesn't fix the text selection issues ... */ |
758 |
|
#if defined(USE_MAEMO) && (MAEMO_VERSION_MAJOR >=5) |
759 |
|
GTK_MESSAGE_OTHER, |
760 |
|
#else |
761 |
|
GTK_MESSAGE_QUESTION, |
762 |
|
#endif |
763 |
|
GTK_BUTTONS_CANCEL, |
764 |
_("Do you want to close this entry only or do " |
_("Do you want to close this entry only or do " |
765 |
"you want to remove it completely from the list?")); |
"you want to remove it completely from the list?")); |
766 |
|
|
772 |
if(gpx->closed) |
if(gpx->closed) |
773 |
gtk_dialog_set_response_sensitive(GTK_DIALOG(dialog), 2, FALSE); |
gtk_dialog_set_response_sensitive(GTK_DIALOG(dialog), 2, FALSE); |
774 |
|
|
775 |
gtk_window_set_title(GTK_WINDOW(dialog), _("Remove entry?")); |
gtk_window_set_title(GTK_WINDOW(dialog), _("Close or remove entry?")); |
776 |
|
|
777 |
/* set the active flag again if the user answered "no" */ |
/* set the active flag again if the user answered "no" */ |
778 |
switch(gtk_dialog_run(GTK_DIALOG(dialog))) { |
switch(gtk_dialog_run(GTK_DIALOG(dialog))) { |
841 |
|
|
842 |
gpx_busy_dialog_destroy(dialog); |
gpx_busy_dialog_destroy(dialog); |
843 |
} |
} |
844 |
#ifndef USE_BREAD_CRUMB_TRAIL |
#if !defined(USE_BREAD_CRUMB_TRAIL) && !defined(BCT) |
845 |
cachelist_dialog(appdata, gpx); |
#ifdef USE_STACKABLE_WINDOW |
846 |
|
if(!appdata->cur_gpx) |
847 |
|
#endif |
848 |
|
cachelist_dialog(appdata, gpx); |
849 |
|
#ifdef USE_STACKABLE_WINDOW |
850 |
|
else |
851 |
|
printf("selected gpx, but cachelist window already present\n"); |
852 |
|
#endif |
853 |
#else |
#else |
854 |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
855 |
appdata->cur_view = cachelist_create(appdata, gpx, NULL); |
appdata->cur_view = cachelist_create(appdata, gpx, NULL); |
988 |
GtkTreeIter iter; |
GtkTreeIter iter; |
989 |
gtk_list_store_append(appdata->gpxstore, &iter); |
gtk_list_store_append(appdata->gpxstore, &iter); |
990 |
gpxlist_set(appdata->gpxstore, &iter, gpx); |
gpxlist_set(appdata->gpxstore, &iter, gpx); |
991 |
|
|
992 |
if(gpx == sel_gpx) { |
if(gpx == sel_gpx) { |
993 |
sel_iter = iter; |
sel_iter = iter; |
994 |
sel_iter_valid = TRUE; |
sel_iter_valid = TRUE; |
1048 |
|
|
1049 |
/******************** begin of menu *********************/ |
/******************** begin of menu *********************/ |
1050 |
|
|
1051 |
|
typedef struct { |
1052 |
|
appdata_t *appdata; |
1053 |
|
GtkWidget *dialog; |
1054 |
|
} about_context_t; |
1055 |
|
|
1056 |
|
#ifdef ENABLE_BROWSER_INTERFACE |
1057 |
|
void on_paypal_button_clicked(GtkButton *button, about_context_t *context) { |
1058 |
|
gtk_dialog_response(GTK_DIALOG(context->dialog), GTK_RESPONSE_ACCEPT); |
1059 |
|
browser_url(context->appdata, |
1060 |
|
"https://www.paypal.com/cgi-bin/webscr" |
1061 |
|
"?cmd=_s-xclick&hosted_button_id=7400558"); |
1062 |
|
} |
1063 |
|
#endif |
1064 |
|
|
1065 |
static void |
static void |
1066 |
cb_menu_about(GtkWidget *window, gpointer data) { |
cb_menu_about(GtkWidget *window, gpointer data) { |
1067 |
GtkAboutDialog *about = GTK_ABOUT_DIALOG(gtk_about_dialog_new()); |
about_context_t context; |
1068 |
|
|
1069 |
|
context.appdata = (appdata_t *)data; |
1070 |
|
|
1071 |
gtk_about_dialog_set_name(about, "GPXView"); |
#ifdef ENABLE_LIBLOCATION |
1072 |
gtk_about_dialog_set_version(about, VERSION); |
char *uses = "uses liblocation"; |
1073 |
gtk_about_dialog_set_copyright(about, |
#elif defined(ENABLE_GPSBT) |
1074 |
_("GPXView (c) 2008 by\n" |
char *uses = "uses gpsbt and gpsd"; |
1075 |
"Till Harbaum <till@harbaum.org>\n" |
#else |
1076 |
"Geocaching.com: Tantil")); |
char *uses = "uses gpsd"; |
1077 |
|
#endif |
1078 |
gtk_about_dialog_set_website(about, |
|
1079 |
_("http://www.harbaum.org/till/maemo")); |
const gchar *authors[] = { |
1080 |
|
"Till Harbaum <till@harbaum.org>", |
1081 |
gtk_about_dialog_set_comments(about, |
"John Stowers <john.stowers@gmail.com>", |
1082 |
_("Geocaching.com GPX file viewer")); |
NULL }; |
1083 |
|
|
1084 |
gtk_widget_show_all(GTK_WIDGET(about)); |
context.dialog = g_object_new(GTK_TYPE_ABOUT_DIALOG, |
1085 |
gtk_dialog_run(GTK_DIALOG(about)); |
"name", "GPXView", |
1086 |
gtk_widget_destroy(GTK_WIDGET(about)); |
"version", VERSION, |
1087 |
|
"copyright", _("Copyright 2008-2009"), |
1088 |
|
"authors", authors, |
1089 |
|
"website", _("http://www.harbaum.org/till/maemo"), |
1090 |
|
"comments", _(uses), |
1091 |
|
NULL); |
1092 |
|
|
1093 |
|
#ifdef ENABLE_BROWSER_INTERFACE |
1094 |
|
/* add a way to donate to the project */ |
1095 |
|
GtkWidget *alignment = gtk_alignment_new(0.5, 0, 0, 0); |
1096 |
|
|
1097 |
|
GtkWidget *hbox = gtk_hbox_new(FALSE, 8); |
1098 |
|
gtk_box_pack_start(GTK_BOX(hbox), |
1099 |
|
gtk_label_new(_("Do you like GPXView?")), |
1100 |
|
FALSE, FALSE, 0); |
1101 |
|
|
1102 |
|
GtkWidget *button = gtk_button_new(); |
1103 |
|
gtk_button_set_image(GTK_BUTTON(button), |
1104 |
|
icon_get_widget(ICON_MISC, 8)); |
1105 |
|
gtk_button_set_relief(GTK_BUTTON(button), GTK_RELIEF_NONE); |
1106 |
|
g_signal_connect(button, "clicked", |
1107 |
|
G_CALLBACK(on_paypal_button_clicked), &context); |
1108 |
|
gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, FALSE, 0); |
1109 |
|
|
1110 |
|
gtk_container_add(GTK_CONTAINER(alignment), hbox); |
1111 |
|
gtk_box_pack_start_defaults(GTK_BOX((GTK_DIALOG(context.dialog))->vbox), |
1112 |
|
alignment); |
1113 |
|
|
1114 |
|
gtk_widget_show_all(alignment); |
1115 |
|
#endif |
1116 |
|
|
1117 |
|
gtk_dialog_run(GTK_DIALOG(context.dialog)); |
1118 |
|
gtk_widget_destroy(context.dialog); |
1119 |
} |
} |
1120 |
|
|
1121 |
#if defined(USE_MAEMO) && defined(HILDON_HELP) |
#if defined(USE_MAEMO) && defined(HILDON_HELP) |
1461 |
/* don't search if we are asked to search for nothing */ |
/* don't search if we are asked to search for nothing */ |
1462 |
if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) && |
if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) && |
1463 |
strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) { |
strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) { |
|
gpx_t *found = NULL; |
|
1464 |
|
|
1465 |
printf("Search for %s (flags = %x)...\n", p, appdata->search); |
printf("Search for %s (flags = %x)...\n", p, appdata->search); |
1466 |
|
|
1467 |
#ifndef USE_BREAD_CRUMB_TRAIL |
#if !defined(USE_BREAD_CRUMB_TRAIL) && !defined(BCT) |
1468 |
found = search_do(appdata, appdata->gpx, p, appdata->search, FALSE); |
gpx_t *found = |
1469 |
|
search_do(appdata, appdata->gpx, p, appdata->search, FALSE); |
1470 |
|
|
1471 |
/* do search result dialog here ... */ |
/* do search result dialog here ... */ |
1472 |
cachelist_dialog(appdata, found); |
cachelist_dialog(appdata, found); |
1473 |
|
#ifndef USE_STACKABLE_WINDOW |
1474 |
search_result_free(found); |
search_result_free(found); |
1475 |
#else |
#else |
1476 |
|
appdata->search_results = found; |
1477 |
|
#endif |
1478 |
|
#else |
1479 |
|
gpx_t *found = NULL; |
1480 |
|
|
1481 |
if(appdata->cur_gpx) |
if(appdata->cur_gpx) |
1482 |
found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE); |
found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE); |
1483 |
else |
else |
1498 |
gtk_widget_destroy(dialog); |
gtk_widget_destroy(dialog); |
1499 |
} |
} |
1500 |
|
|
1501 |
void on_window_destroy (GtkWidget *widget, gpointer data); |
static void on_window_destroy (GtkWidget *widget, gpointer data); |
1502 |
|
|
1503 |
#ifndef USE_MAEMO |
#ifndef USE_MAEMO |
1504 |
static void |
static void |
1560 |
notes_log_export(appdata); |
notes_log_export(appdata); |
1561 |
} |
} |
1562 |
|
|
1563 |
#ifdef USE_MAEMO |
#ifdef ENABLE_MAEMO_MAPPER |
1564 |
static void |
static void |
1565 |
cb_menu_export_mmpoi(GtkWidget *widget, gpointer data) { |
cb_menu_export_mmpoi(GtkWidget *widget, gpointer data) { |
1566 |
appdata_t *appdata = (appdata_t*)data; |
appdata_t *appdata = (appdata_t*)data; |
1574 |
garmin_export(appdata); |
garmin_export(appdata); |
1575 |
} |
} |
1576 |
|
|
1577 |
|
#ifdef ENABLE_OSM_GPS_MAP |
1578 |
|
static void |
1579 |
|
cb_menu_map(GtkWidget *window, gpointer data) { |
1580 |
|
map((appdata_t *)data); |
1581 |
|
} |
1582 |
|
#endif |
1583 |
|
|
1584 |
static void |
static void |
1585 |
cb_menu_geomath(GtkWidget *window, gpointer data) { |
cb_menu_geomath(GtkWidget *window, gpointer data) { |
1586 |
geomath_dialog((appdata_t *)data); |
geomath_dialog((appdata_t *)data); |
1597 |
} |
} |
1598 |
|
|
1599 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
1600 |
|
typedef struct { |
1601 |
|
char *label, *desc; |
1602 |
|
GtkSignalFunc activate_cb; |
1603 |
|
} menu_entry_t; |
1604 |
|
|
1605 |
void on_export_clicked(GtkButton *button, appdata_t *appdata) { |
typedef struct { |
1606 |
HildonStackableWindow *view_window; |
const char *title; |
1607 |
GtkWidget *but; |
const menu_entry_t *menu; |
1608 |
|
int len; |
1609 |
|
} submenu_t; |
1610 |
|
|
1611 |
view_window = HILDON_STACKABLE_WINDOW (hildon_stackable_window_new ()); |
#define COLUMNS 1 |
|
gtk_window_set_title (GTK_WINDOW (view_window), "Export"); |
|
1612 |
|
|
1613 |
GtkVBox *contents = GTK_VBOX(gtk_vbox_new (12, FALSE)); |
void on_submenu_entry_clicked(GtkButton *button, GtkWidget *menu) { |
1614 |
|
|
1615 |
but = hildon_button_new_with_text( |
/* force closing of submenu dialog */ |
1616 |
HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH, |
gtk_dialog_response(GTK_DIALOG(menu), GTK_RESPONSE_NONE); |
1617 |
HILDON_BUTTON_ARRANGEMENT_VERTICAL, |
gtk_widget_hide(menu); |
1618 |
_("Export to Maemo Mapper"), |
|
1619 |
_("Save a Maemo Mapper POI file")); |
/* let gtk clean up */ |
1620 |
g_signal_connect(but, "clicked", |
while(gtk_events_pending()) |
1621 |
G_CALLBACK(cb_menu_export_mmpoi), appdata); |
gtk_main_iteration(); |
1622 |
gtk_box_pack_start(GTK_BOX(contents), but, FALSE, FALSE, 0); |
} |
1623 |
|
|
1624 |
|
static GtkWidget *app_submenu_create(appdata_t *appdata, |
1625 |
|
const submenu_t *submenu) { |
1626 |
|
|
1627 |
but = hildon_button_new_with_text( |
/* create a oridinary dialog box */ |
1628 |
HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH, |
GtkWidget *dialog = gtk_dialog_new(); |
1629 |
HILDON_BUTTON_ARRANGEMENT_VERTICAL, |
gtk_window_set_title(GTK_WINDOW(dialog), _(submenu->title)); |
1630 |
_("Export Field Notes"), |
gtk_window_set_modal(GTK_WINDOW(dialog), TRUE); |
1631 |
_("Save a Garmin Field Notes file")); |
gtk_window_set_transient_for(GTK_WINDOW(dialog), |
1632 |
g_signal_connect(but, "clicked", |
GTK_WINDOW(appdata->window)); |
1633 |
G_CALLBACK(cb_menu_export_log), appdata); |
gtk_dialog_set_has_separator(GTK_DIALOG(dialog), FALSE); |
|
gtk_box_pack_start(GTK_BOX(contents), but, FALSE, FALSE, 0); |
|
|
|
|
1634 |
|
|
1635 |
but = hildon_button_new_with_text( |
GtkWidget *table = gtk_table_new(submenu->len/COLUMNS, COLUMNS, TRUE); |
1636 |
|
int x = 0, y = 0; |
1637 |
|
|
1638 |
|
const menu_entry_t *menu_entries = submenu->menu; |
1639 |
|
while(menu_entries->label) { |
1640 |
|
GtkWidget *button = NULL; |
1641 |
|
|
1642 |
|
button = hildon_button_new_with_text( |
1643 |
HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH, |
HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH, |
1644 |
HILDON_BUTTON_ARRANGEMENT_VERTICAL, |
HILDON_BUTTON_ARRANGEMENT_VERTICAL, |
1645 |
_("Export Garmin GPX"), |
_(menu_entries->label), _(menu_entries->desc)); |
1646 |
_("Save a GPX file containing modified waypoints")); |
|
1647 |
g_signal_connect(but, "clicked", |
/* try to center both texts */ |
1648 |
G_CALLBACK(cb_menu_export_garmin), appdata); |
hildon_button_set_title_alignment(HILDON_BUTTON(button), 0.5, 0.5); |
1649 |
gtk_box_pack_start(GTK_BOX(contents), but, FALSE, FALSE, 0); |
hildon_button_set_value_alignment(HILDON_BUTTON(button), 0.5, 0.5); |
1650 |
|
|
1651 |
|
g_signal_connect(button, "clicked", |
1652 |
|
G_CALLBACK(on_submenu_entry_clicked), dialog); |
1653 |
|
|
1654 |
|
g_signal_connect(button, "clicked", |
1655 |
|
menu_entries->activate_cb, appdata); |
1656 |
|
|
1657 |
|
gtk_table_attach_defaults(GTK_TABLE(table), button, x, x+1, y, y+1); |
1658 |
|
|
1659 |
|
x++; |
1660 |
|
if(x == COLUMNS) { x = 0; y++; } |
1661 |
|
|
1662 |
|
menu_entries++; |
1663 |
|
} |
1664 |
|
|
1665 |
gtk_container_add (GTK_CONTAINER (view_window), GTK_WIDGET (contents)); |
gtk_box_pack_start_defaults(GTK_BOX(GTK_DIALOG(dialog)->vbox), table); |
1666 |
gtk_widget_show_all (GTK_WIDGET (view_window)); |
|
1667 |
|
return dialog; |
1668 |
} |
} |
1669 |
|
|
1670 |
void on_tools_clicked(GtkButton *button, appdata_t *appdata) { |
/* popup the dialog shaped submenu */ |
1671 |
HildonStackableWindow *view_window; |
static void submenu_popup(GtkWidget *menu) { |
1672 |
GtkWidget *but; |
gtk_widget_show_all(menu); |
1673 |
|
gtk_dialog_run(GTK_DIALOG(menu)); |
1674 |
|
gtk_widget_hide(menu); |
1675 |
|
} |
1676 |
|
|
1677 |
view_window = HILDON_STACKABLE_WINDOW (hildon_stackable_window_new ()); |
static void submenu_cleanup(GtkWidget *menu) { |
1678 |
gtk_window_set_title (GTK_WINDOW (view_window), "Export"); |
gtk_widget_destroy(menu); |
1679 |
|
} |
1680 |
|
|
1681 |
GtkVBox *contents = GTK_VBOX(gtk_vbox_new (12, FALSE)); |
static const menu_entry_t submenu_export_entries[] = { |
1682 |
|
#ifdef ENABLE_MAEMO_MAPPER |
1683 |
|
{ "Export to Maemo Mapper" , "Save a Maemo Mapper POI file", |
1684 |
|
G_CALLBACK(cb_menu_export_mmpoi) }, |
1685 |
|
#endif |
1686 |
|
{ "Export Field Notes", "Save a Garmin Field Notes file", |
1687 |
|
G_CALLBACK(cb_menu_export_log) }, |
1688 |
|
{ "Export Garmin GPX", "Save modified waypoints in GPX file", |
1689 |
|
G_CALLBACK(cb_menu_export_garmin) }, |
1690 |
|
{ NULL, NULL, NULL } |
1691 |
|
}; |
1692 |
|
|
1693 |
but = hildon_button_new_with_text( |
static const submenu_t submenu_export = { |
1694 |
HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH, |
"Export", submenu_export_entries, |
1695 |
HILDON_BUTTON_ARRANGEMENT_VERTICAL, |
sizeof(submenu_export_entries)/sizeof(menu_entry_t)-1 |
1696 |
_("Geomath"), |
}; |
|
_("Geocoordinate calculation")); |
|
|
g_signal_connect(but, "clicked", |
|
|
G_CALLBACK(cb_menu_geomath), appdata); |
|
|
gtk_box_pack_start(GTK_BOX(contents), but, FALSE, FALSE, 0); |
|
1697 |
|
|
1698 |
|
/* the export submenu */ |
1699 |
|
void on_export_clicked(GtkButton *button, appdata_t *appdata) { |
1700 |
|
if(!appdata->export_menu) |
1701 |
|
appdata->export_menu = app_submenu_create(appdata, &submenu_export); |
1702 |
|
|
1703 |
but = hildon_button_new_with_text( |
submenu_popup(appdata->export_menu); |
1704 |
HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH, |
} |
|
HILDON_BUTTON_ARRANGEMENT_VERTICAL, |
|
|
_("Geotext"), |
|
|
_("Text analysis, letter counting etc")); |
|
|
g_signal_connect(but, "clicked", |
|
|
G_CALLBACK(cb_menu_geotext), appdata); |
|
|
gtk_box_pack_start(GTK_BOX(contents), but, FALSE, FALSE, 0); |
|
|
|
|
1705 |
|
|
1706 |
but = hildon_button_new_with_text( |
static const menu_entry_t submenu_tools_entries[] = { |
1707 |
HILDON_SIZE_FINGER_HEIGHT | HILDON_SIZE_AUTO_WIDTH, |
{ "Geomath", "Geocoordinate calculation", |
1708 |
HILDON_BUTTON_ARRANGEMENT_VERTICAL, |
G_CALLBACK(cb_menu_geomath) }, |
1709 |
_("Precise Position"), |
{ "Geotext", "Text analysis", |
1710 |
_("Calculate a very precise GPS position")); |
G_CALLBACK(cb_menu_geotext) }, |
1711 |
g_signal_connect(but, "clicked", |
{ "Precise Position", "Calculate a precise GPS position", |
1712 |
G_CALLBACK(cb_menu_precpos), appdata); |
G_CALLBACK(cb_menu_precpos) }, |
1713 |
gtk_box_pack_start(GTK_BOX(contents), but, FALSE, FALSE, 0); |
{ NULL, NULL, NULL } |
1714 |
|
}; |
1715 |
|
|
1716 |
|
static const submenu_t submenu_tools = { |
1717 |
|
"Tools", submenu_tools_entries, |
1718 |
|
sizeof(submenu_tools_entries)/sizeof(menu_entry_t)-1 |
1719 |
|
}; |
1720 |
|
|
1721 |
gtk_container_add (GTK_CONTAINER (view_window), GTK_WIDGET (contents)); |
/* the tools submenu */ |
1722 |
gtk_widget_show_all (GTK_WIDGET (view_window)); |
void on_tools_clicked(GtkButton *button, appdata_t *appdata) { |
1723 |
|
if(!appdata->tools_menu) |
1724 |
|
appdata->tools_menu = app_submenu_create(appdata, &submenu_tools); |
1725 |
|
|
1726 |
|
submenu_popup(appdata->tools_menu); |
1727 |
} |
} |
1728 |
|
|
1729 |
HildonAppMenu *menu_create(appdata_t *appdata, int mode) { |
HildonAppMenu *menu_create(appdata_t *appdata, int mode) { |
1751 |
g_signal_connect_after(button, "clicked", |
g_signal_connect_after(button, "clicked", |
1752 |
G_CALLBACK(cb_menu_adddir), appdata); |
G_CALLBACK(cb_menu_adddir), appdata); |
1753 |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
|
} |
|
1754 |
|
|
|
if(mode == MENU_GPXLIST) { |
|
1755 |
button = gtk_button_new_with_label(_("Export")); |
button = gtk_button_new_with_label(_("Export")); |
1756 |
g_signal_connect_after(button, "clicked", |
g_signal_connect_after(button, "clicked", |
1757 |
G_CALLBACK(on_export_clicked), appdata); |
G_CALLBACK(on_export_clicked), appdata); |
1768 |
G_CALLBACK(on_tools_clicked), appdata); |
G_CALLBACK(on_tools_clicked), appdata); |
1769 |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
1770 |
|
|
1771 |
gtk_widget_show(GTK_WIDGET(menu)); |
#ifdef ENABLE_OSM_GPS_MAP |
1772 |
|
button = gtk_button_new_with_label(_("Map")); |
1773 |
|
g_signal_connect_after(button, "clicked", |
1774 |
|
G_CALLBACK(cb_menu_map), appdata); |
1775 |
|
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
1776 |
|
#endif |
1777 |
|
|
1778 |
|
#ifdef HILDON_HELP |
1779 |
|
button = gtk_button_new_with_label(_("Help")); |
1780 |
|
g_signal_connect_after(button, "clicked", |
1781 |
|
G_CALLBACK(cb_menu_help), appdata); |
1782 |
|
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
1783 |
|
#endif |
1784 |
|
|
1785 |
|
gtk_widget_show_all(GTK_WIDGET(menu)); |
1786 |
|
|
1787 |
return menu; |
return menu; |
1788 |
} |
} |
1792 |
GtkWidget *menu, *item; |
GtkWidget *menu, *item; |
1793 |
menu = gtk_menu_new(); |
menu = gtk_menu_new(); |
1794 |
|
|
1795 |
#ifdef USE_BREAD_CRUMB_TRAIL |
#if defined(USE_BREAD_CRUMB_TRAIL) || defined(BCT) |
1796 |
appdata->menu_import = |
appdata->menu_import = |
1797 |
#endif |
#endif |
1798 |
item = gtk_menu_item_new_with_label(_("Import")); |
item = gtk_menu_item_new_with_label(_("Import")); |
1822 |
g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_remove), appdata); |
g_signal_connect(item, "activate", GTK_SIGNAL_FUNC(cb_menu_remove), appdata); |
1823 |
#endif |
#endif |
1824 |
|
|
1825 |
#ifdef USE_BREAD_CRUMB_TRAIL |
#if defined(USE_BREAD_CRUMB_TRAIL) || defined(BCT) |
1826 |
appdata->menu_export = |
appdata->menu_export = |
1827 |
#endif |
#endif |
1828 |
item = gtk_menu_item_new_with_label(_("Export")); |
item = gtk_menu_item_new_with_label(_("Export")); |
1830 |
submenu = gtk_menu_new(); |
submenu = gtk_menu_new(); |
1831 |
gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu); |
gtk_menu_item_set_submenu(GTK_MENU_ITEM(item), submenu); |
1832 |
|
|
1833 |
#ifdef USE_MAEMO |
#ifdef ENABLE_MAEMO_MAPPER |
1834 |
item = gtk_menu_item_new_with_label( _("Maemo Mapper POI") ); |
item = gtk_menu_item_new_with_label( _("Maemo Mapper POI") ); |
1835 |
gtk_menu_append(GTK_MENU_SHELL(submenu), item); |
gtk_menu_append(GTK_MENU_SHELL(submenu), item); |
1836 |
g_signal_connect(item, "activate", |
g_signal_connect(item, "activate", |
1847 |
g_signal_connect(item, "activate", |
g_signal_connect(item, "activate", |
1848 |
GTK_SIGNAL_FUNC(cb_menu_export_garmin), appdata); |
GTK_SIGNAL_FUNC(cb_menu_export_garmin), appdata); |
1849 |
|
|
1850 |
#ifdef USE_BREAD_CRUMB_TRAIL |
#if defined(USE_BREAD_CRUMB_TRAIL) || defined(BCT) |
1851 |
appdata->menu_search = |
appdata->menu_search = |
1852 |
#endif |
#endif |
1853 |
item = gtk_menu_item_new_with_label( _("Search") ); |
item = gtk_menu_item_new_with_label( _("Search") ); |
1856 |
|
|
1857 |
gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new()); |
gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new()); |
1858 |
|
|
|
#ifndef NO_COPY_N_PASTE |
|
1859 |
/* ----------- copy'n paste submenu ----------------- */ |
/* ----------- copy'n paste submenu ----------------- */ |
1860 |
appdata->clipboard = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); |
#ifndef NO_COPY_N_PASTE |
|
gtk_clipboard_set_can_store(appdata->clipboard, NULL, 0); |
|
|
|
|
1861 |
item = gtk_menu_item_new_with_label(_("Edit")); |
item = gtk_menu_item_new_with_label(_("Edit")); |
1862 |
gtk_menu_append(GTK_MENU_SHELL(menu), item); |
gtk_menu_append(GTK_MENU_SHELL(menu), item); |
1863 |
submenu = gtk_menu_new(); |
submenu = gtk_menu_new(); |
1884 |
|
|
1885 |
gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new()); |
gtk_menu_append(GTK_MENU_SHELL(menu), gtk_separator_menu_item_new()); |
1886 |
|
|
1887 |
|
#ifdef ENABLE_OSM_GPS_MAP |
1888 |
|
item = gtk_menu_item_new_with_label( _("Map") ); |
1889 |
|
gtk_menu_append(GTK_MENU_SHELL(menu), item); |
1890 |
|
g_signal_connect(item, "activate", |
1891 |
|
GTK_SIGNAL_FUNC(cb_menu_map), appdata); |
1892 |
|
#endif |
1893 |
|
|
1894 |
item = gtk_menu_item_new_with_label(_("Tools")); |
item = gtk_menu_item_new_with_label(_("Tools")); |
1895 |
gtk_menu_append(GTK_MENU_SHELL(menu), item); |
gtk_menu_append(GTK_MENU_SHELL(menu), item); |
1896 |
submenu = gtk_menu_new(); |
submenu = gtk_menu_new(); |
1955 |
if(appdata->image_path) free(appdata->image_path); |
if(appdata->image_path) free(appdata->image_path); |
1956 |
if(appdata->search_str) free(appdata->search_str); |
if(appdata->search_str) free(appdata->search_str); |
1957 |
|
|
1958 |
|
#ifdef USE_STACKABLE_WINDOW |
1959 |
|
if(appdata->export_menu) submenu_cleanup(appdata->export_menu); |
1960 |
|
if(appdata->tools_menu) submenu_cleanup(appdata->tools_menu); |
1961 |
|
#endif |
1962 |
|
|
1963 |
gnome_vfs_shutdown(); |
gnome_vfs_shutdown(); |
1964 |
icons_free(); |
icons_free(); |
1965 |
gps_release(appdata); |
gps_release(appdata); |
1988 |
puts("everything is gone"); |
puts("everything is gone"); |
1989 |
} |
} |
1990 |
|
|
1991 |
void on_window_destroy (GtkWidget *widget, gpointer data) { |
static void on_window_destroy (GtkWidget *widget, gpointer data) { |
1992 |
appdata_t *appdata = (appdata_t*)data; |
appdata_t *appdata = (appdata_t*)data; |
1993 |
|
|
1994 |
gconf_save_state(appdata); |
gconf_save_state(appdata); |
1997 |
} |
} |
1998 |
|
|
1999 |
gboolean on_window_key_press(GtkWidget *widget, |
gboolean on_window_key_press(GtkWidget *widget, |
2000 |
GdkEventKey *event, gpointer data) { |
GdkEventKey *event, appdata_t *appdata) { |
|
appdata_t *appdata = (appdata_t*)data; |
|
2001 |
int handled = FALSE; |
int handled = FALSE; |
2002 |
|
|
2003 |
// printf("key event %d\n", event->keyval); |
// printf("key event %d\n", event->keyval); |
2005 |
switch(event->keyval) { |
switch(event->keyval) { |
2006 |
#ifdef USE_MAEMO |
#ifdef USE_MAEMO |
2007 |
|
|
|
#if 0 /* don't do this as it interferes with gtkentry fields */ |
|
|
case HILDON_HARDKEY_SELECT: |
|
|
/* remove as long as we haven't reached the main gpx list */ |
|
|
if(appdata->cur_gpx) |
|
|
hildon_bread_crumb_trail_pop(HILDON_BREAD_CRUMB_TRAIL(appdata->bct)); |
|
|
handled = TRUE; |
|
|
break; |
|
|
#endif |
|
|
|
|
2008 |
#ifdef HILDON_HARDKEY_INCREASE |
#ifdef HILDON_HARDKEY_INCREASE |
2009 |
case HILDON_HARDKEY_INCREASE: |
case HILDON_HARDKEY_INCREASE: |
2010 |
html_zoom(appdata, TRUE); |
html_zoom(appdata, TRUE); |
2051 |
return handled; |
return handled; |
2052 |
} |
} |
2053 |
|
|
2054 |
#ifdef USE_BREAD_CRUMB_TRAIL |
#if defined(USE_BREAD_CRUMB_TRAIL) || defined(BCT) |
2055 |
typedef struct { |
typedef struct { |
2056 |
int level; |
int level; |
2057 |
appdata_t *appdata; |
appdata_t *appdata; |
2143 |
|
|
2144 |
gtk_widget_show_all(crumb->appdata->vbox); |
gtk_widget_show_all(crumb->appdata->vbox); |
2145 |
g_free(data); |
g_free(data); |
2146 |
|
|
2147 |
|
#ifdef ENABLE_OSM_GPS_MAP |
2148 |
|
map_update(crumb->appdata); |
2149 |
|
#endif |
2150 |
} |
} |
2151 |
|
|
2152 |
static void crumb_add(appdata_t *appdata, char *name, int level, |
static void crumb_add(appdata_t *appdata, char *name, int level, |
2187 |
#endif |
#endif |
2188 |
} |
} |
2189 |
|
|
2190 |
|
#ifdef USE_BREAD_CRUMB_TRAIL |
2191 |
hildon_bread_crumb_trail_push_text(HILDON_BREAD_CRUMB_TRAIL(appdata->bct), |
hildon_bread_crumb_trail_push_text(HILDON_BREAD_CRUMB_TRAIL(appdata->bct), |
2192 |
name, crumb, (GDestroyNotify)crumb_back); |
name, crumb, (GDestroyNotify)crumb_back); |
2193 |
|
#else |
2194 |
|
bct_push_text(appdata->bct, name, crumb, (GDestroyNotify)crumb_back); |
2195 |
|
#endif |
2196 |
|
|
2197 |
|
#ifdef ENABLE_OSM_GPS_MAP |
2198 |
|
map_update(appdata); |
2199 |
|
#endif |
2200 |
} |
} |
2201 |
#endif // USE_BREAD_CRUMB_TRAIL |
#endif // USE_BREAD_CRUMB_TRAIL |
2202 |
|
|
2203 |
void main_after_settings_redraw(appdata_t *appdata, int flags) { |
void main_after_settings_redraw(appdata_t *appdata, int flags) { |
2204 |
#ifndef USE_MAEMO |
printf("main after settings redraw\n"); |
2205 |
// in non-maemo setup this can only affect the main screen as |
|
2206 |
// the menu is blocked while a dialog is open. also the main |
if(!appdata->cur_view) { |
2207 |
// screen is always present |
printf("no active view\n"); |
2208 |
if(appdata->gpxlist_items != appdata->cur_items) { |
return; |
|
/* re-do the main screen */ |
|
|
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
|
|
appdata->cur_view = gpxlist_create_view_and_model(appdata, NULL); |
|
|
gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view); |
|
|
gtk_widget_show_all(appdata->vbox); |
|
2209 |
} |
} |
2210 |
#else |
|
2211 |
/* a cache screen cannot be changed from the settings and thus doesn't */ |
/* a cache screen cannot be changed from the settings and thus doesn't */ |
2212 |
/* need to be redrawn */ |
/* need to be redrawn */ |
2213 |
if(appdata->cur_cache) { |
if(appdata->cur_cache) { |
2231 |
} |
} |
2232 |
|
|
2233 |
if(redraw) { |
if(redraw) { |
2234 |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
GtkWidget *container = appdata->vbox; |
2235 |
|
|
2236 |
|
#ifdef USE_STACKABLE_WINDOW |
2237 |
|
HildonWindowStack *stack = hildon_window_stack_get_default(); |
2238 |
|
container = hildon_window_stack_peek(stack); |
2239 |
|
#endif |
2240 |
|
|
2241 |
|
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
2242 |
switch(redraw) { |
switch(redraw) { |
2243 |
case 1: |
case 1: |
2244 |
appdata->cur_view = cachelist_create(appdata, |
appdata->cur_view = cachelist_create(appdata, |
2253 |
break; |
break; |
2254 |
} |
} |
2255 |
|
|
2256 |
gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view); |
#ifdef USE_STACKABLE_WINDOW |
2257 |
gtk_widget_show_all(appdata->vbox); |
if(container != appdata->vbox) |
2258 |
} |
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
2259 |
|
else |
2260 |
#endif |
#endif |
2261 |
|
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
2262 |
|
|
2263 |
|
gtk_widget_show_all(container); |
2264 |
|
} |
2265 |
} |
} |
2266 |
|
|
2267 |
int main(int argc, char *argv[]) { |
int main(int argc, char *argv[]) { |
2290 |
fprintf(stderr, "error initiating osso context\n"); |
fprintf(stderr, "error initiating osso context\n"); |
2291 |
} |
} |
2292 |
|
|
2293 |
|
#ifdef ENABLE_MAEMO_MAPPER |
2294 |
dbus_register(&appdata); |
dbus_register(&appdata); |
2295 |
#endif |
#endif |
2296 |
|
#endif |
2297 |
|
|
2298 |
icons_init(); |
icons_init(); |
2299 |
|
|
2317 |
/* Create a Window. */ |
/* Create a Window. */ |
2318 |
appdata.window = gtk_window_new(GTK_WINDOW_TOPLEVEL); |
appdata.window = gtk_window_new(GTK_WINDOW_TOPLEVEL); |
2319 |
/* Set a decent default size for the window. */ |
/* Set a decent default size for the window. */ |
2320 |
gtk_window_set_default_size(GTK_WINDOW(appdata.window), 500, 300); |
gtk_window_set_default_size(GTK_WINDOW(appdata.window), 640, 480); |
2321 |
#endif |
#endif |
2322 |
|
|
2323 |
|
#if MAEMO_VERSION_MAJOR == 5 |
2324 |
gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView"); |
gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView"); |
2325 |
|
#endif |
2326 |
|
|
2327 |
g_signal_connect(G_OBJECT(appdata.window), "destroy", |
g_signal_connect(G_OBJECT(appdata.window), "destroy", |
2328 |
G_CALLBACK(on_window_destroy), &appdata); |
G_CALLBACK(on_window_destroy), &appdata); |
2329 |
|
|
2330 |
g_signal_connect(G_OBJECT(appdata.window), "key_press_event", |
g_signal_connect(G_OBJECT(appdata.window), "key_press_event", |
2331 |
G_CALLBACK(on_window_key_press), &appdata); |
G_CALLBACK(on_window_key_press), &appdata); |
2332 |
|
|
2333 |
|
/* prepare clipboard */ |
2334 |
|
appdata.clipboard = gtk_clipboard_get(GDK_SELECTION_CLIPBOARD); |
2335 |
|
gtk_clipboard_set_can_store(appdata.clipboard, NULL, 0); |
2336 |
|
|
2337 |
appdata.vbox = gtk_vbox_new(FALSE, 2); |
appdata.vbox = gtk_vbox_new(FALSE, 2); |
2338 |
gtk_container_add(GTK_CONTAINER(appdata.window), appdata.vbox); |
gtk_container_add(GTK_CONTAINER(appdata.window), appdata.vbox); |
|
|
|
2339 |
#ifndef USE_STACKABLE_WINDOW |
#ifndef USE_STACKABLE_WINDOW |
2340 |
menu_create(&appdata); |
menu_create(&appdata); |
2341 |
#else |
#else |
2349 |
gtk_box_pack_start(GTK_BOX(appdata.vbox), appdata.bct, FALSE,FALSE,0); |
gtk_box_pack_start(GTK_BOX(appdata.vbox), appdata.bct, FALSE,FALSE,0); |
2350 |
|
|
2351 |
hildon_bread_crumb_trail_clear(HILDON_BREAD_CRUMB_TRAIL(appdata.bct)); |
hildon_bread_crumb_trail_clear(HILDON_BREAD_CRUMB_TRAIL(appdata.bct)); |
2352 |
|
#else |
2353 |
|
#ifdef BCT |
2354 |
|
/* on non-hildon machines we use some custom made breadcrumbtrail */ |
2355 |
|
/* replacement */ |
2356 |
|
appdata.bct = bct_new(); |
2357 |
|
gtk_box_pack_start(GTK_BOX(appdata.vbox), appdata.bct, FALSE,FALSE,0); |
2358 |
|
#endif |
2359 |
|
#endif |
2360 |
|
|
2361 |
|
#if defined(USE_BREAD_CRUMB_TRAIL) || defined(BCT) |
2362 |
crumb_add(&appdata, "GPX", CRUMB_GPXLIST, NULL); |
crumb_add(&appdata, "GPX", CRUMB_GPXLIST, NULL); |
2363 |
#endif |
#endif |
2364 |
|
|