]> git.saurik.com Git - wxWidgets.git/blob - wxPython/demo/Gauge.py
The great wxVScrolledWindow refactoring: allow using it both horizontal and
[wxWidgets.git] / wxPython / demo / Gauge.py
1
2 import wx
3
4 #----------------------------------------------------------------------
5
6 class TestPanel(wx.Panel):
7 def __init__(self, parent, log):
8 wx.Panel.__init__(self, parent, -1)
9 self.log = log
10 self.count = 0
11
12 wx.StaticText(self, -1, "This example shows the wx.Gauge control.", (45, 15))
13
14 self.g1 = wx.Gauge(self, -1, 50, (110, 50), (250, 25))
15 self.g2 = wx.Gauge(self, -1, 50, (110, 95), (250, 25))
16
17 self.Bind(wx.EVT_TIMER, self.TimerHandler)
18 self.timer = wx.Timer(self)
19 self.timer.Start(100)
20
21 def __del__(self):
22 self.timer.Stop()
23
24 def TimerHandler(self, event):
25 self.count = self.count + 1
26
27 if self.count >= 50:
28 self.count = 0
29
30 self.g1.SetValue(self.count)
31 self.g2.Pulse()
32
33
34 #----------------------------------------------------------------------
35
36 def runTest(frame, nb, log):
37 win = TestPanel(nb, log)
38 return win
39
40 #----------------------------------------------------------------------
41
42
43 overview = """\
44 A Gauge is a horizontal or vertical bar which shows a quantity in a graphical
45 fashion. It is often used to indicate progress through lengthy tasks, such as
46 file copying or data analysis.
47
48 When the Gauge is initialized, it's "complete" value is usually set; at any rate,
49 before using the Gauge, the maximum value of the control must be set. As the task
50 progresses, the Gauge is updated by the program via the <code>SetValue</code> method.
51
52 This control is for use within a GUI; there is a seperate ProgressDialog class
53 to present the same sort of control as a dialog to the user.
54 """
55
56 if __name__ == '__main__':
57 import sys,os
58 import run
59 run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
60