[GRASS-SVN] r46842 - grass/branches/develbranch_6/gui/wxpython/gui_modules

svn_grass at osgeo.org svn_grass at osgeo.org
Wed Jun 29 06:52:43 EDT 2011


Author: lucadelu
Date: 2011-06-29 03:52:43 -0700 (Wed, 29 Jun 2011)
New Revision: 46842

Modified:
   grass/branches/develbranch_6/gui/wxpython/gui_modules/mcalc_builder.py
Log:
braces handling improvement; logical workflow improvement for functions; it already support functions for raster3d

Modified: grass/branches/develbranch_6/gui/wxpython/gui_modules/mcalc_builder.py
===================================================================
--- grass/branches/develbranch_6/gui/wxpython/gui_modules/mcalc_builder.py	2011-06-29 10:47:43 UTC (rev 46841)
+++ grass/branches/develbranch_6/gui/wxpython/gui_modules/mcalc_builder.py	2011-06-29 10:52:43 UTC (rev 46842)
@@ -66,53 +66,51 @@
         # variables
         #
         self.heading = _('mapcalc statement')
-        self.funct_list = [
-            'abs(x)',
-            'acos(x)',
-            'asin(x)',
-            'atan(x)',
-            'atan(x,y)',
-            'cos(x)',
-            'double(x)',
-            'eval([x,y,...,]z)',
-            'exp(x)',
-            'exp(x,y)',
-            'float(x)',
-            'graph(x,x1,y1[x2,y2..])',
-            'if(x)',
-            'if(x,a)',
-            'if(x,a,b)',
-            'if(x,a,b,c)',
-            'int(x)',
-            'isnull(x)',
-            'log(x)',
-            'log(x,b)',
-            'max(x,y[,z...])',
-            'median(x,y[,z...])',
-            'min(x,y[,z...])',
-            'mode(x,y[,z...])',
-            'not(x)',
-            'pow(x,y)',
-            'rand(a,b)',
-            'round(x)',
-            'sin(x)',
-            'sqrt(x)',
-            'tan(x)',
-            'xor(x,y)',
-            'row()',
-            'col()',
-            'x()',
-            'y()',
-            'ewres()',
-            'nsres()',
-            'null()'
-            ]
+        self.funct_dict = {
+            'abs(x)':'abs()',
+            'acos(x)':'acos()',
+            'asin(x)':'asin()',
+            'atan(x)':'atan()',
+            'atan(x,y)':'atan( , )',
+            'cos(x)':'cos()',
+            'double(x)':'double()',
+            'eval([x,y,...,]z)':'eval()',
+            'exp(x)':'exp()',
+            'exp(x,y)':'exp( , )',
+            'float(x)':'float()',
+            'graph(x,x1,y1[x2,y2..])':'graph( , , )',
+            'if(x)':'if()',
+            'if(x,a)':'if( , )',
+            'if(x,a,b)':'if( , , )',
+            'if(x,a,b,c)':'if( , , , )',
+            'int(x)':'if()',
+            'isnull(x)':'isnull()',
+            'log(x)':'log(',
+            'log(x,b)':'log( , )',
+            'max(x,y[,z...])':'max( , )',
+            'median(x,y[,z...])':'median( , )',
+            'min(x,y[,z...])':'min( , )',
+            'mode(x,y[,z...])':'mode( , )',
+            'not(x)':'not()',
+            'pow(x,y)':'pow( , )',
+            'rand(a,b)':'rand( , )',
+            'round(x)':'round()',
+            'sin(x)':'sin()',
+            'sqrt(x)':'sqrt()',
+            'tan(x)':'tan()',
+            'xor(x,y)':'xor( , )',
+            'row()':'row()',
+            'col()':'col()',
+            'x()':'x()',
+            'y()':'y()',
+            'ewres()':'ewres()',
+            'nsres()':'nsres()',
+            'null()':'null()'
+            }
         
         if self.rast3d:
-            indx = self.funct_list.index('y()') +1
-            self.funct_list.insert(indx, 'z()')
-            indx = self.funct_list.index('nsres()') +1
-            self.funct_list.insert(indx, 'tbres()')
+            self.funct_dict['z()'] = 'z()'
+            self.funct_dict['tbres()'] = 'tbres()'
             element = 'rast3d'
         else:
             element = 'cell'
@@ -152,8 +150,8 @@
         self.btn['mult'] = wx.Button(parent = self.panel, id = wx.ID_ANY, label = "*")
         self.btn['mult'].SetToolTipString(_('multiply'))
 
-        self.btn['paren'] = wx.Button(parent = self.panel, id = wx.ID_ANY, label = "( )") 
-
+        self.btn['parenl'] = wx.Button(parent = self.panel, id = wx.ID_ANY, label = "(") 
+        self.btn['parenr'] = wx.Button(parent = self.panel, id = wx.ID_ANY, label = ")")
         self.btn['lshift'] = wx.Button(parent = self.panel, id = wx.ID_ANY, label = "<<")
         self.btn['lshift'].SetToolTipString(_('left shift'))
         self.btn['rshift'] = wx.Button(parent = self.panel, id = wx.ID_ANY, label = ">>")
@@ -217,7 +215,7 @@
         self.functlabel = wx.StaticText(parent = self.panel, id = wx.ID_ANY,
                                         label = _('Insert mapcalc function'))
         self.function = wx.ComboBox(parent = self.panel, id = wx.ID_ANY, 
-                                    size = (250, -1), choices = self.funct_list,
+                                    size = (250, -1), choices = sorted(self.funct_dict.keys()),
                                     style = wx.CB_DROPDOWN |
                                     wx.CB_READONLY | wx.TE_PROCESS_ENTER)
         
@@ -241,7 +239,7 @@
         self.btn_load.Bind(wx.EVT_BUTTON, self.OnLoadExpression)
         
         self.mapselect.Bind(wx.EVT_TEXT, self.OnSelect)
-        self.function.Bind(wx.EVT_COMBOBOX, self.OnSelect)
+        self.function.Bind(wx.EVT_COMBOBOX, self._return_funct)
         self.function.Bind(wx.EVT_TEXT_ENTER, self.OnSelect)
         self.newmaptxt.Bind(wx.EVT_TEXT, self.OnUpdateStatusBar)
         self.text_mcalc.Bind(wx.EVT_TEXT, self.OnUpdateStatusBar)
@@ -249,7 +247,11 @@
         self._layout()
 
         self.SetMinSize(self.GetBestSize())
-        
+    
+    def _return_funct(self,event):
+	i = event.GetString()
+	self._addSomething(self.funct_dict[i])
+    
     def _layout(self):
         sizer = wx.BoxSizer(wx.VERTICAL)
         
@@ -286,23 +288,28 @@
 
         operandSizer = wx.StaticBoxSizer(self.operandBox, wx.HORIZONTAL)
         buttonSizer3 = wx.GridBagSizer(7, 1)
-        buttonSizer3.Add(item = self.newmaplabel, pos = (0, 0),
+        buttonSizer3.Add(item = self.newmaplabel, pos = (0,0),
                          span = (1, 2), flag = wx.ALIGN_CENTER)
         buttonSizer3.Add(item = self.newmaptxt, pos = (1,0),
                          span = (1, 2))
-        buttonSizer3.Add(item = self.mapsellabel, pos = (2,0),
+        buttonSizer3.Add(item = self.functlabel, pos = (2,0),
                          span = (1,2), flag = wx.ALIGN_CENTER)
-        buttonSizer3.Add(item = self.mapselect, pos = (3,0),
-                         span = (1,2))
-        buttonSizer3.Add(item = self.functlabel, pos = (4,0),
+        buttonSizer3.Add(item = self.function, pos = (3,0),
+                         span = (1,2))                         
+        buttonSizer3.Add(item = self.mapsellabel, pos = (4,0),
                          span = (1,2), flag = wx.ALIGN_CENTER)
-        buttonSizer3.Add(item = self.function, pos = (5,0),
+        buttonSizer3.Add(item = self.mapselect, pos = (5,0),
                          span = (1,2))
-        buttonSizer3.Add(item = self.btn['paren'], pos = (6, 0),
+        threebutton = wx.GridBagSizer(1, 2)
+        threebutton.Add(item = self.btn['parenl'], pos = (0,0),
                          span = (1,1), flag = wx.ALIGN_LEFT)
-        buttonSizer3.Add(item = self.btn_clear, pos = (6,1),
+        threebutton.Add(item = self.btn['parenr'], pos = (0,1),
+                         span = (1,1), flag = wx.ALIGN_CENTER)
+        threebutton.Add(item = self.btn_clear, pos = (0,2),
                          span = (1,1), flag = wx.ALIGN_RIGHT)
-        
+        buttonSizer3.Add(item = threebutton, pos = (6,0),
+	                 span = (1,1), flag = wx.ALIGN_CENTER)
+
         buttonSizer4 = wx.BoxSizer(wx.HORIZONTAL)
         buttonSizer4.AddSpacer(10)
         buttonSizer4.Add(item = self.btn_load,
@@ -380,7 +387,8 @@
         elif event.GetId() == self.btn['and'].GetId(): mark = "&&"
         elif event.GetId() == self.btn['andnull'].GetId(): mark = "&&&"
         elif event.GetId() == self.btn['cond'].GetId(): mark = " ? : "
-        elif event.GetId() == self.btn['paren'].GetId(): mark = "( )"        
+        elif event.GetId() == self.btn['parenl'].GetId(): mark = "("
+        elif event.GetId() == self.btn['parenr'].GetId(): mark = ")"
         self._addSomething(mark)
         
     def OnSelect(self, event):



More information about the grass-commit mailing list