]> git.saurik.com Git - wxWidgets.git/blame_incremental - wxPython/demo/PyPlot.py
Compile fixes for Panther
[wxWidgets.git] / wxPython / demo / PyPlot.py
... / ...
CommitLineData
1
2import wx
3
4hadImportError = False
5try:
6 import wx.lib.plot
7except ImportError:
8 hadImportError = True
9
10
11################################################################\
12# Where's the code??? |
13# |
14# wx.lib.plot.py came with its own excellent demo built in, |
15# for testing purposes, but it serves quite well to demonstrate |
16# the code and classes within, so we are simply borrowing that |
17# code for the demo. Please load up wx.lib.plot.py for a review |
18# of the code itself. The demo/test is at the bottom of |
19# the file, as expected. |
20################################################################/
21
22#---------------------------------------------------------------------------
23
24class TestPanel(wx.Panel):
25 def __init__(self, parent, log):
26 self.log = log
27 wx.Panel.__init__(self, parent, -1)
28
29 b = wx.Button(self, -1, "Show the PyPlot sample", (50,50))
30 self.Bind(wx.EVT_BUTTON, self.OnButton, b)
31
32
33 def OnButton(self, evt):
34 win = wx.lib.plot.TestFrame(self, -1, "PlotCanvas Demo")
35 win.Show()
36
37#---------------------------------------------------------------------------
38
39
40def runTest(frame, nb, log):
41 if not hadImportError:
42 win = TestPanel(nb, log)
43 else:
44 from Main import MessagePanel
45 win = MessagePanel(nb, """\
46This demo requires the Numeric or numarray module,
47which could not be imported. It probably is not installed
48(it's not part of the standard Python distribution). See the
49Python site (http://www.python.org) for information on
50downloading source or binaries.""",
51 'Sorry', wx.ICON_WARNING)
52
53 return win
54
55
56#----------------------------------------------------------------------
57
58if hadImportError:
59 overview = ""
60else:
61 overview = """\
62<html><body>
63<center><h2>PyPlot</h2></center>
64
65This demo illustrates the features of the new PyPlot modules, found
66in wx.lib.plot.py. All methods and functions are documented clearly
67therein; only the overview is included here.
68
69<p>
70PyPlot is an improvement over wxPlotCanvas, which is now deprecated.
71If you are using wxPlotCanvas now, please make plans to migrate in
72anticipation of the time that wxPlotCanvas disappears completely.
73
74<p>
75The demo illustrates four different plot styles (with appropriate
76variations on fonts, etc, to show how flexible it is) as well as
77provides you with a means to tinker with all the features that
78come with the class itself.
79
80<p><ul>
81<li>File Menu
82
83 <ul>
84 <li>Page Setup
85
86 <p>This allows you to set up how the plot will be printed. This
87 is built into the library itself.
88
89 <li>Print Preview
90
91 <p>As you might expect, this allows you to preview how the plot
92 will look when printed, in light of the page setup you may
93 have selected above.
94
95 <li>Print
96
97 <p>Surprise! It prints the current plot to your printer! :-)
98
99 <li>Save Plot
100
101 <p>That's right, the library even provides you with the means
102 to export the plotted data out to a graphics file. Several
103 formats are allowed for, basically any image class that
104 supports saving.
105 </ul>
106
107<li>Plot Menu
108
109 <ul>
110 <li>Plot 1 ... Plot 5
111
112 <p>Different data with different plot formats, including one empty
113 plot.
114
115 <li>Enable Zoom
116
117 <p>If Zoom is enabled, you can rubber-band select an area of the
118 plot to examine it in detail using the left mouse button. Right
119 mouse button zooms back out. This is automatically supported
120 by the library, all you have to do is turn it on.
121
122 <li>Enable Grid
123
124 <p>Plots can have different styles of grids, and and these grids can
125 be turned on or off as needed.
126
127 <li>Enable Legend
128
129 <p>Plot can have legends or not, the contents which are definable
130 by you.
131 </ul>
132</ul>
133
134<HR><pre>
135%s</pre>
136</body></html>
137""" % wx.lib.plot.__doc__
138
139
140if __name__ == '__main__':
141 import sys,os
142 import run
143 run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
144