[GRASS-SVN] r32889 - grass/trunk/gui/wxpython/gui_modules
svn_grass at osgeo.org
svn_grass at osgeo.org
Tue Aug 19 08:43:00 EDT 2008
Author: martinl
Date: 2008-08-19 08:42:40 -0400 (Tue, 19 Aug 2008)
New Revision: 32889
Modified:
grass/trunk/gui/wxpython/gui_modules/mapdisp.py
grass/trunk/gui/wxpython/gui_modules/render.py
Log:
wxGUI: update progress bar info via event
(merge from devbr6, r32888)
Modified: grass/trunk/gui/wxpython/gui_modules/mapdisp.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/mapdisp.py 2008-08-19 12:39:12 UTC (rev 32888)
+++ grass/trunk/gui/wxpython/gui_modules/mapdisp.py 2008-08-19 12:42:40 UTC (rev 32889)
@@ -34,6 +34,7 @@
import wx
import wx.aui
+
from threading import Thread
import globalvar
@@ -128,13 +129,13 @@
Parent for BufferedWindow class (2D display mode) and
GLWindow (3D display mode)
"""
- def __init__(self, parent, id,
+ def __init__(self, parent, id=wx.ID_ANY,
pos=wx.DefaultPosition,
size=wx.DefaultSize,
style=wx.NO_FULL_REPAINT_ON_RESIZE,
Map=None, tree=None, gismgr=None):
- pass
-
+ self.parent = parent # MapFrame
+
def EraseMap(self):
"""
Erase the canvas (virtual method)
@@ -212,7 +213,6 @@
Map, tree, gismgr)
wx.Window.__init__(self, parent, id, pos, size, style)
- self.parent = parent
self.Map = Map
self.tree = tree
self.gismanager = gismgr
@@ -637,9 +637,7 @@
self.parent.onRenderGauge.Show()
if self.parent.onRenderGauge.GetRange() > 0:
self.parent.onRenderGauge.SetValue(1)
- self.parent.onRenderTimer.Start(100)
- self.parent.onRenderCounter = 0
-
+
#
# render background image if needed
#
@@ -736,8 +734,6 @@
#
# hide process bar
#
- if self.parent.onRenderGauge.GetRange() > 0:
- self.parent.onRenderTimer.Stop()
self.parent.onRenderGauge.Hide()
#
@@ -2402,7 +2398,6 @@
self.gismanager = gismgr # GIS Manager object
self.Map = Map # instance of render.Map
- self.Map.window = self
self.tree = tree # GIS Manager layer tree object
self.page = page # Notebook page holding the layer tree
self.layerbook = notebook # GIS Manager layer tree notebook
@@ -2493,9 +2488,7 @@
self.onRenderGauge = wx.Gauge(parent=self.statusbar, id=wx.ID_ANY,
range=0, style=wx.GA_HORIZONTAL)
self.onRenderGauge.Hide()
- self.Bind(wx.EVT_TIMER, self.TimerOnRender)
- self.onRenderTimer = wx.Timer(self)
-
+
self.StatusbarReposition() # reposition statusbar
#
@@ -2520,7 +2513,8 @@
#
self.Bind(wx.EVT_ACTIVATE, self.OnFocus)
self.Bind(wx.EVT_CLOSE, self.OnCloseWindow)
-
+ self.Bind(render.EVT_UPDATE_PRGBAR, self.OnUpdateProgress)
+
#
# Update fancy gui style
#
@@ -2761,6 +2755,12 @@
self.Map.region = self.Map.GetRegion() # g.region -upgc
# self.Map.SetRegion() # adjust region to match display window
+ def OnUpdateProgress(self, event):
+ """Update progress bar info"""
+ self.onRenderGauge.SetValue(event.value)
+
+ event.Skip()
+
def OnFocus(self, event):
"""
Change choicebook page to match display.
@@ -2811,11 +2811,7 @@
Re-display current map composition
"""
self.MapWindow.UpdateMap(render=False)
-
- def TimerOnRender(self, event):
- """Update process bar"""
- self.onRenderGauge.SetValue(self.onRenderCounter)
-
+
def OnRender(self, event):
"""
Re-render map composition (each map layer)
Modified: grass/trunk/gui/wxpython/gui_modules/render.py
===================================================================
--- grass/trunk/gui/wxpython/gui_modules/render.py 2008-08-19 12:39:12 UTC (rev 32888)
+++ grass/trunk/gui/wxpython/gui_modules/render.py 2008-08-19 12:42:40 UTC (rev 32889)
@@ -33,6 +33,7 @@
import tempfile
import wx
+from wx.lib.newevent import NewEvent
import globalvar
import utils
@@ -40,6 +41,8 @@
from debug import Debug as Debug
from preferences import globalSettings as UserSettings
+wxUpdateProgressBar, EVT_UPDATE_PRGBAR = NewEvent()
+
#
# use g.pnmcomp for creating image composition or
# wxPython functionality
@@ -318,9 +321,7 @@
"""
Map composition (stack of map layers and overlays)
"""
- def __init__(self, gisrc=None, window=None):
- self.window = window # used for wx.SafeYield()
-
+ def __init__(self, gisrc=None):
#
# region/extent settigns
#
@@ -818,6 +819,7 @@
os.environ["GRASS_RENDER_IMMEDIATE"] = "TRUE"
# render map layers
+ ilayer = 1
for layer in self.layers + self.overlays:
# skip dead or disabled map layers
if layer == None or layer.active == False:
@@ -832,10 +834,9 @@
continue
# update progress bar
- if mapWindow is not None:
- mapWindow.onRenderCounter += 1
-
- wx.SafeYield(self.window)
+ wx.SafeYield(mapWindow)
+ event = wxUpdateProgressBar(value=ilayer)
+ wx.PostEvent(mapWindow, event)
# add image to compositing list
if layer.type != "overlay":
@@ -844,7 +845,8 @@
opacities.append(str(layer.opacity))
Debug.msg (3, "Map.Render() type=%s, layer=%s " % (layer.type, layer.name))
-
+ ilayer += 1
+
# ugly hack for MSYS
if not subprocess.mswindows:
mapstr = ",".join(maps)
More information about the grass-commit
mailing list