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

svn_grass at osgeo.org svn_grass at osgeo.org
Tue Sep 13 18:08:07 EDT 2011


Author: martinl
Date: 2011-09-13 15:08:07 -0700 (Tue, 13 Sep 2011)
New Revision: 48282

Modified:
   grass/trunk/gui/wxpython/gui_modules/mapdisp_vdigit.py
   grass/trunk/gui/wxpython/gui_modules/wxvdigit.py
   grass/trunk/gui/wxpython/gui_modules/wxvdriver.py
Log:
wxGUI/vdigit: fix copying feature from background map


Modified: grass/trunk/gui/wxpython/gui_modules/mapdisp_vdigit.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/mapdisp_vdigit.py	2011-09-13 21:12:16 UTC (rev 48281)
+++ grass/trunk/gui/wxpython/gui_modules/mapdisp_vdigit.py	2011-09-13 22:08:07 UTC (rev 48282)
@@ -21,10 +21,11 @@
 import dbm_dialogs
 
 import gcmd
-from debug import Debug
+from debug          import Debug
 from mapdisp_window import BufferedWindow
-from preferences import globalSettings as UserSettings
-
+from preferences    import globalSettings as UserSettings
+from utils          import ListOfCatsToRange
+from globalvar      import QUERYLAYER
 from vdigit import VDigitCategoryDialog
 from vdigit import VDigitZBulkDialog
 from vdigit import VDigitDuplicatesDialog
@@ -705,7 +706,7 @@
         if UserSettings.Get(group = 'vdigit', key = 'bgmap',
                             subkey = 'value', internal = True) == '':
             # no background map -> copy from current vector map layer
-            nselected = self.digit.GetDisplay().SelectLinesByBox((pos1, pos2))
+            nselected = self.bdigit.GetDisplay().SelectLinesByBox((pos1, pos2))
             
             if nselected > 0:
                 # highlight selected features
@@ -714,17 +715,15 @@
                 self.UpdateMap(render = False, renderVector = False)
         else:
             # copy features from background map
-            self.copyIds += self.digit.SelectLinesFromBackgroundMap(bbox = (pos1, pos2))
+            self.copyIds = self.digit.SelectLinesFromBackgroundMap(bbox = (pos1, pos2))
             if len(self.copyIds) > 0:
                 color = UserSettings.Get(group = 'vdigit', key = 'symbol',
                                          subkey = ['highlight', 'color'])
-                colorStr = str(color[0]) + ":" + \
-                    str(color[1]) + ":" + \
-                    str(color[2])
+                colorStr = str(color[0]) + ":" + str(color[1]) + ":" + str(color[2])
                 dVectTmp = ['d.vect',
                             'map=%s' % UserSettings.Get(group = 'vdigit', key = 'bgmap',
                                                         subkey = 'value', internal = True),
-                            'cats=%s' % utils.ListOfCatsToRange(self.copyIds),
+                            'cats=%s' % ListOfCatsToRange(self.copyIds),
                             '-i',
                             'color=%s' % colorStr,
                             'fcolor=%s' % colorStr,
@@ -733,16 +732,16 @@
                 
                 if not self.layerTmp:
                     self.layerTmp = self.Map.AddLayer(type = 'vector',
-                                                      name = globalvar.QUERYLAYER,
+                                                      name = QUERYLAYER,
                                                       command = dVectTmp)
                 else:
                     self.layerTmp.SetCmd(dVectTmp)
-                
-                self.UpdateMap(render = True, renderVector = False)
             else:
-                self.UpdateMap(render = False, renderVector = False)
+                if self.layerTmp:
+                    self.Map.DeleteLayer(self.layerTmp)
+                    self.layerTmp = None
             
-            self.redrawAll = None
+            self.UpdateMap(render = True, renderVector = True)
             
     def OnLeftUpBulkLine(self, event):
         """!Left mouse button released - vector digitizer z-bulk line

Modified: grass/trunk/gui/wxpython/gui_modules/wxvdigit.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/wxvdigit.py	2011-09-13 21:12:16 UTC (rev 48281)
+++ grass/trunk/gui/wxpython/gui_modules/wxvdigit.py	2011-09-13 22:08:07 UTC (rev 48282)
@@ -1729,15 +1729,12 @@
         
         @return list of selected feature ids
         """
-        ret = list()
+        # try select features by box first
+        if self._display.SelectLinesByBox(bbox, poMapInfo = self.poBgMapInfo) < 1:
+            self._display.SelectLineByPoint(bbox[0], poMapInfo = self.poBgMapInfo)['line']
+            
+        return self._display.selected['ids']
         
-        # try select features by Box
-        ids = self._display.SelectLinesByBox(bbox, poMapInfo = self.poBgMapInfo)
-        if not ids:
-            ids = [self._display.SelectLineByPoint(bbox[0], poMapInfo = self.poBgMapInfo)['line'], ]
-        
-        return ids
-
     def GetUndoLevel(self):
         """!Get undo level (number of active changesets)
         

Modified: grass/trunk/gui/wxpython/gui_modules/wxvdriver.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/wxvdriver.py	2011-09-13 21:12:16 UTC (rev 48281)
+++ grass/trunk/gui/wxpython/gui_modules/wxvdriver.py	2011-09-13 22:08:07 UTC (rev 48282)
@@ -527,11 +527,6 @@
             # select by ids
             self.selected['cats'] = list()
         
-        if thisMapInfo:
-            selected = self.selected['ids']
-        else:
-            selected = list()
-        
         poList = Vect_new_list()
         x1, y1 = bbox[0]
         x2, y2 = bbox[1]
@@ -568,9 +563,9 @@
                     continue # skip lines just overlapping bbox
             
             if not self._isSelected(line):
-                selected.append(line)
+                self.selected['ids'].append(line)
             else:
-                selected.remove(line)
+                self.selected['ids'].remove(line)
         
         Vect_destroy_line_struct(poBbox)
         Vect_destroy_list(poList)
@@ -601,11 +596,6 @@
             # select by ids 
             self.selected['cats'] = list()
         
-        if thisMapInfo:
-            selected = self.selected['ids']
-        else:
-            selected = list()
-        
         poFound = Vect_new_list()
         
         lineNearest = Vect_find_line_list(poMapInfo, point[0], point[1], 0,
@@ -615,9 +605,9 @@
         
         if lineNearest > 0:
             if not self._isSelected(lineNearest):
-                selected.append(lineNearest)
+                self.selected['ids'].append(lineNearest)
             else:
-                selected.remove(lineNearest)
+                self.selected['ids'].remove(lineNearest)
         
         px = c_double()
         py = c_double()
@@ -635,14 +625,14 @@
 	    for i in range(found.n_values):
 		line = found.value[i]
 		if line != lineNearest:
-                    selected.append(line)
+                    self.selected['ids'].append(line)
 	    
             self.GetDuplicates()
 	    
 	    for i in range(found.n_values):
 		line = found.value[i]
 		if line != lineNearest and not self._isDuplicated(line):
-                    selected.remove(line)
+                    self.selected['ids'].remove(line)
         
         Vect_destroy_list(poFound)
         



More information about the grass-commit mailing list