]> git.saurik.com Git - wxWidgets.git/blob - wxPython/demo/Gauge.py
added tech note about writing unit tests
[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.g1.SetBezelFace(3)
16 self.g1.SetShadowWidth(3)
17
18 self.g2 = wx.Gauge(
19 self, -1, 50, (110, 95), (250, 25),
20 wx.GA_HORIZONTAL|wx.GA_SMOOTH
21 )
22
23 self.g2.SetBezelFace(5)
24 self.g2.SetShadowWidth(5)
25
26 self.Bind(wx.EVT_IDLE, self.IdleHandler)
27
28
29 def IdleHandler(self, event):
30 self.count = self.count + 1
31
32 if self.count >= 50:
33 self.count = 0
34
35 self.g1.SetValue(self.count)
36 self.g2.SetValue(self.count)
37
38
39
40 #----------------------------------------------------------------------
41
42 def runTest(frame, nb, log):
43 win = TestPanel(nb, log)
44 return win
45
46 #----------------------------------------------------------------------
47
48
49 overview = """\
50 A Gauge is a horizontal or vertical bar which shows a quantity in a graphical
51 fashion. It is often used to indicate progress through lengthy tasks, such as
52 file copying or data analysis.
53
54 When the Gauge is initialized, it's "complete" value is usually set; at any rate,
55 before using the Gauge, the maximum value of the control must be set. As the task
56 progresses, the Gauge is updated by the program via the <code>SetValue</code> method.
57
58 This control is for use within a GUI; there is a seperate ProgressDialog class
59 to present the same sort of control as a dialog to the user.
60 """
61
62 if __name__ == '__main__':
63 import sys,os
64 import run
65 run.main(['', os.path.basename(sys.argv[0])])
66