X-Git-Url: https://git.street.me.uk/andy/viking.git/blobdiff_plain/3317dc4e75fe8c19d7ab5faaa043f5af4ad606f9..b2aa700f11bb54b6f9c6a0f8cf95bf3caccf7df5:/src/globals.c diff --git a/src/globals.c b/src/globals.c index 91d38b00..2edcdba7 100644 --- a/src/globals.c +++ b/src/globals.c @@ -41,50 +41,58 @@ static VikLayerParamScale params_scales_lat[] = { {-90.0, 90.0, 0.05, 2} }; static VikLayerParamScale params_scales_long[] = { {-180.0, 180.0, 0.05, 2} }; static VikLayerParam prefs1[] = { - { VIKING_PREFERENCES_NAMESPACE "degree_format", VIK_LAYER_PARAM_UINT, VIK_DEGREE_FORMAT_DMS, N_("Degree format:"), VIK_LAYER_WIDGET_COMBOBOX, params_degree_formats, NULL }, + { VIKING_PREFERENCES_NAMESPACE "degree_format", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("Degree format:"), VIK_LAYER_WIDGET_COMBOBOX, params_degree_formats, NULL, NULL }, }; static VikLayerParam prefs2[] = { - { VIKING_PREFERENCES_NAMESPACE "units_distance", VIK_LAYER_PARAM_UINT, VIK_UNITS_DISTANCE_KILOMETRES, N_("Distance units:"), VIK_LAYER_WIDGET_COMBOBOX, params_units_distance, NULL }, + { VIKING_PREFERENCES_NAMESPACE "units_distance", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("Distance units:"), VIK_LAYER_WIDGET_COMBOBOX, params_units_distance, NULL, NULL }, }; static VikLayerParam prefs3[] = { - { VIKING_PREFERENCES_NAMESPACE "units_speed", VIK_LAYER_PARAM_UINT, VIK_UNITS_SPEED_KILOMETRES_PER_HOUR, N_("Speed units:"), VIK_LAYER_WIDGET_COMBOBOX, params_units_speed, NULL }, + { VIKING_PREFERENCES_NAMESPACE "units_speed", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("Speed units:"), VIK_LAYER_WIDGET_COMBOBOX, params_units_speed, NULL, NULL }, }; static VikLayerParam prefs4[] = { - { VIKING_PREFERENCES_NAMESPACE "units_height", VIK_LAYER_PARAM_UINT, VIK_UNITS_HEIGHT_METRES, N_("Height units:"), VIK_LAYER_WIDGET_COMBOBOX, params_units_height, NULL }, + { VIKING_PREFERENCES_NAMESPACE "units_height", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("Height units:"), VIK_LAYER_WIDGET_COMBOBOX, params_units_height, NULL, NULL }, }; static VikLayerParam prefs5[] = { - { VIKING_PREFERENCES_NAMESPACE "use_large_waypoint_icons", VIK_LAYER_PARAM_BOOLEAN, TRUE, N_("Use large waypoint icons:"), VIK_LAYER_WIDGET_CHECKBUTTON, NULL, NULL }, + { VIKING_PREFERENCES_NAMESPACE "use_large_waypoint_icons", VIK_LAYER_PARAM_BOOLEAN, VIK_LAYER_GROUP_NONE, N_("Use large waypoint icons:"), VIK_LAYER_WIDGET_CHECKBUTTON, NULL, NULL, NULL }, }; static VikLayerParam prefs6[] = { - { VIKING_PREFERENCES_NAMESPACE "default_latitude", VIK_LAYER_PARAM_DOUBLE, VIK_LOCATION_LAT, N_("Default latitude:"), VIK_LAYER_WIDGET_SPINBUTTON, params_scales_lat, NULL }, + { VIKING_PREFERENCES_NAMESPACE "default_latitude", VIK_LAYER_PARAM_DOUBLE, VIK_LAYER_GROUP_NONE, N_("Default latitude:"), VIK_LAYER_WIDGET_SPINBUTTON, params_scales_lat, NULL, NULL }, }; static VikLayerParam prefs7[] = { - { VIKING_PREFERENCES_NAMESPACE "default_longitude", VIK_LAYER_PARAM_DOUBLE, VIK_LOCATION_LONG, N_("Default longitude:"), VIK_LAYER_WIDGET_SPINBUTTON, params_scales_long, NULL }, + { VIKING_PREFERENCES_NAMESPACE "default_longitude", VIK_LAYER_PARAM_DOUBLE, VIK_LAYER_GROUP_NONE, N_("Default longitude:"), VIK_LAYER_WIDGET_SPINBUTTON, params_scales_long, NULL, NULL }, }; /* External/Export Options */ static gchar * params_kml_export_units[] = {"Metric", "Statute", "Nautical", NULL}; +static gchar * params_gpx_export_trk_sort[] = {N_("Alphabetical"), N_("Time"), NULL}; static VikLayerParam io_prefs[] = { - { VIKING_PREFERENCES_IO_NAMESPACE "kml_export_units", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("KML File Export Units:"), VIK_LAYER_WIDGET_COMBOBOX, params_kml_export_units, NULL }, + { VIKING_PREFERENCES_IO_NAMESPACE "kml_export_units", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("KML File Export Units:"), VIK_LAYER_WIDGET_COMBOBOX, params_kml_export_units, NULL, NULL }, + { VIKING_PREFERENCES_IO_NAMESPACE "gpx_export_track_sort", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("GPX Track Order:"), VIK_LAYER_WIDGET_COMBOBOX, params_gpx_export_trk_sort, NULL, NULL }, }; #ifndef WINDOWS static VikLayerParam io_prefs_non_windows[] = { - { VIKING_PREFERENCES_IO_NAMESPACE "image_viewer", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("Image Viewer:"), VIK_LAYER_WIDGET_FILEENTRY, NULL, NULL }, + { VIKING_PREFERENCES_IO_NAMESPACE "image_viewer", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("Image Viewer:"), VIK_LAYER_WIDGET_FILEENTRY, NULL, NULL, NULL }, }; #endif +static VikLayerParam io_prefs_external_gpx[] = { + { VIKING_PREFERENCES_IO_NAMESPACE "external_gpx_1", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("External GPX Program 1:"), VIK_LAYER_WIDGET_FILEENTRY, NULL, NULL, NULL }, + { VIKING_PREFERENCES_IO_NAMESPACE "external_gpx_2", VIK_LAYER_PARAM_STRING, VIK_LAYER_GROUP_NONE, N_("External GPX Program 2:"), VIK_LAYER_WIDGET_FILEENTRY, NULL, NULL, NULL }, +}; + /* End of Options static stuff */ void a_vik_preferences_init () { + // Defaults for the options are setup here a_preferences_register_group ( VIKING_PREFERENCES_GROUP_KEY, _("General") ); VikLayerParamData tmp; @@ -115,10 +123,20 @@ void a_vik_preferences_init () tmp.u = VIK_KML_EXPORT_UNITS_METRIC; a_preferences_register(&io_prefs[0], tmp, VIKING_PREFERENCES_IO_GROUP_KEY); + tmp.u = VIK_GPX_EXPORT_TRK_SORT_TIME; + a_preferences_register(&io_prefs[1], tmp, VIKING_PREFERENCES_IO_GROUP_KEY); + #ifndef WINDOWS - tmp.s = "eog"; + tmp.s = "xdg-open"; a_preferences_register(&io_prefs_non_windows[0], tmp, VIKING_PREFERENCES_IO_GROUP_KEY); #endif + + // JOSM for OSM editing around a GPX track + tmp.s = "josm"; + a_preferences_register(&io_prefs_external_gpx[0], tmp, VIKING_PREFERENCES_IO_GROUP_KEY); + // Add a second external program - another OSM editor by default + tmp.s = "merkaartor"; + a_preferences_register(&io_prefs_external_gpx[1], tmp, VIKING_PREFERENCES_IO_GROUP_KEY); } vik_degree_format_t a_vik_get_degree_format ( ) @@ -175,13 +193,30 @@ gdouble a_vik_get_default_long ( ) vik_kml_export_units_t a_vik_get_kml_export_units ( ) { vik_kml_export_units_t units; - units = a_preferences_get(VIKING_PREFERENCES_NAMESPACE "kml_export_units")->u; + units = a_preferences_get(VIKING_PREFERENCES_IO_NAMESPACE "kml_export_units")->u; return units; } +vik_gpx_export_trk_sort_t a_vik_get_gpx_export_trk_sort ( ) +{ + vik_gpx_export_trk_sort_t sort; + sort = a_preferences_get(VIKING_PREFERENCES_IO_NAMESPACE "gpx_export_track_sort")->u; + return sort; +} + #ifndef WINDOWS const gchar* a_vik_get_image_viewer ( ) { return a_preferences_get(VIKING_PREFERENCES_IO_NAMESPACE "image_viewer")->s; } #endif + +const gchar* a_vik_get_external_gpx_program_1 ( ) +{ + return a_preferences_get(VIKING_PREFERENCES_IO_NAMESPACE "external_gpx_1")->s; +} + +const gchar* a_vik_get_external_gpx_program_2 ( ) +{ + return a_preferences_get(VIKING_PREFERENCES_IO_NAMESPACE "external_gpx_2")->s; +}