[GRASS-SVN] r34835 - grass/trunk/gui/wxpython/gui_modules

svn_grass at osgeo.org svn_grass at osgeo.org
Fri Dec 12 08:34:38 EST 2008


Author: martinl
Date: 2008-12-12 08:34:38 -0500 (Fri, 12 Dec 2008)
New Revision: 34835

Modified:
   grass/trunk/gui/wxpython/gui_modules/mapdisp.py
   grass/trunk/gui/wxpython/gui_modules/render.py
   grass/trunk/gui/wxpython/gui_modules/utils.py
Log:
wxGUI: can't handle whole-Earth extent (trac #395)
       (merge from devbr6, r34834)


Modified: grass/trunk/gui/wxpython/gui_modules/mapdisp.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/mapdisp.py	2008-12-12 13:32:48 UTC (rev 34834)
+++ grass/trunk/gui/wxpython/gui_modules/mapdisp.py	2008-12-12 13:34:38 UTC (rev 34835)
@@ -2183,8 +2183,16 @@
 
         # if new region has been calculated, set the values
         if newreg != {}:
+            # LL locations
+            if self.parent.Map.projinfo['proj'] == 'll':
+                if newreg['n'] > 90.0:
+                    newreg['n'] = 90.0
+                if newreg['s'] < -90.0:
+                    newreg['s'] = -90.0
+            
             ce = newreg['w'] + (newreg['e'] - newreg['w']) / 2
             cn = newreg['s'] + (newreg['n'] - newreg['s']) / 2
+            
             if hasattr(self, "vdigitMove"):
                 # xo = self.Cell2Pixel((self.Map.region['center_easting'], self.Map.region['center_northing']))
                 # xn = self.Cell2Pixel(ce, cn))
@@ -2641,13 +2649,8 @@
         # Init print module and classes
         #
         self.printopt = disp_print.PrintOptions(self, self.MapWindow)
-
+        
         #
-        # Current location information
-        #
-        self.projinfo = self.Map.ProjInfo()
-
-        #
         # Initialization of digitization tool
         #
         self.digit = None
@@ -2910,7 +2913,10 @@
                 self.statusbar.SetStatusText("%.2f, %.2f (seg: %.2f; tot: %.2f)" % \
                                                  (e, n, distance_seg, distance_tot), 0)
             else:
-                self.statusbar.SetStatusText("%.2f, %.2f" % (e, n), 0)
+                if self.Map.projinfo['proj'] == 'll':
+                    self.statusbar.SetStatusText("%s" % utils.Deg2DMS(e, n), 0)
+                else:
+                    self.statusbar.SetStatusText("%.2f, %.2f" % (e, n), 0)
         
         event.Skip()
 
@@ -3658,8 +3664,8 @@
                                            'to measure.%s'
                                            'Double click with left button to clear.') % \
                                              (os.linesep), style)
-        if self.projinfo['proj'] != 'xy':
-            units = self.projinfo['units']
+        if self.Map.projinfo['proj'] != 'xy':
+            units = self.Map.projinfo['units']
             style = self.gismanager.goutput.cmd_output.StyleCommand
             self.gismanager.goutput.WriteLog(_('Measuring distance') + ' ('
                                              + units + '):',
@@ -3688,7 +3694,7 @@
         strdist = str(d)
         strtotdist = str(td)
 
-        if self.projinfo['proj'] == 'xy' or 'degree' not in self.projinfo['unit']:
+        if self.Map.projinfo['proj'] == 'xy' or 'degree' not in self.Map.projinfo['unit']:
             angle = int(math.degrees(math.atan2(north,east)) + 0.5)
             angle = angle+90
             if angle < 0: angle = 360+angle
@@ -3722,7 +3728,7 @@
         as a function of length. From code by Hamish Bowman
         Grass Development Team 2006"""
 
-        mapunits = self.projinfo['units']
+        mapunits = self.Map.projinfo['units']
         if mapunits == 'metres': mapunits = 'meters'
         outunits = mapunits
         dist = float(dist)
@@ -3815,7 +3821,7 @@
         id = 0 # unique index for overlay layer
 
         # If location is latlon, only display north arrow (scale won't work)
-        #        proj = self.projinfo['proj']
+        #        proj = self.Map.projinfo['proj']
         #        if proj == 'll':
         #            barcmd = 'd.barscale -n'
         #        else:

Modified: grass/trunk/gui/wxpython/gui_modules/render.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/render.py	2008-12-12 13:32:48 UTC (rev 34834)
+++ grass/trunk/gui/wxpython/gui_modules/render.py	2008-12-12 13:34:38 UTC (rev 34835)
@@ -381,6 +381,8 @@
         os.environ["GRASS_TRANSPARENT"] = "TRUE"
         os.environ["GRASS_BACKGROUNDCOLOR"] = "ffffff"
 
+        self.projinfo = self.ProjInfo()
+        
     def InitRegion(self):
         """
         Initialize current region settings.
@@ -537,6 +539,13 @@
         self.region['e'] = self.region['center_easting'] + ew
         self.region['w'] = self.region['center_easting'] - ew
 
+        # LL locations
+        if self.projinfo['proj'] == 'll':
+            if self.region['n'] > 90.0:
+                self.region['n'] = 90.0
+            if self.region['s'] < -90.0:
+                self.region['s'] = -90.0
+        
     def ChangeMapSize(self, (width, height)):
         """Change size of rendered map.
         

Modified: grass/trunk/gui/wxpython/gui_modules/utils.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/utils.py	2008-12-12 13:32:48 UTC (rev 34834)
+++ grass/trunk/gui/wxpython/gui_modules/utils.py	2008-12-12 13:34:38 UTC (rev 34835)
@@ -260,6 +260,68 @@
     
     return layers
 
+def Deg2DMS(lon, lat):
+    """Convert deg value to dms string
+
+    @param lat latitude
+    @param lon longitude
+
+    @return DMS string
+    @return empty string on error
+    """
+    try:
+        flat = float(lat)
+        flon = float(lon)
+    except ValueError:
+        return ''
+
+    # fix longitude
+    while flon > 180.0:
+        flon -= 360.0
+    while flon < -180.0:
+        flon += 360.0
+
+    # hemisphere
+    if flat < 0.0:
+        flat = abs(flat)
+        hlat = 'S'
+    else:
+        hlat = 'N'
+
+    if flon < 0.0:
+        hlon = 'W'
+        flon = abs(flon)
+    else:
+        hlon = 'E'
+
+    slat = __ll_parts(flat)
+    slon = __ll_parts(flon)
+
+    return slon + hlon + '; ' + slat + hlat
+
+def __ll_parts(value):
+    """Converts deg to d:m:s string"""
+    if value == 0.0:
+        return '00:00:00.0000'
+    
+    d = int(int(value))
+    m = int((value - d) * 60)
+    s = ((value - d) * 60 - m) * 60
+    if m < 0:
+        m = '00'
+    elif m < 10:
+        m = '0' + str(m)
+    else:
+        m = str(m)
+    if s < 0:
+        s = '00.0000'
+    elif s < 10.0:
+        s = '0%.4f' % s
+    else:
+        s = '%.4f' % s
+    
+    return str(d) + ':' + m + ':' + s
+
 def reexec_with_pythonw():
     """Re-execute Python on Mac OS"""
     if sys.platform == 'darwin' and \



More information about the grass-commit mailing list