[GRASS-SVN] r56537 - grass/branches/develbranch_6/gui/wxpython/nviz
svn_grass at osgeo.org
svn_grass at osgeo.org
Sat Jun 1 10:10:26 PDT 2013
Author: annakrat
Date: 2013-06-01 10:10:25 -0700 (Sat, 01 Jun 2013)
New Revision: 56537
Modified:
grass/branches/develbranch_6/gui/wxpython/nviz/mapwindow.py
grass/branches/develbranch_6/gui/wxpython/nviz/tools.py
Log:
wxNviz: load areas as boundaries and centroids (merge from trunk, r56495)
Modified: grass/branches/develbranch_6/gui/wxpython/nviz/mapwindow.py
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/nviz/mapwindow.py 2013-06-01 17:05:15 UTC (rev 56536)
+++ grass/branches/develbranch_6/gui/wxpython/nviz/mapwindow.py 2013-06-01 17:10:25 UTC (rev 56537)
@@ -1301,17 +1301,12 @@
elif type == '3d-raster':
self.LoadRaster3d(item)
elif type == 'vector':
- # data = self.tree.GetPyData(item)[0]['nviz']
- # vecType = []
- # if data and 'vector' in data:
- # for v in ('lines', 'points'):
- # if data['vector'][v]:
- # vecType.append(v)
layer = self.tree.GetPyData(item)[0]['maplayer']
- npoints, nlines, nfeatures, mapIs3D = self.lmgr.nviz.VectorInfo(layer)
- if npoints > 0:
+ vInfo = grass.vector_info_topo(layer.GetName())
+ if (vInfo['points']) > 0:
+ # include vInfo['centroids'] to initially load centroids
self.LoadVector(item, points = True)
- if nlines > 0 or mapIs3D:
+ if (vInfo['lines'] + vInfo['boundaries']) > 0 or vInfo['map3d']:
self.LoadVector(item, points = False)
except GException, e:
@@ -1350,10 +1345,10 @@
self.UnloadRaster3d(layer)
elif ltype == 'vector':
maplayer = self.tree.GetPyData(layer)[0]['maplayer']
- npoints, nlines, nfeatures, mapIs3D = self.lmgr.nviz.VectorInfo(maplayer)
- if npoints > 0:
+ vInfo = grass.vector_info_topo(maplayer.GetName())
+ if (vInfo['points'] + vInfo['centroids']) > 0:
self.UnloadVector(layer, points = True)
- if nlines > 0:
+ if (vInfo['lines'] + vInfo['boundaries']) > 0 or vInfo['map3d']:
self.UnloadVector(layer, points = False)
except GException, e:
@@ -2188,10 +2183,10 @@
if type == 'raster':
self.nvizDefault.SetSurfaceDefaultProp(data['surface'])
if type == 'vector':
- npoints, nlines, nfeatures, mapIs3D = self.lmgr.nviz.VectorInfo(layer)
- if npoints > 0:
+ vInfo = grass.vector_info_topo(layer.GetName())
+ if (vInfo['points'] + vInfo['centroids']) > 0:
self.nvizDefault.SetVectorPointsDefaultProp(data['vector']['points'])
- if nlines > 0:
+ if (vInfo['lines'] + vInfo['boundaries']) > 0:
self.nvizDefault.SetVectorLinesDefaultProp(data['vector']['lines'])
def NvizCmdCommand(self):
@@ -2310,17 +2305,17 @@
markers = ['x', 'box', 'sphere', 'cube', 'diamond',
'dec_tree', 'con_tree', 'aster', 'gyro', 'histogram']
for vector in vectors:
- npoints, nlines, nfeatures, mapIs3D = self.lmgr.nviz.VectorInfo(
- self.tree.GetPyData(vector)[0]['maplayer'])
+ layerName = self.tree.GetPyData(vector)[0]['maplayer'].GetName()
+ vInfo = grass.vector_info_topo(layerName)
nvizData = self.tree.GetPyData(vector)[0]['nviz']['vector']
- if nlines > 0:
+ if (vInfo['lines'] + vInfo['boundaries']) > 0:
cmdLines += "%s," % self.tree.GetPyData(vector)[0]['maplayer'].GetName()
cmdLWidth += "%d," % nvizData['lines']['width']['value']
cmdLHeight += "%d," % nvizData['lines']['height']['value']
cmdLColor += "%s," % nvizData['lines']['color']['value']
cmdLMode += "%s," % nvizData['lines']['mode']['type']
cmdLPos += "0,0,%d," % nvizData['lines']['height']['value']
- if npoints > 0:
+ if (vInfo['points'] + vInfo['centroids']) > 0:
cmdPoints += "%s," % self.tree.GetPyData(vector)[0]['maplayer'].GetName()
cmdPWidth += "%d," % nvizData['points']['width']['value']
cmdPSize += "%d," % nvizData['points']['size']['value']
Modified: grass/branches/develbranch_6/gui/wxpython/nviz/tools.py
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/nviz/tools.py 2013-06-01 17:05:15 UTC (rev 56536)
+++ grass/branches/develbranch_6/gui/wxpython/nviz/tools.py 2013-06-01 17:10:25 UTC (rev 56537)
@@ -4450,43 +4450,20 @@
# enable/disable res widget + set draw mode
self.OnSurfaceMode(event = None)
-
- def VectorInfo(self, layer):
- """!Get number of points/lines
- @param layer MapLayer instance
-
- @return num of points/features (expect of points)
- @return None
- """
- vInfo = grass.vector_info_topo(layer.GetName())
-
- if not vInfo:
- return None
-
- nprimitives = 0
- for key, value in vInfo.iteritems():
- if key in ('points',
- 'lines',
- 'boundaries',
- 'centroids',
- 'faces',
- 'kernels'):
- nprimitives += value
-
- return (vInfo['points'], vInfo['lines'], nprimitives, vInfo['map3d'])
-
def UpdateVectorPage(self, layer, data, updateName = True):
"""!Update vector page"""
- npoints, nlines, nfeatures, mapIs3D = self.VectorInfo(layer)
- if mapIs3D:
+ vInfo = grass.vector_info_topo(layer.GetName())
+ if not vInfo:
+ return
+ if vInfo['map3d']:
desc = _("Vector map is 3D")
enable = False
else:
desc = _("Vector map is 2D")
enable = True
desc += " - " + _("%(features)d features (%(points)d points)") % \
- { 'features' : nfeatures, 'points' : npoints }
+ { 'features' : vInfo['primitives'], 'points' : vInfo['points']}
if updateName:
self.FindWindowById(self.win['vector']['map']).SetValue(layer.name)
@@ -4506,13 +4483,12 @@
showLines.SetValue(True)
else:
showLines.SetValue(False)
- if nlines > 0:
- showLines.Enable(True)
- else:
- showLines.Enable(False)
+ if (vInfo['lines'] + vInfo['boundaries']) > 0:
+ showLines.Enable(True)
+ else:
+ showLines.Enable(False)
- self.UpdateVectorShow('lines',
- showLines.IsChecked())
+ self.UpdateVectorShow('lines', showLines.IsChecked())
width = self.FindWindowById(self.win['vector']['lines']['width'])
width.SetValue(data['lines']['width']['value'])
@@ -4553,13 +4529,12 @@
showPoints.SetValue(True)
else:
showPoints.SetValue(False)
- if npoints > 0:
- showPoints.Enable(True)
- else:
- showPoints.Enable(False)
+ if (vInfo['points'] + vInfo['centroids']) > 0:
+ showPoints.Enable(True)
+ else:
+ showPoints.Enable(False)
- self.UpdateVectorShow('points',
- showPoints.IsChecked())
+ self.UpdateVectorShow('points', showPoints.IsChecked())
# size, width, marker, color
for prop in ('size', 'marker', 'color'):
win = self.FindWindowById(self.win['vector']['points'][prop])
More information about the grass-commit
mailing list