120 |
HELP_ID_IMPORT, appdata->osso_context); |
HELP_ID_IMPORT, appdata->osso_context); |
121 |
#endif |
#endif |
122 |
#else |
#else |
123 |
dialog = gtk_file_chooser_dialog_new (whole_dir?_("Open Directory"): |
dialog = gtk_file_chooser_dialog_new (whole_dir?_("Import directory"): |
124 |
_("Open File"), |
_("Import file"), |
125 |
GTK_WINDOW(appdata->window), |
GTK_WINDOW(appdata->window), |
126 |
whole_dir?GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER : |
whole_dir?GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER : |
127 |
GTK_FILE_CHOOSER_ACTION_OPEN, |
GTK_FILE_CHOOSER_ACTION_OPEN, |
264 |
// gtk_widget_show_all(appdata->vbox); |
// gtk_widget_show_all(appdata->vbox); |
265 |
#else |
#else |
266 |
|
|
267 |
|
if(!appdata->cur_view) { |
268 |
|
printf("cachelist redraw: no active view\n"); |
269 |
|
return; |
270 |
|
} |
271 |
|
|
272 |
g_assert(!appdata->cur_cache); |
g_assert(!appdata->cur_cache); |
273 |
int redraw = 0; |
int redraw = 0; |
274 |
if(appdata->search_results) |
if(appdata->search_results) |
279 |
} |
} |
280 |
|
|
281 |
if(redraw) { |
if(redraw) { |
282 |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
GtkWidget *container = appdata->vbox; |
283 |
|
|
284 |
|
printf("redraw %d\n", redraw); |
285 |
|
|
286 |
|
#ifdef USE_STACKABLE_WINDOW |
287 |
|
HildonWindowStack *stack = hildon_window_stack_get_default(); |
288 |
|
container = hildon_window_stack_peek(stack); |
289 |
|
#endif |
290 |
|
|
291 |
|
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
292 |
switch(redraw) { |
switch(redraw) { |
293 |
case 1: |
case 1: |
294 |
appdata->cur_view = cachelist_create(appdata, |
appdata->cur_view = cachelist_create(appdata, |
300 |
break; |
break; |
301 |
} |
} |
302 |
|
|
303 |
gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view); |
#ifdef USE_STACKABLE_WINDOW |
304 |
gtk_widget_show_all(appdata->vbox); |
if(container != appdata->vbox) |
305 |
|
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
306 |
|
else |
307 |
|
#endif |
308 |
|
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
309 |
|
|
310 |
|
gtk_widget_show_all(container); |
311 |
} |
} |
312 |
#endif |
#endif |
313 |
} |
} |
320 |
#ifdef USE_MAEMO |
#ifdef USE_MAEMO |
321 |
appdata_t *appdata = (appdata_t*)data; |
appdata_t *appdata = (appdata_t*)data; |
322 |
|
|
323 |
|
if(appdata->cur_cache) |
324 |
|
return TRUE; |
325 |
|
|
326 |
if(appdata->cachelist_disable_screensaver) |
if(appdata->cachelist_disable_screensaver) |
327 |
if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK) |
if (osso_display_blanking_pause(appdata->osso_context) != OSSO_OK) |
328 |
fprintf(stderr, "error with display blank\n"); |
fprintf(stderr, "error with display blank\n"); |
335 |
} |
} |
336 |
|
|
337 |
static void cachelist_timer_reset(appdata_t *appdata) { |
static void cachelist_timer_reset(appdata_t *appdata) { |
338 |
|
printf("cachelist timer reset\n"); |
339 |
g_assert(appdata->cachelist_handler_id); |
g_assert(appdata->cachelist_handler_id); |
340 |
gtk_timeout_remove(appdata->cachelist_handler_id); |
gtk_timeout_remove(appdata->cachelist_handler_id); |
341 |
appdata->cachelist_handler_id = |
appdata->cachelist_handler_id = |
567 |
} |
} |
568 |
#else |
#else |
569 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
570 |
|
static void search_result_free(gpx_t *result); |
571 |
|
|
572 |
|
void on_cachelist_destroy(GtkWidget *widget, appdata_t *appdata) { |
573 |
|
if(appdata->search_results) { |
574 |
|
search_result_free(appdata->search_results); |
575 |
|
appdata->search_results = NULL; |
576 |
|
} |
577 |
|
appdata->cur_gpx = NULL; |
578 |
|
|
579 |
|
/* restore cur_view */ |
580 |
|
appdata->cur_view = g_object_get_data(G_OBJECT(widget), "cur_view"); |
581 |
|
} |
582 |
|
|
583 |
void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) { |
void cachelist_dialog(appdata_t *appdata, gpx_t *gpx) { |
584 |
GtkWidget *window = hildon_stackable_window_new(); |
GtkWidget *window = hildon_stackable_window_new(); |
585 |
|
|
586 |
gtk_window_set_title(GTK_WINDOW(window), gpx->name); |
/* store last "cur_view" in window */ |
587 |
|
g_object_set_data(G_OBJECT(window), "cur_view", appdata->cur_view); |
588 |
|
|
589 |
gtk_container_add(GTK_CONTAINER(window), |
appdata->cur_gpx = gpx; |
590 |
cachelist_create(appdata, gpx, NULL)); |
char *title = g_strdup_printf("GPXView - %s", gpx->name); |
591 |
|
gtk_window_set_title(GTK_WINDOW(window), title); |
592 |
|
g_free(title); |
593 |
|
|
594 |
|
appdata->cur_view = cachelist_create(appdata, gpx, NULL); |
595 |
|
gtk_container_add(GTK_CONTAINER(window), appdata->cur_view); |
596 |
|
|
597 |
|
|
598 |
hildon_window_set_app_menu(HILDON_WINDOW(window), |
hildon_window_set_app_menu(HILDON_WINDOW(window), |
599 |
menu_create(appdata, MENU_CACHELIST)); |
menu_create(appdata, MENU_CACHELIST)); |
600 |
|
|
601 |
|
g_signal_connect(G_OBJECT(window), "destroy", |
602 |
|
G_CALLBACK(on_cachelist_destroy), appdata); |
603 |
|
|
604 |
gtk_widget_show_all(window); |
gtk_widget_show_all(window); |
605 |
} |
} |
606 |
#endif |
#endif |
811 |
gpx_busy_dialog_destroy(dialog); |
gpx_busy_dialog_destroy(dialog); |
812 |
} |
} |
813 |
#ifndef USE_BREAD_CRUMB_TRAIL |
#ifndef USE_BREAD_CRUMB_TRAIL |
814 |
cachelist_dialog(appdata, gpx); |
#ifdef USE_STACKABLE_WINDOW |
815 |
|
if(!appdata->cur_gpx) |
816 |
|
#endif |
817 |
|
cachelist_dialog(appdata, gpx); |
818 |
|
#ifdef USE_STACKABLE_WINDOW |
819 |
|
else |
820 |
|
printf("selected gpx, but cachelist window already present\n"); |
821 |
|
#endif |
822 |
#else |
#else |
823 |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
824 |
appdata->cur_view = cachelist_create(appdata, gpx, NULL); |
appdata->cur_view = cachelist_create(appdata, gpx, NULL); |
1382 |
/* don't search if we are asked to search for nothing */ |
/* don't search if we are asked to search for nothing */ |
1383 |
if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) && |
if(((appdata->search & (SEARCH_ID|SEARCH_NAME|SEARCH_DESC|SEARCH_OWNER)) && |
1384 |
strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) { |
strlen(p) > 0) || (appdata->search & SEARCH_FINDS)) { |
|
gpx_t *found = NULL; |
|
1385 |
|
|
1386 |
printf("Search for %s (flags = %x)...\n", p, appdata->search); |
printf("Search for %s (flags = %x)...\n", p, appdata->search); |
1387 |
|
|
1388 |
#ifndef USE_BREAD_CRUMB_TRAIL |
#ifndef USE_BREAD_CRUMB_TRAIL |
1389 |
found = search_do(appdata, appdata->gpx, p, appdata->search, FALSE); |
gpx_t *found = |
1390 |
|
search_do(appdata, appdata->gpx, p, appdata->search, FALSE); |
1391 |
|
|
1392 |
/* do search result dialog here ... */ |
/* do search result dialog here ... */ |
1393 |
cachelist_dialog(appdata, found); |
cachelist_dialog(appdata, found); |
1394 |
|
#ifndef USE_STACKABLE_WINDOW |
1395 |
search_result_free(found); |
search_result_free(found); |
1396 |
#else |
#else |
1397 |
|
appdata->search_results = found; |
1398 |
|
#endif |
1399 |
|
#else |
1400 |
|
gpx_t *found = NULL; |
1401 |
|
|
1402 |
if(appdata->cur_gpx) |
if(appdata->cur_gpx) |
1403 |
found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE); |
found = search_do(appdata, appdata->cur_gpx, p, appdata->search, TRUE); |
1404 |
else |
else |
1511 |
} |
} |
1512 |
|
|
1513 |
#ifdef USE_STACKABLE_WINDOW |
#ifdef USE_STACKABLE_WINDOW |
1514 |
|
static void on_export_destroy(GtkWidget *widget, appdata_t *appdata) { |
1515 |
|
appdata->cur_view = g_object_get_data(G_OBJECT(widget), "cur_view"); |
1516 |
|
} |
1517 |
|
|
1518 |
void on_export_clicked(GtkButton *button, appdata_t *appdata) { |
void on_export_clicked(GtkButton *button, appdata_t *appdata) { |
1519 |
HildonStackableWindow *view_window; |
HildonStackableWindow *view_window; |
1520 |
GtkWidget *but; |
GtkWidget *but; |
1521 |
|
|
1522 |
view_window = HILDON_STACKABLE_WINDOW (hildon_stackable_window_new ()); |
view_window = HILDON_STACKABLE_WINDOW (hildon_stackable_window_new ()); |
1523 |
gtk_window_set_title (GTK_WINDOW (view_window), "Export"); |
gtk_window_set_title (GTK_WINDOW (view_window), "GPXView - Export"); |
1524 |
|
|
1525 |
|
/* store last "cur_view" in window */ |
1526 |
|
g_object_set_data(G_OBJECT(view_window), "cur_view", appdata->cur_view); |
1527 |
|
appdata->cur_view = NULL; |
1528 |
|
|
1529 |
|
g_signal_connect(G_OBJECT(view_window), "destroy", |
1530 |
|
G_CALLBACK(on_export_destroy), appdata); |
1531 |
|
|
1532 |
GtkVBox *contents = GTK_VBOX(gtk_vbox_new (12, FALSE)); |
GtkVBox *contents = GTK_VBOX(gtk_vbox_new (12, FALSE)); |
1533 |
|
|
1564 |
gtk_widget_show_all (GTK_WIDGET (view_window)); |
gtk_widget_show_all (GTK_WIDGET (view_window)); |
1565 |
} |
} |
1566 |
|
|
1567 |
|
static void on_tools_destroy(GtkWidget *widget, appdata_t *appdata) { |
1568 |
|
appdata->cur_view = g_object_get_data(G_OBJECT(widget), "cur_view"); |
1569 |
|
} |
1570 |
|
|
1571 |
void on_tools_clicked(GtkButton *button, appdata_t *appdata) { |
void on_tools_clicked(GtkButton *button, appdata_t *appdata) { |
1572 |
HildonStackableWindow *view_window; |
HildonStackableWindow *view_window; |
1573 |
GtkWidget *but; |
GtkWidget *but; |
1574 |
|
|
1575 |
view_window = HILDON_STACKABLE_WINDOW (hildon_stackable_window_new ()); |
view_window = HILDON_STACKABLE_WINDOW (hildon_stackable_window_new ()); |
1576 |
gtk_window_set_title (GTK_WINDOW (view_window), "Export"); |
gtk_window_set_title (GTK_WINDOW (view_window), "GPXView - Tools"); |
1577 |
|
|
1578 |
|
/* store last "cur_view" in window */ |
1579 |
|
g_object_set_data(G_OBJECT(view_window), "cur_view", appdata->cur_view); |
1580 |
|
appdata->cur_view = NULL; |
1581 |
|
|
1582 |
|
g_signal_connect(G_OBJECT(view_window), "destroy", |
1583 |
|
G_CALLBACK(on_tools_destroy), appdata); |
1584 |
|
|
1585 |
GtkVBox *contents = GTK_VBOX(gtk_vbox_new (12, FALSE)); |
GtkVBox *contents = GTK_VBOX(gtk_vbox_new (12, FALSE)); |
1586 |
|
|
1661 |
G_CALLBACK(on_tools_clicked), appdata); |
G_CALLBACK(on_tools_clicked), appdata); |
1662 |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
hildon_app_menu_append(menu, GTK_BUTTON(button)); |
1663 |
|
|
1664 |
gtk_widget_show(GTK_WIDGET(menu)); |
// gtk_widget_show(GTK_WIDGET(menu)); |
1665 |
|
|
1666 |
return menu; |
return menu; |
1667 |
} |
} |
1867 |
} |
} |
1868 |
|
|
1869 |
gboolean on_window_key_press(GtkWidget *widget, |
gboolean on_window_key_press(GtkWidget *widget, |
1870 |
GdkEventKey *event, gpointer data) { |
GdkEventKey *event, appdata_t *appdata) { |
|
appdata_t *appdata = (appdata_t*)data; |
|
1871 |
int handled = FALSE; |
int handled = FALSE; |
1872 |
|
|
1873 |
// printf("key event %d\n", event->keyval); |
// printf("key event %d\n", event->keyval); |
1875 |
switch(event->keyval) { |
switch(event->keyval) { |
1876 |
#ifdef USE_MAEMO |
#ifdef USE_MAEMO |
1877 |
|
|
|
#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 |
|
|
|
|
1878 |
#ifdef HILDON_HARDKEY_INCREASE |
#ifdef HILDON_HARDKEY_INCREASE |
1879 |
case HILDON_HARDKEY_INCREASE: |
case HILDON_HARDKEY_INCREASE: |
1880 |
html_zoom(appdata, TRUE); |
html_zoom(appdata, TRUE); |
2059 |
#endif // USE_BREAD_CRUMB_TRAIL |
#endif // USE_BREAD_CRUMB_TRAIL |
2060 |
|
|
2061 |
void main_after_settings_redraw(appdata_t *appdata, int flags) { |
void main_after_settings_redraw(appdata_t *appdata, int flags) { |
2062 |
|
printf("main after settings redraw\n"); |
2063 |
|
|
2064 |
|
if(!appdata->cur_view) { |
2065 |
|
printf("no active view\n"); |
2066 |
|
return; |
2067 |
|
} |
2068 |
|
|
2069 |
#ifndef USE_MAEMO |
#ifndef USE_MAEMO |
2070 |
// in non-maemo setup this can only affect the main screen as |
// in non-maemo setup this can only affect the main screen as |
2071 |
// the menu is blocked while a dialog is open. also the main |
// the menu is blocked while a dialog is open. also the main |
2101 |
} |
} |
2102 |
|
|
2103 |
if(redraw) { |
if(redraw) { |
2104 |
gtk_container_remove(GTK_CONTAINER(appdata->vbox), appdata->cur_view); |
GtkWidget *container = appdata->vbox; |
2105 |
|
|
2106 |
|
#ifdef USE_STACKABLE_WINDOW |
2107 |
|
HildonWindowStack *stack = hildon_window_stack_get_default(); |
2108 |
|
container = hildon_window_stack_peek(stack); |
2109 |
|
#endif |
2110 |
|
|
2111 |
|
gtk_container_remove(GTK_CONTAINER(container), appdata->cur_view); |
2112 |
switch(redraw) { |
switch(redraw) { |
2113 |
case 1: |
case 1: |
2114 |
appdata->cur_view = cachelist_create(appdata, |
appdata->cur_view = cachelist_create(appdata, |
2123 |
break; |
break; |
2124 |
} |
} |
2125 |
|
|
2126 |
gtk_box_pack_start_defaults(GTK_BOX(appdata->vbox), appdata->cur_view); |
#ifdef USE_STACKABLE_WINDOW |
2127 |
gtk_widget_show_all(appdata->vbox); |
if(container != appdata->vbox) |
2128 |
} |
gtk_container_add(GTK_CONTAINER(container), appdata->cur_view); |
2129 |
|
else |
2130 |
#endif |
#endif |
2131 |
|
gtk_box_pack_start_defaults(GTK_BOX(container), appdata->cur_view); |
2132 |
|
|
2133 |
|
gtk_widget_show_all(container); |
2134 |
|
} |
2135 |
|
#endif // USE_MAEMO |
2136 |
} |
} |
2137 |
|
|
2138 |
int main(int argc, char *argv[]) { |
int main(int argc, char *argv[]) { |
2189 |
gtk_window_set_default_size(GTK_WINDOW(appdata.window), 500, 300); |
gtk_window_set_default_size(GTK_WINDOW(appdata.window), 500, 300); |
2190 |
#endif |
#endif |
2191 |
|
|
2192 |
|
#if MAEMO_VERSION_MAJOR == 5 |
2193 |
gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView"); |
gtk_window_set_title(GTK_WINDOW(appdata.window), "GPXView"); |
2194 |
|
#endif |
2195 |
|
|
2196 |
g_signal_connect(G_OBJECT(appdata.window), "destroy", |
g_signal_connect(G_OBJECT(appdata.window), "destroy", |
2197 |
G_CALLBACK(on_window_destroy), &appdata); |
G_CALLBACK(on_window_destroy), &appdata); |
2198 |
|
|