From 8fff393b8b3e984c3b6e180aee7f5b3618c09015 Mon Sep 17 00:00:00 2001 From: Serge Noiraud Date: Sun, 15 May 2011 08:46:57 +0000 Subject: [PATCH] geography : use the same map directory for all views. adding possibility to change the zoom when we center the map. svn: r17502 --- src/config.py | 1 + src/plugins/lib/maps/geography.py | 27 +++++++++++++++++++++++++-- src/plugins/view/geoperson.py | 7 ++++--- 3 files changed, 30 insertions(+), 5 deletions(-) diff --git a/src/config.py b/src/config.py index df5e93bc3..66bcd053c 100644 --- a/src/config.py +++ b/src/config.py @@ -164,6 +164,7 @@ register('geography.center-lat', 0.0) register('geography.map', "person") register('geography.map_service', 1) register('geography.zoom', 0) +register('geography.zoom_when_center', 12) register('geography.show_cross', False) register('geography.path', "") diff --git a/src/plugins/lib/maps/geography.py b/src/plugins/lib/maps/geography.py index 57b095255..1e2c99538 100644 --- a/src/plugins/lib/maps/geography.py +++ b/src/plugins/lib/maps/geography.py @@ -120,6 +120,7 @@ class GeoGraphyView(osmGpsMap, NavigationView): ('geography.path', GEOGRAPHY_PATH), ('geography.zoom', 10), + ('geography.zoom_when_center', 12), ('geography.show_cross', True), ('geography.lock', False), ('geography.center-lat', 0.0), @@ -213,6 +214,22 @@ class GeoGraphyView(osmGpsMap, NavigationView): This method will be called after the ini file is initialized, use it to monitor changes in the ini file """ + self._config.connect("geography.path", + self.set_path) + self._config.connect("geography.zoom_when_center", + self.set_zoom_when_center) + + def set_path(self, client, cnxn_id, entry, data): + """ + All geography views must have the same path for maps + """ + config.set("geography.path", entry) + + def set_zoom_when_center(self, client, cnxn_id, entry, data): + """ + All geography views must have the same zoom_when_center for maps + """ + config.set("geography.zoom_when_center", int(entry)) #------------------------------------------------------------------------- # @@ -297,7 +314,7 @@ class GeoGraphyView(osmGpsMap, NavigationView): """ Center the map at the new position then save it. """ - self.osm.set_center_and_zoom(lat, lon, 12) + self.osm.set_center_and_zoom(lat, lon, config.get("geography.zoom_when_center")) self.save_center(lat, lon) #------------------------------------------------------------------------- @@ -752,7 +769,9 @@ class GeoGraphyView(osmGpsMap, NavigationView): Function that builds the widget in the configuration dialog for the map options. """ - table = gtk.Table(2, 2) + self._config.set('geography.path',config.get('geography.path')) + self._config.set('geography.zoom_when_center',config.get('geography.zoom_when_center')) + table = gtk.Table(1, 1) table.set_border_width(12) table.set_col_spacings(6) table.set_row_spacings(6) @@ -766,6 +785,10 @@ class GeoGraphyView(osmGpsMap, NavigationView): 'You can remove all tiles placed in the above path.\n' 'Be careful! If you have no internet, you\'ll get no map.'), 3) + configdialog.add_slider(table, + _('Zoom used when centering'), + 4, 'geography.zoom_when_center', + (2, 16)) # there is no button. I need to found a solution for this. # it can be very dangerous ! if someone put / in geography.path ... # perhaps we need some contrĂ´l on this path : diff --git a/src/plugins/view/geoperson.py b/src/plugins/view/geoperson.py index d447bf52f..b9409710f 100644 --- a/src/plugins/view/geoperson.py +++ b/src/plugins/view/geoperson.py @@ -119,6 +119,7 @@ class GeoPerson(GeoGraphyView): ('geography.path', constants.GEOGRAPHY_PATH), ('geography.zoom', 10), + ('geography.zoom_when_center', 12), ('geography.show_cross', True), ('geography.lock', False), ('geography.center-lat', 0.0), @@ -504,14 +505,14 @@ class GeoPerson(GeoGraphyView): configdialog.add_text(table, _('Animation speed in milliseconds (big value means slower)'), 1) - self.config_size_slider = configdialog.add_slider(table, + configdialog.add_slider(table, "", 2, 'geography.speed', (100, 1000)) configdialog.add_text(table, _('How many steps between two markers when we are on large move ?'), 3) - self.config_size_slider = configdialog.add_slider(table, + configdialog.add_slider(table, "", 4, 'geography.steps', (10, 100)) @@ -519,7 +520,7 @@ class GeoPerson(GeoGraphyView): _('The minimum latitude/longitude to select large move.\n' 'The value is in tenth of degree.'), 5) - self.config_size_slider = configdialog.add_slider(table, + configdialog.add_slider(table, "", 6, 'geography.maximum_lon_lat', (5, 50))