[GRASS-SVN] r38151 - in grass/trunk/gui/wxpython: . gui_modules
svn_grass at osgeo.org
svn_grass at osgeo.org
Wed Jul 1 16:21:57 EDT 2009
Author: martinl
Date: 2009-07-01 16:21:56 -0400 (Wed, 01 Jul 2009)
New Revision: 38151
Modified:
grass/trunk/gui/wxpython/gui_modules/mapdisp.py
grass/trunk/gui/wxpython/gui_modules/preferences.py
grass/trunk/gui/wxpython/gui_modules/utils.py
grass/trunk/gui/wxpython/wxgui.py
Log:
wxGUI: latlong bug-fixes
(merge from devbr6, r38150)
Modified: grass/trunk/gui/wxpython/gui_modules/mapdisp.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/mapdisp.py 2009-07-01 20:09:12 UTC (rev 38150)
+++ grass/trunk/gui/wxpython/gui_modules/mapdisp.py 2009-07-01 20:21:56 UTC (rev 38151)
@@ -554,19 +554,21 @@
proj, coord = utils.ReprojectCoordinates(coord = (e, n),
projOut = UserSettings.Get(group='display',
key='projection',
- subkey='proj4'))
+ subkey='proj4'),
+ flags = 'd')
if coord:
+ e, n = coord
if proj in ('ll', 'latlong', 'longlat'):
- self.statusbar.SetStatusText("%s, %s" % (coord[0], coord[1]), 0)
+ self.statusbar.SetStatusText("%s" % utils.Deg2DMS(e, n), 0)
else:
- self.statusbar.SetStatusText("%.2f, %.2f" % (coord[0], coord[1]), 0)
+ self.statusbar.SetStatusText("%.2f; %.2f" % (e, n), 0)
else:
self.statusbar.SetStatusText(_("Error in projection"), 0)
else:
if self.Map.projinfo['proj'] == 'll':
self.statusbar.SetStatusText("%s" % utils.Deg2DMS(e, n), 0)
else:
- self.statusbar.SetStatusText("%.2f, %.2f" % (e, n), 0)
+ self.statusbar.SetStatusText("%.2f; %.2f" % (e, n), 0)
event.Skip()
@@ -787,16 +789,55 @@
Go to position
"""
try:
- e, n = map(float, self.statusbarWin['goto'].GetValue().split(','))
+ if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
+ UserSettings.Get(group='display', key='projection', subkey='proj4'):
+ # reproject values
+ projIn = UserSettings.Get(group='display',
+ key='projection',
+ subkey='proj4')
+ projOut = gcmd.RunCommand('g.proj',
+ flags = 'jf',
+ read = True)
+ proj = projIn.split(' ')[0].split('=')[1]
+ if proj in ('ll', 'latlong', 'longlat'):
+ e, n = self.statusbarWin['goto'].GetValue().split(';')
+ e, n = utils.DMS2Deg(e, n)
+ proj, coord1 = utils.ReprojectCoordinates(coord = (e, n),
+ projIn = projIn,
+ projOut = projOut, flags = 'd')
+ e, n = coord1
+ else:
+ e, n = map(float, self.statusbarWin['goto'].GetValue().split(';'))
+ proj, coord1 = utils.ReprojectCoordinates(coord = (e, n),
+ projIn = projIn,
+ projOut = projOut, flags = 'd')
+ e, n = coord1
+ else:
+ if self.Map.projinfo['proj'] == 'll':
+ e, n = self.statusbarWin['goto'].GetValue().split(';')
+ else:
+ e, n = map(float, self.statusbarWin['goto'].GetValue().split(';'))
+
+ region = self.Map.GetCurrentRegion()
+ if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
+ UserSettings.Get(group='display', key='projection', subkey='proj4'):
+ region['center_easting'], region['center_northing'] = e, n
+ else:
+ if self.Map.projinfo['proj'] == 'll':
+ region['center_easting'], region['center_northing'] = utils.DMS2Deg(e, n)
+ else:
+ region['center_easting'], region['center_northing'] = e, n
except ValueError:
region = self.Map.GetCurrentRegion()
- self.statusbarWin['goto'].SetValue("%.2f, %.2f" % (region['center_easting'],
- region['center_northing']))
+ if self.Map.projinfo['proj'] == 'll':
+ self.statusbarWin['goto'].SetValue("%s" % utils.Deg2DMS(region['center_easting'],
+ region['center_northing']))
+ else:
+ self.statusbarWin['goto'].SetValue("%.2f; %.2f" % (region['center_easting'],
+ region['center_northing']))
return
-
- region = self.Map.GetCurrentRegion()
- region['center_northing'] = n
- region['center_easting'] = e
+
+
dn = (region['nsres'] * region['rows']) / 2.
region['n'] = region['center_northing'] + dn
region['s'] = region['center_northing'] - dn
@@ -828,67 +869,73 @@
# enable long help
self.StatusbarEnableLongHelp()
- elif self.statusbarWin['toggle'].GetSelection() == 1: # Extent
- if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
- UserSettings.Get(group='display', key='projection', subkey='proj4'):
- projOut = UserSettings.Get(group='display',
- key='projection',
- subkey='proj4')
- proj, coord1 = utils.ReprojectCoordinates(coord = (self.Map.region["w"], self.Map.region["s"]),
- projOut = projOut)
- proj, coord2 = utils.ReprojectCoordinates(coord = (self.Map.region["e"], self.Map.region["n"]),
- projOut = projOut)
-
- if coord1 and coord2:
- if proj in ('ll', 'latlong', 'longlat'):
- self.statusbar.SetStatusText("%s - %s, %s - %s" %
- (coord1[0], coord2[0],
- coord1[1], coord2[1]))
- else:
- self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f" %
- (float(coord1[0]), float(coord2[0]),
- float(coord1[1]), float(coord2[1])))
- else:
- self.statusbar.SetStatusText(_("Error in projection"), 0)
+ elif self.statusbarWin['toggle'].GetSelection() in (1, 2): # Extent
+ sel = self.statusbarWin['toggle'].GetSelection()
+ if sel == 1:
+ region = self.Map.region
else:
- self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f" %
- (self.Map.region["w"], self.Map.region["e"],
- self.Map.region["s"], self.Map.region["n"]), 0)
- # enable long help
- self.StatusbarEnableLongHelp()
+ region = self.Map.GetRegion() # computation region
- elif self.statusbarWin['toggle'].GetSelection() == 2: # Comp. region
- compregion = self.Map.GetRegion()
if UserSettings.Get(group='display', key='projection', subkey='enabled') and \
UserSettings.Get(group='display', key='projection', subkey='proj4'):
projOut = UserSettings.Get(group='display',
key='projection',
subkey='proj4')
- proj, coord1 = utils.ReprojectCoordinates(coord = (compregion["w"], compregion["s"]),
+ proj, coord1 = utils.ReprojectCoordinates(coord = (region["w"], region["s"]),
projOut = projOut)
- proj, coord2 = utils.ReprojectCoordinates(coord = (compregion["e"], compregion["n"]),
+ proj, coord2 = utils.ReprojectCoordinates(coord = (region["e"], region["n"]),
projOut = projOut)
- proj, coord3 = utils.ReprojectCoordinates(coord = (compregion["ewres"], compregion["nsres"]),
- projOut = projOut)
+ if sel == 2:
+ proj, coord3 = utils.ReprojectCoordinates(coord = (region["ewres"], region["nsres"]),
+ projOut = projOut)
- if coord1 and coord2 and coord3:
+ if coord1 and coord2:
if proj in ('ll', 'latlong', 'longlat'):
- self.statusbar.SetStatusText("%s - %s, %s - %s (%s, %s)" %
- (coord1[0], coord2[0],
- coord1[1], coord2[1],
- coord3[0], coord3[1]))
+ w, s = utils.Deg2DMS(coord1[0], coord1[1], string = False)
+ e, n = utils.Deg2DMS(coord2[0], coord2[1], string = False)
+ if sel == 1:
+ self.statusbar.SetStatusText("%s - %s, %s - %s" %
+ (w, e, s, n), 0)
+ else:
+ ewres, nsres = utils.Deg2DMS(coord3[0], coord3[1], string = False)
+ self.statusbar.SetStatusText("%s - %s, %s - %s (%s, %s)" %
+ (w, e, s, n, ewres, nsres), 0)
else:
- self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f (%.2f, %.2f)" %
- (float(coord1[0]), float(coord2[0]),
- float(coord1[1]), float(coord2[1]),
- float(coord3[0]), float(coord3[1])))
+ w, s = coord1
+ e, n = coord2
+ if sel == 1:
+ self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f" %
+ (w, e, s, n), 0)
+ else:
+ ewres, nsres = coord3
+ self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f (%.2f, %.2f)" %
+ (w, e, s, n, ewres, nsres), 0)
else:
self.statusbar.SetStatusText(_("Error in projection"), 0)
else:
- self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f (%.2f, %.2f)" %
- (compregion["w"], compregion["e"],
- compregion["s"], compregion["n"],
- compregion["ewres"], compregion["nsres"]), 0)
+ if self.Map.projinfo['proj'] == 'll':
+ w, s = utils.Deg2DMS(region["w"], region["s"],
+ string = False)
+ e, n = utils.Deg2DMS(region["e"], region["n"],
+ string = False)
+ if sel == 1:
+ self.statusbar.SetStatusText("%s - %s, %s - %s" %
+ (w, e, s, n), 0)
+ else:
+ ewres, nsres = utils.Deg2DMS(region['ewres'], region['nsres'],
+ string = False)
+ self.statusbar.SetStatusText("%s - %s, %s - %s (%s, %s)" %
+ (w, e, s, n, ewres, nsres), 0)
+ else:
+ w, s = region["w"], region["s"]
+ e, n = region["e"], region["n"]
+ if sel == 1:
+ self.statusbar.SetStatusText("%.2f - %.2f, %.2f - %.2f" %
+ (w, e, s, n), 0)
+ else:
+ ewres, nsres = region['ewres'], region['nsres']
+ self.statusbar.SetStatusText("%s - %s, %s - %s (%s, %s)" %
+ (w, e, s, n, ewres, nsres), 0)
# enable long help
self.StatusbarEnableLongHelp()
@@ -972,14 +1019,20 @@
subkey='proj4'))
if coord:
if proj in ('ll', 'latlong', 'longlat'):
- self.statusbarWin['goto'].SetValue("%s, %s" % (coord[0],
+ self.statusbarWin['goto'].SetValue("%s; %s" % (coord[0],
coord[1]))
else:
- self.statusbarWin['goto'].SetValue("%.2f, %.2f" % (coord[0],
+ self.statusbarWin['goto'].SetValue("%.2f; %.2f" % (coord[0],
coord[1]))
+ else:
+ self.statusbar.SetStatusText(_("Error in projection"), 0)
else:
- self.statusbarWin['goto'].SetValue("%.2f, %.2f" % (region['center_easting'],
- region['center_northing']))
+ if self.Map.projinfo['proj'] == 'll':
+ self.statusbarWin['goto'].SetValue("%s" % utils.Deg2DMS(region['center_easting'],
+ region['center_northing']))
+ else:
+ self.statusbarWin['goto'].SetValue("%.2f; %.2f" % (region['center_easting'],
+ region['center_northing']))
self.statusbarWin['goto'].Show()
# disable long help
Modified: grass/trunk/gui/wxpython/gui_modules/preferences.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/preferences.py 2009-07-01 20:09:12 UTC (rev 38150)
+++ grass/trunk/gui/wxpython/gui_modules/preferences.py 2009-07-01 20:21:56 UTC (rev 38151)
@@ -1591,11 +1591,15 @@
choices = map(str, self.epsgCodeDict.keys())
list.SetItems(choices)
- list.SetSelection(0)
- code = int(list.GetStringSelection())
+ code = int(list.GetValue())
win = self.FindWindowById(self.winId['display:projection:proj4'])
- win.SetValue(self.epsgCodeDict[code][1])
-
+ if self.epsgCodeDict.has_key(code):
+ win.SetValue(self.epsgCodeDict[code][1])
+ else:
+ list.SetSelection(0)
+ code = int(list.GetStringSelection())
+ win.SetValue(self.epsgCodeDict[code][1])
+
def OnSetProj(self, event):
"""!Enable mapdisplay window statusbar projection"""
checked = event.IsChecked()
Modified: grass/trunk/gui/wxpython/gui_modules/utils.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/utils.py 2009-07-01 20:09:12 UTC (rev 38150)
+++ grass/trunk/gui/wxpython/gui_modules/utils.py 2009-07-01 20:21:56 UTC (rev 38151)
@@ -266,20 +266,24 @@
return layers
-def Deg2DMS(lon, lat):
+def Deg2DMS(lon, lat, string = True):
"""!Convert deg value to dms string
- @param lat latitude
- @param lon longitude
-
- @return DMS string
+ @param lon longitude (x)
+ @param lat latitude (y)
+ @param string True to return string otherwise tuple
+
+ @return DMS string or tuple of values
@return empty string on error
"""
try:
flat = float(lat)
flon = float(lon)
except ValueError:
- return ''
+ if string:
+ return ''
+ else:
+ return None
# fix longitude
while flon > 180.0:
@@ -303,31 +307,88 @@
slat = __ll_parts(flat)
slon = __ll_parts(flon)
- return slon + hlon + '; ' + slat + hlat
+ if string:
+ return slon + hlon + '; ' + slat + hlat
+
+ 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'
+def DMS2Deg(lon, lat):
+ """!Convert dms value to deg
+
+ @param lon longitude (x)
+ @param lat latitude (y)
- 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 tuple of converted values
+ @return ValueError on error
+ """
+ x = __ll_parts(lon, reverse = True)
+ y = __ll_parts(lat, reverse = True)
- return str(d) + ':' + m + ':' + s
+ return (x, y)
+def __ll_parts(value, reverse = False):
+ """!Converts deg to d:m:s string
+
+ @param value value to be converted
+ @param reverse True to convert from d:m:s to deg
+
+ @return converted value (string/float)
+ @return ValueError on error (reverse == True)
+ """
+ if not reverse:
+ 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
+ else: # -> reverse
+ try:
+ d, m, s = value.split(':')
+ hs = s[-1]
+ s = s[:-1]
+ except ValueError:
+ try:
+ d, m = value.split(':')
+ hs = m[-1]
+ m = m[:-1]
+ s = '0.0'
+ except ValueError:
+ try:
+ d = value
+ hs = d[-1]
+ d = d[:-1]
+ m = '0'
+ s = '0.0'
+ except ValueError:
+ raise ValueError
+
+ if hs not in ('N', 'S', 'E', 'W'):
+ raise ValueError
+
+ coef = 1.0
+ if hs in ('S', 'W'):
+ coef = -1.0
+
+ fm = int(m) / 60.0
+ fs = float(s) / (60 * 60)
+
+ return coef * (float(d) + fm + fs)
+
def GetCmdString(cmd):
"""
Get GRASS command as string.
@@ -442,7 +503,7 @@
proj = projOut.split(' ')[0].split('=')[1]
except IndexError:
proj = ''
- if proj in ('ll', 'latlong', 'longlat'):
+ if proj in ('ll', 'latlong', 'longlat') and 'd' not in flags:
return (proj, (e, n))
else:
return (proj, (float(e), float(n)))
Modified: grass/trunk/gui/wxpython/wxgui.py
===================================================================
--- grass/trunk/gui/wxpython/wxgui.py 2009-07-01 20:09:12 UTC (rev 38150)
+++ grass/trunk/gui/wxpython/wxgui.py 2009-07-01 20:21:56 UTC (rev 38151)
@@ -892,7 +892,9 @@
def OnPreferences(self, event):
"""!General GUI preferences/settings"""
- preferences.PreferencesDialog(parent=self).ShowModal()
+ dlg = preferences.PreferencesDialog(parent=self)
+ dlg.CenterOnScreen()
+ dlg.ShowModal()
def DispHistogram(self, event):
"""
More information about the grass-commit
mailing list