[GRASS-SVN] r41584 - in grass/trunk/gui/wxpython: . docs
gui_modules icons xml
svn_grass at osgeo.org
svn_grass at osgeo.org
Sun Mar 28 07:02:02 EDT 2010
Author: martinl
Date: 2010-03-28 07:02:00 -0400 (Sun, 28 Mar 2010)
New Revision: 41584
Added:
grass/trunk/gui/wxpython/docs/wxGUI.Modeler.html
grass/trunk/gui/wxpython/gui_modules/gmodeler.py
grass/trunk/gui/wxpython/xml/menudata_modeler.xml
Modified:
grass/trunk/gui/wxpython/docs/Makefile
grass/trunk/gui/wxpython/gui_modules/menu.py
grass/trunk/gui/wxpython/gui_modules/menudata.py
grass/trunk/gui/wxpython/gui_modules/toolbars.py
grass/trunk/gui/wxpython/icons/grass2_icons.py
grass/trunk/gui/wxpython/icons/grass_icons.py
grass/trunk/gui/wxpython/icons/icon.py
grass/trunk/gui/wxpython/icons/silk_icons.py
grass/trunk/gui/wxpython/wxgui.py
Log:
wxGUI: graphical modeler development started
Modified: grass/trunk/gui/wxpython/docs/Makefile
===================================================================
--- grass/trunk/gui/wxpython/docs/Makefile 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/docs/Makefile 2010-03-28 11:02:00 UTC (rev 41584)
@@ -6,6 +6,7 @@
wxGUI.Vector_Digitizing_Tool \
wxGUI.Attribute_Table_Manager \
wxGUI.Nviz \
- wxGUI.Icons
+ wxGUI.Icons \
+ wxGUI.Modeler
default: $(patsubst %,$(HTMLDIR)/%.html,$(FILES))
Added: grass/trunk/gui/wxpython/docs/wxGUI.Modeler.html
===================================================================
--- grass/trunk/gui/wxpython/docs/wxGUI.Modeler.html (rev 0)
+++ grass/trunk/gui/wxpython/docs/wxGUI.Modeler.html 2010-03-28 11:02:00 UTC (rev 41584)
@@ -0,0 +1,11 @@
+<h2>DESCRIPTION</h2>
+
+<b>Note:</b> <em>wxGUI Modeler is currently under development. Not
+all functionality is implemented.</em>
+
+<h2>AUTHORS</h2>
+
+Martin Landa, CTU in Prague, Czech Republic
+
+<p>
+<i>$Date$</i>
Property changes on: grass/trunk/gui/wxpython/docs/wxGUI.Modeler.html
___________________________________________________________________
Added: svn:mime-type
+ text/html
Added: svn:keywords
+ Author Date Id
Added: svn:eol-style
+ native
Added: grass/trunk/gui/wxpython/gui_modules/gmodeler.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/gmodeler.py (rev 0)
+++ grass/trunk/gui/wxpython/gui_modules/gmodeler.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -0,0 +1,123 @@
+"""!
+ at package gmodeler.py
+
+ at brief Graphical modeler to create edit, and manage models
+
+Classes:
+ - ModelFrame
+ - ModelCanvas
+
+(C) 2010 by the GRASS Development Team
+This program is free software under the GNU General Public License
+(>=v2). Read the file COPYING that comes with GRASS for details.
+
+ at author Martin Landa <landa.martin gmail.com>
+"""
+
+import os
+
+import globalvar
+if not os.getenv("GRASS_WXBUNDLED"):
+ globalvar.CheckForWx()
+import wx
+import wx.lib.ogl as ogl
+
+import menu
+import menudata
+import toolbars
+
+from grass.script import core as grass
+
+class ModelFrame(wx.Frame):
+ def __init__(self, parent, id = wx.ID_ANY, title = _("Graphical modeler (under development)"), **kwargs):
+ """!Graphical modeler main window
+
+ @param parent parent window
+ @param id window id
+ @param title window title
+
+ @param kwargs wx.Frames' arguments
+ """
+ self.parent = parent
+
+ wx.Frame.__init__(self, parent = parent, id = id, title = title, **kwargs)
+ self.SetIcon(wx.Icon(os.path.join(globalvar.ETCICONDIR, 'grass.ico'), wx.BITMAP_TYPE_ICO))
+
+ self.menubar = menu.Menu(parent = self, data = menudata.ModelerData())
+ self.SetMenuBar(self.menubar)
+
+ self.toolbar = toolbars.ModelToolbar(parent = self)
+ self.SetToolBar(self.toolbar)
+
+ self.statusbar = self.CreateStatusBar(number = 1)
+
+ self.canvas = ModelCanvas(self)
+ self.canvas.SetBackgroundColour(wx.WHITE)
+
+ self.Bind(wx.EVT_CLOSE, self.OnCloseWindow)
+
+ self._layout()
+ self.SetMinSize((400, 300))
+
+ def _layout(self):
+ """!Do layout"""
+ sizer = wx.BoxSizer(wx.VERTICAL)
+
+ sizer.Add(item = self.canvas, proportion = 1,
+ flag = wx.EXPAND)
+
+ self.SetAutoLayout(True)
+ self.SetSizer(sizer)
+ sizer.Fit(self)
+
+ self.Layout()
+
+ def OnCloseWindow(self, event):
+ """!Close window"""
+ self.Destroy()
+
+ def OnModelNew(self, event):
+ """!Create new model"""
+ pass
+
+ def OnModelOpen(self, event):
+ """!Load model from file"""
+ pass
+
+ def OnModelSave(self, event):
+ """!Save model to file"""
+ pass
+
+ def OnModelSaveAs(self, event):
+ """!Create model to file as"""
+ pass
+
+ def OnAddAction(self, event):
+ """!Add action to model"""
+ pass
+
+ def OnHelp(self, event):
+ """!Display manual page"""
+ grass.run_command('g.manual',
+ entry = 'wxGUI.Modeler')
+
+class ModelCanvas(ogl.ShapeCanvas):
+ """!Canvas where model is drawn"""
+ def __init__(self, parent):
+ ogl.OGLInitialize()
+ ogl.ShapeCanvas.__init__(self, parent)
+
+ self.diagram = ogl.Diagram()
+ self.SetDiagram(self.diagram)
+ self.diagram.SetCanvas(self)
+
+def main():
+ app = wx.PySimpleApp()
+ frame = ModelFrame(parent = None)
+ frame.CenterOnScreen()
+ frame.Show()
+
+ app.MainLoop()
+
+if __name__ == "__main__":
+ main()
Property changes on: grass/trunk/gui/wxpython/gui_modules/gmodeler.py
___________________________________________________________________
Added: svn:mime-type
+ text/x-python
Added: svn:keywords
+ Author Date Id
Added: svn:eol-style
+ native
Modified: grass/trunk/gui/wxpython/gui_modules/menu.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/menu.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/gui_modules/menu.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -27,7 +27,7 @@
else:
self._createMenuItem(menu, *eachItem)
- self.parent.Bind(wx.EVT_MENU_HIGHLIGHT_ALL, self.parent.OnMenuHighlight)
+ self.parent.Bind(wx.EVT_MENU_HIGHLIGHT_ALL, self.OnMenuHighlight)
return menu
@@ -69,3 +69,16 @@
"""
return self.menucmd
+ def OnMenuHighlight(self, event):
+ """
+ Default menu help handler
+ """
+ # Show how to get menu item info from this event handler
+ id = event.GetMenuId()
+ item = self.FindItemById(id)
+ if item:
+ text = item.GetText()
+ help = item.GetHelp()
+
+ # but in this case just call Skip so the default is done
+ event.Skip()
Modified: grass/trunk/gui/wxpython/gui_modules/menudata.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/menudata.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/gui_modules/menudata.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -4,7 +4,7 @@
@brief Complex list for menu entries for wxGUI.
Classes:
- - Data
+ - MenuData
- ManagerData
- ModelerData
@@ -44,6 +44,38 @@
def __init__(self, filename):
self.tree = etree.parse(filename)
+ def _getMenuItem(self, mi):
+ """!Get menu item
+
+ @param mi menu item instance
+ """
+ if mi.tag == 'separator':
+ return ('', '', '', '', '')
+ elif mi.tag == 'menuitem':
+ label = _(mi.find('label').text)
+ help = _(mi.find('help').text)
+ handler = mi.find('handler').text
+ gcmd = mi.find('command') # optional
+ keywords = mi.find('keywords') # optional
+ shortcut = mi.find('shortcut') # optional
+ if gcmd != None:
+ gcmd = gcmd.text
+ else:
+ gcmd = ""
+ if keywords != None:
+ keywords = keywords.text
+ else:
+ keywords = ""
+ if shortcut != None:
+ shortcut = shortcut.text
+ else:
+ shortcut = ""
+ return (label, help, handler, gcmd, keywords, shortcut)
+ elif mi.tag == 'menu':
+ return self._getMenu(mi)
+ else:
+ raise Exception()
+
def _getMenu(self, m):
"""!Get menu
@@ -162,38 +194,6 @@
filename = os.path.join(globalvar.ETCWXDIR, 'xml', 'menudata.xml')
MenuData.__init__(self, filename)
-
- def _getMenuItem(self, mi):
- """!Get menu item
-
- @param mi menu item instance
- """
- if mi.tag == 'separator':
- return ('', '', '', '', '')
- elif mi.tag == 'menuitem':
- label = _(mi.find('label').text)
- help = _(mi.find('help').text)
- handler = mi.find('handler').text
- gcmd = mi.find('command') # optional
- keywords = mi.find('keywords') # optional
- shortcut = mi.find('shortcut') # optional
- if gcmd != None:
- gcmd = gcmd.text
- else:
- gcmd = ""
- if keywords != None:
- keywords = keywords.text
- else:
- keywords = ""
- if shortcut != None:
- shortcut = shortcut.text
- else:
- shortcut = ""
- return (label, help, handler, gcmd, keywords, shortcut)
- elif mi.tag == 'menu':
- return self._getMenu(mi)
- else:
- raise Exception()
def GetModules(self):
"""!Create dictionary of modules used to search module by
@@ -221,6 +221,14 @@
return modules
+class ModelerData(MenuData):
+ def __init__(self, filename = None):
+ if not filename:
+ gisbase = os.getenv('GISBASE')
+ filename = os.path.join(globalvar.ETCWXDIR, 'xml', 'menudata_modeler.xml')
+
+ MenuData.__init__(self, filename)
+
if __name__ == "__main__":
import sys
Modified: grass/trunk/gui/wxpython/gui_modules/toolbars.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/toolbars.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/gui_modules/toolbars.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -11,6 +11,7 @@
- VDigitToolbar
- ProfileToolbar
- NvizToolbar
+ - ModelToolbar
(C) 2007-2010 by the GRASS Development Team
This program is free software under the GNU General Public License
@@ -35,11 +36,11 @@
import vdigit
from vdigit import VDigitSettingsDialog as VDigitSettingsDialog
from debug import Debug as Debug
-from icon import Icons as Icons
from preferences import globalSettings as UserSettings
gmpath = os.path.join(globalvar.ETCWXDIR, "icons")
sys.path.append(gmpath)
+from icon import Icons as Icons
class AbstractToolbar(wx.ToolBar):
"""!Abstract toolbar class"""
@@ -1373,5 +1374,40 @@
# disable the toolbar
self.parent.RemoveToolbar("nviz")
+
+class ModelToolbar(AbstractToolbar):
+ """!Graphical modeler toolbar (see gmodeler.py)
+ """
+ def __init__(self, parent):
+ AbstractToolbar.__init__(self, parent)
-
+ self.InitToolbar(self.ToolbarData())
+
+ # realize the toolbar
+ self.Realize()
+
+ def ToolbarData(self):
+ """!Toolbar data"""
+ self.new = wx.NewId()
+ self.open = wx.NewId()
+ self.save = wx.NewId()
+ self.quit = wx.NewId()
+
+ # tool, label, bitmap, kind, shortHelp, longHelp, handler
+ return (
+ (self.new, 'new', Icons['modelNew'].GetBitmap(),
+ wx.ITEM_NORMAL, Icons['modelNew'].GetLabel(), Icons['modelNew'].GetDesc(),
+ self.parent.OnModelNew),
+ (self.open, 'open', Icons['modelOpen'].GetBitmap(),
+ wx.ITEM_NORMAL, Icons['modelOpen'].GetLabel(), Icons['modelOpen'].GetDesc(),
+ self.parent.OnModelOpen),
+ (self.save, 'save', Icons['modelSave'].GetBitmap(),
+ wx.ITEM_NORMAL, Icons['modelSave'].GetLabel(), Icons['modelSave'].GetDesc(),
+ self.parent.OnModelSave),
+ ('', '', '', '', '', '', ''),
+ (self.quit, 'quit', Icons['quit'].GetBitmap(),
+ wx.ITEM_NORMAL, Icons['quit'].GetLabel(), Icons['quit'].GetDesc(),
+ self.parent.OnCloseWindow),
+ )
+
+
Modified: grass/trunk/gui/wxpython/icons/grass2_icons.py
===================================================================
--- grass/trunk/gui/wxpython/icons/grass2_icons.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/icons/grass2_icons.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -63,10 +63,10 @@
"digAdditionalTools" : 'tools.png',
# layer manager
"newdisplay" : 'monitor-create.png',
- "workspaceNew" : 'create.png',
- "workspaceLoad" : 'layer-open.png',
- "workspaceOpen" : 'open.png',
- "workspaceSave" : 'save.png',
+ "fileNew" : 'create.png',
+ "fileLoad" : 'layer-open.png',
+ "fileOpen" : 'open.png',
+ "fileSave" : 'save.png',
"addrast" : 'layer-raster-add.png',
"addrast3d" : 'layer-raster3d-add.png',
"addshaded" : 'layer-shaded-relief-add.png',
Modified: grass/trunk/gui/wxpython/icons/grass_icons.py
===================================================================
--- grass/trunk/gui/wxpython/icons/grass_icons.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/icons/grass_icons.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -52,10 +52,10 @@
"digAdditionalTools" : wx.ART_ERROR, # FIXME
# layer manager
"newdisplay" : 'gui-startmon.gif',
- "workspaceNew" : 'file-new.gif',
- "workspaceLoad" : 'file-new.gif', # change the icon if possible
- "workspaceOpen" : 'file-open.gif',
- "workspaceSave" : 'file-save.gif',
+ "fileNew" : 'file-new.gif',
+ "fileLoad" : 'file-new.gif', # change the icon if possible
+ "fileOpen" : 'file-open.gif',
+ "fileSave" : 'file-save.gif',
"addrast" : 'element-cell.gif',
"addrast3d" : 'element-grid3.gif',
"addvect" : 'element-vector.gif',
Modified: grass/trunk/gui/wxpython/icons/icon.py
===================================================================
--- grass/trunk/gui/wxpython/icons/icon.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/icons/icon.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -1,4 +1,4 @@
-"""
+"""!
@package icon
@brief Icon themes
@@ -10,7 +10,7 @@
Classes:
- MetaIcon
-(C) 2007-2008 by the GRASS Development Team
+(C) 2007-2008, 2010 by the GRASS Development Team
This program is free software under the GNU General Public
License (>=v2). Read the file COPYING that comes with GRASS
for details.
@@ -174,18 +174,17 @@
label=_("Save display to graphic file")),
"printmap" : MetaIcon (img=Icons["printmap"],
label=_("Print display")),
- # gis manager
+ # layer manager
"newdisplay" : MetaIcon (img=Icons["newdisplay"],
label=_("Start new display")),
- "workspaceNew" : MetaIcon (img=Icons["workspaceNew"],
+ "workspaceNew" : MetaIcon (img=Icons["fileNew"],
label=_("Create new workspace file (Ctrl+N)")),
- "workspaceLoad" : MetaIcon (img=Icons["workspaceLoad"],
+ "workspaceLoad" : MetaIcon (img=Icons["fileLoad"],
label=_("Load map layers into workspace (Ctrl+L)")),
- "workspaceOpen" : MetaIcon (img=Icons["workspaceOpen"],
+ "workspaceOpen" : MetaIcon (img=Icons["fileOpen"],
label=_("Open existing workspace file (Ctrl+O)")),
- "workspaceSave" : MetaIcon (img=Icons["workspaceSave"],
+ "workspaceSave" : MetaIcon (img=Icons["fileSave"],
label=_("Save current workspace to file (Ctrl+S)")),
- # TODO: "layer" is not conformant with GRASS vocabulary (vector layer: 1..x) !
"addrast" : MetaIcon (img=Icons["addrast"],
label=_("Add raster map layer (Ctrl+R)")),
"addvect" : MetaIcon (img=Icons["addvect"],
@@ -337,10 +336,16 @@
"nvizSettings": MetaIcon (img=Icons["nvizSettings"],
label=_("Settings"),
desc=_("Show Nviz settings dialog")),
+ # modeler
+ "modelNew" : MetaIcon (img=Icons["fileNew"],
+ label=_("Create new model (Ctrl+N)")),
+ "modelOpen" : MetaIcon (img=Icons["fileOpen"],
+ label=_("Load model from file (Ctrl+O)")),
+ "modelSave" : MetaIcon (img=Icons["fileSave"],
+ label=_("Save current model to file (Ctrl+S)")),
}
# testing ...
if __name__ == "__main__":
for k, v in Icons.iteritems():
print v.GetImageName()
-
Modified: grass/trunk/gui/wxpython/icons/silk_icons.py
===================================================================
--- grass/trunk/gui/wxpython/icons/silk_icons.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/icons/silk_icons.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -65,10 +65,10 @@
"digAdditionalTools" : 'plugin.png',
# layer manager
"newdisplay" : 'application_add.png',
- "workspaceNew" : 'page_white.png',
- "workspaceLoad" : 'page_white_get.png',
- "workspaceOpen" : 'folder.png',
- "workspaceSave" : 'page_save.png',
+ "fileNew" : 'page_white.png',
+ "fileLoad" : 'page_white_get.png',
+ "fileOpen" : 'folder.png',
+ "fileSave" : 'page_save.png',
"addrast" : 'image_add.png',
"addrast3d" : 'bricks.png',
"addshaded" : 'picture_empty.png',
Modified: grass/trunk/gui/wxpython/wxgui.py
===================================================================
--- grass/trunk/gui/wxpython/wxgui.py 2010-03-28 10:44:40 UTC (rev 41583)
+++ grass/trunk/gui/wxpython/wxgui.py 2010-03-28 11:02:00 UTC (rev 41584)
@@ -244,20 +244,6 @@
return self.toolbar
- def OnMenuHighlight(self, event):
- """
- Default menu help handler
- """
- # Show how to get menu item info from this event handler
- id = event.GetMenuId()
- item = self.GetMenuBar().FindItemById(id)
- if item:
- text = item.GetText()
- help = item.GetHelp()
-
- # but in this case just call Skip so the default is done
- event.Skip()
-
def OnGeorectify(self, event):
"""
Launch georectifier module
Added: grass/trunk/gui/wxpython/xml/menudata_modeler.xml
===================================================================
--- grass/trunk/gui/wxpython/xml/menudata_modeler.xml (rev 0)
+++ grass/trunk/gui/wxpython/xml/menudata_modeler.xml 2010-03-28 11:02:00 UTC (rev 41584)
@@ -0,0 +1,59 @@
+<menudata>
+ <menubar>
+ <menu>
+ <label>&File</label>
+ <items>
+ <menuitem>
+ <label>New</label>
+ <help>Create new model</help>
+ <handler>OnModelNew</handler>
+ <shortcut>Ctrl+N</shortcut>
+ </menuitem>
+ <menuitem>
+ <label>Open</label>
+ <help>Load model from file</help>
+ <handler>OnModelOpen</handler>
+ <shortcut>Ctrl+O</shortcut>
+ </menuitem>
+ <menuitem>
+ <label>Save</label>
+ <help>Save model</help>
+ <handler>OnModelSave</handler>
+ <shortcut>Ctrl+S</shortcut>
+ </menuitem>
+ <menuitem>
+ <label>Save as</label>
+ <help>Save model to file</help>
+ <handler>OnModelSaveAs</handler>
+ </menuitem>
+ <separator />
+ <menuitem>
+ <label>Close</label>
+ <help>Close modeler</help>
+ <handler>OnCloseWindow</handler>
+ <shortcut>Ctrl+E</shortcut>
+ </menuitem>
+ </items>
+ </menu>
+ <menu>
+ <label>&Model</label>
+ <items>
+ <menuitem>
+ <label>Add action</label>
+ <help>Add action (GRASS module) to model</help>
+ <handler>OnAddAction</handler>
+ </menuitem>
+ </items>
+ </menu>
+ <menu>
+ <label>&Help</label>
+ <items>
+ <menuitem>
+ <label>Help</label>
+ <help>Display the HTML man pages of Graphical modeler</help>
+ <handler>OnHelp</handler>
+ </menuitem>
+ </items>
+ </menu>
+ </menubar>
+</menudata>
More information about the grass-commit
mailing list