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

svn_grass at osgeo.org svn_grass at osgeo.org
Mon Sep 1 06:39:56 EDT 2008


Author: martinl
Date: 2008-09-01 06:39:54 -0400 (Mon, 01 Sep 2008)
New Revision: 33186

Modified:
   grass/trunk/gui/wxpython/gui_modules/render.py
   grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py
Log:
wxGUI: render command layer on enter
multiple commands separated by ';' can be entered, trac #268 
(merge from devbr6, r33185)


Modified: grass/trunk/gui/wxpython/gui_modules/render.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/render.py	2008-09-01 10:32:30 UTC (rev 33185)
+++ grass/trunk/gui/wxpython/gui_modules/render.py	2008-09-01 10:39:54 UTC (rev 33186)
@@ -134,8 +134,20 @@
         # execute command
         #
         try:
-            runcmd = gcmd.Command(cmd=self.cmdlist + ['--q'],
-                                  stderr=None)
+            if self.type == 'command':
+                read = False
+                for cmd in self.cmdlist:
+                    runcmd = gcmd.Command(cmd=cmd + ['--q'],
+                                          stderr=None)
+                    if runcmd.returncode != 0:
+                        break
+                    if not read:
+                        os.environ["GRASS_PNG_READ"] = "TRUE"
+                
+                os.environ["GRASS_PNG_READ"] = "FALSE"
+            else:
+                runcmd = gcmd.Command(cmd=self.cmdlist + ['--q'],
+                                      stderr=None)
             
             if runcmd.returncode != 0:
                 #clean up after probley
@@ -178,7 +190,13 @@
         @return command list/string
         """
         if string:
-            return ' '.join(self.cmdlist)
+            if self.type == 'command':
+                cmdStr = ''
+                for cmd in self.cmdlist:
+                    cmdStr += ' '.join(cmd) + ';'
+                return cmdStr
+            else:
+                return ' '.join(self.cmdlist)
         else:
             return self.cmdlist
 
@@ -255,7 +273,7 @@
         """Set new command for layer"""
         self.cmdlist = cmd
         Debug.msg(3, "Layer.SetCmd(): cmd='%s'" % self.GetCmd(string=True))
-
+        
         # for re-rendering
         self.force_render = True
         
@@ -848,6 +866,8 @@
             os.environ["GRASS_RENDER_IMMEDIATE"] = "png"
         else:
             os.environ["GRASS_RENDER_IMMEDIATE"] = "TRUE"
+
+        os.environ["GRASS_PNG_READ"] = "FALSE"
         
         self._renderLayers(force, mapWindow, maps, masks, opacities)
             
@@ -1005,10 +1025,10 @@
 
         if kargs.has_key('type'):
             layer.SetType(kargs['type']) # check type
-
+        
         if kargs.has_key('command'):
             layer.SetCmd(kargs['command'])
-            
+        
         if kargs.has_key('name'):
             layer.SetName(kargs['name'])
 

Modified: grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py	2008-09-01 10:32:30 UTC (rev 33185)
+++ grass/trunk/gui/wxpython/gui_modules/wxgui_utils.py	2008-09-01 10:39:54 UTC (rev 33186)
@@ -540,10 +540,11 @@
         if ltype == 'command':
             # generic command item
             ctrl = wx.TextCtrl(self, id=wx.ID_ANY, value='',
-                               pos=wx.DefaultPosition, size=(250,25),
-                               style=wx.TE_MULTILINE|wx.TE_WORDWRAP)
+                               pos=wx.DefaultPosition, size=(self.GetSize()[0]-100,25),
+                               # style=wx.TE_MULTILINE|wx.TE_WORDWRAP)
+                               style=wx.TE_PROCESS_ENTER | wx.TE_DONTWRAP)
             ctrl.Bind(wx.EVT_TEXT_ENTER, self.OnCmdChanged)
-            ctrl.Bind(wx.EVT_TEXT,       self.OnCmdChanged)
+            # ctrl.Bind(wx.EVT_TEXT,       self.OnCmdChanged)
         elif ltype == 'group':
             # group item
             ctrl = None
@@ -900,9 +901,14 @@
                     # ignore when map layer is edited
                     self.Map.ChangeLayerActive(mapLayer, checked)
 
+        #
         # update progress bar range (mapwindow statusbar)
+        #
         self.mapdisplay.onRenderGauge.SetRange(len(self.Map.GetListOfLayers(l_active=True)))
 
+        #
+        # nviz
+        #
         if self.mapdisplay.toolbars['nviz'] and \
                 self.GetPyData(item) is not None:
             # nviz - load/unload data layer
@@ -967,6 +973,10 @@
         """Selection changed"""
         oldlayer = event.GetOldItem()
         layer = event.GetItem()
+        if layer == oldlayer:
+            event.Veto()
+            return
+        
         self.layer_selected = layer
         
         try:
@@ -975,13 +985,17 @@
         except:
             pass
 
+        #
         # update statusbar -> show command string
+        #
         if self.GetPyData(layer) and self.GetPyData(layer)[0]['maplayer']:
             cmd = self.GetPyData(layer)[0]['maplayer'].GetCmd(string=True)
             if len(cmd) > 0:
                 self.gismgr.SetStatusText(cmd)
         
+        #
         # update nviz tools
+        #
         if self.mapdisplay.toolbars['nviz'] and \
                 self.GetPyData(self.layer_selected) is not None:
 
@@ -1253,13 +1267,16 @@
 
     def ChangeLayer(self, item):
         """Change layer"""
-
         type = self.GetPyData(item)[0]['type']
-
+        layerName = None
+        
         if type == 'command':
             win = self.FindWindowById(self.GetPyData(item)[0]['ctrl'])
             if win.GetValue() != None:
-                cmdlist = win.GetValue().split(' ')
+                cmd = win.GetValue().split(';')
+                cmdlist = []
+                for c in cmd:
+                    cmdlist.append(c.split(' '))
                 opac = 1.0
                 chk = self.IsItemChecked(item)
                 hidden = not self.IsVisible(item)
@@ -1269,29 +1286,28 @@
                 opac = self.GetPyData(item)[0]['maplayer'].GetOpacity(float=True)
                 chk = self.IsItemChecked(item)
                 hidden = not self.IsVisible(item)
-        # determine layer name
-        layerName = utils.GetLayerNameFromCmd(cmdlist, fullyQualified=True)
-        if not layerName:
-            layerName = self.GetItemText(item)
+                # determine layer name
+                layerName = utils.GetLayerNameFromCmd(cmdlist, fullyQualified=True)
+                if not layerName:
+                    layerName = self.GetItemText(item)
+        
         maplayer = self.Map.ChangeLayer(layer=self.GetPyData(item)[0]['maplayer'], type=type,
                                         command=cmdlist, name=layerName,
                                         l_active=chk, l_hidden=hidden, l_opacity=opac, l_render=False)
-
+        
         self.GetPyData(item)[0]['maplayer'] = maplayer
-
+        
         # if digitization tool enabled -> update list of available vector map layers
         if self.mapdisplay.toolbars['vdigit']:
             self.mapdisplay.toolbars['vdigit'].UpdateListOfLayers(updateTool=True)
-
+        
         # redraw map if auto-rendering is enabled
         self.rerender = True
         self.reorder = True
         #if self.mapdisplay.autoRender.GetValue():
         #    print "*** Change OnRender *****"
         #    self.mapdisplay.OnRender(None)
-
-        # item.SetHeight(TREE_ITEM_HEIGHT)
-
+        
     def OnCloseWindow(self, event):
         pass
         # self.Map.Clean()



More information about the grass-commit mailing list