]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/ProgressDialog.py
Call MGL_init earlier in wxApp::Initialize to avoid crash
[wxWidgets.git] / wxPython / demo / ProgressDialog.py
index ce4220191ba4636388e3cd50cfe05768de34f5e6..9417209834d71da4d720030a2ac0f3641c3e3cc3 100644 (file)
@@ -12,30 +12,49 @@ import  wx
 
 #---------------------------------------------------------------------------
 
-def runTest(frame, nb, log):
-    max = 20
-    
-    dlg = wx.ProgressDialog("Progress dialog example",
-                           "An informative message",
-                           maximum = max,
-                           parent=frame,
-                           style = wx.PD_CAN_ABORT | wx.PD_APP_MODAL)
+class TestPanel(wx.Panel):
+    def __init__(self, parent, log):
+        self.log = log
+        wx.Panel.__init__(self, parent, -1)
+
+        b = wx.Button(self, -1, "Create and Show a ProgressDialog", (50,50))
+        self.Bind(wx.EVT_BUTTON, self.OnButton, b)
+
+
+    def OnButton(self, evt):
+        max = 80
+
+        dlg = wx.ProgressDialog("Progress dialog example",
+                               "An informative message",
+                               maximum = max,
+                               parent=self,
+                               style = wx.PD_CAN_ABORT
+                                | wx.PD_APP_MODAL
+                                | wx.PD_ELAPSED_TIME
+                                #| wx.PD_ESTIMATED_TIME
+                                | wx.PD_REMAINING_TIME
+                                )
 
-    keepGoing = True
-    count = 0
+        keepGoing = True
+        count = 0
 
-    while keepGoing and count < max:
-        count = count + 1
-        #print count
-        wx.Sleep(1)
+        while keepGoing and count < max:
+            count += 1
+            wx.MilliSleep(250)
 
-        if count == max / 2:
-            keepGoing = dlg.Update(count, "Half-time!")
-        else:
-            keepGoing = dlg.Update(count)
+            if count >= max / 2:
+                keepGoing = dlg.Update(count, "Half-time!")
+            else:
+                keepGoing = dlg.Update(count)
 
-    dlg.Destroy()
+        dlg.Destroy()
 
+#---------------------------------------------------------------------------
+
+
+def runTest(frame, nb, log):
+    win = TestPanel(nb, log)
+    return win
 
 #---------------------------------------------------------------------------
 
@@ -59,4 +78,4 @@ If not then you may progress blissfully onward.
 if __name__ == '__main__':
     import sys,os
     import run
-    run.main(['', os.path.basename(sys.argv[0])])
+    run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])