]>
Commit | Line | Data |
---|---|---|
1 | ||
2 | import wx | |
3 | import images | |
4 | ||
5 | #--------------------------------------------------------------------------- | |
6 | ||
7 | class TestToolBar(wx.Frame): | |
8 | def __init__(self, parent, log): | |
9 | wx.Frame.__init__(self, parent, -1, 'Test ToolBar', size=(500, 300)) | |
10 | self.log = log | |
11 | self.timer = None | |
12 | self.Bind(wx.EVT_CLOSE, self.OnCloseWindow) | |
13 | ||
14 | wx.Window(self, -1).SetBackgroundColour(wx.NamedColour("WHITE")) | |
15 | ||
16 | # Use the wxFrame internals to create the toolbar and associate it all | |
17 | # in one tidy method call. | |
18 | tb = self.CreateToolBar( wx.TB_HORIZONTAL | |
19 | | wx.NO_BORDER | |
20 | | wx.TB_FLAT | |
21 | | wx.TB_TEXT | |
22 | ) | |
23 | ||
24 | # Here's a 'simple' toolbar example, and how to bind it using SetToolBar() | |
25 | #tb = wx.ToolBarSimple(self, -1, wx.DefaultPosition, wx.DefaultSize, | |
26 | # wx.TB_HORIZONTAL | wx.NO_BORDER | wx.TB_FLAT) | |
27 | #self.SetToolBar(tb) | |
28 | # But we're doing it a different way here. | |
29 | ||
30 | log.write("Default toolbar tool size: %s\n" % tb.GetToolBitmapSize()) | |
31 | ||
32 | self.CreateStatusBar() | |
33 | ||
34 | tb.AddSimpleTool(10, images.getNewBitmap(), "New", "Long help for 'New'") | |
35 | #tb.AddLabelTool(10, "New", images.getNewBitmap(), shortHelp="New", longHelp="Long help for 'New'") | |
36 | self.Bind(wx.EVT_TOOL, self.OnToolClick, id=10) | |
37 | self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=10) | |
38 | ||
39 | tb.AddSimpleTool(20, images.getOpenBitmap(), "Open", "Long help for 'Open'") | |
40 | self.Bind(wx.EVT_TOOL, self.OnToolClick, id=20) | |
41 | self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=20) | |
42 | ||
43 | tb.AddSeparator() | |
44 | tb.AddSimpleTool(30, images.getCopyBitmap(), "Copy", "Long help for 'Copy'") | |
45 | self.Bind(wx.EVT_TOOL, self.OnToolClick, id=30) | |
46 | self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=30) | |
47 | ||
48 | tb.AddSimpleTool(40, images.getPasteBitmap(), "Paste", "Long help for 'Paste'") | |
49 | self.Bind(wx.EVT_TOOL, self.OnToolClick, id=40) | |
50 | self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=40) | |
51 | ||
52 | tb.AddSeparator() | |
53 | ||
54 | tool = tb.AddCheckTool(50, images.getTog1Bitmap(), | |
55 | shortHelp="Toggle this") | |
56 | self.Bind(wx.EVT_TOOL, self.OnToolClick, id=50) | |
57 | ||
58 | ## tb.AddCheckTool(60, images.getTog1Bitmap(), images.getTog2Bitmap(), | |
59 | ## shortHelp="Toggle with 2 bitmaps") | |
60 | ## self.Bind(EVT_TOOL, self.OnToolClick, id=60) | |
61 | ||
62 | self.Bind(wx.EVT_TOOL_ENTER, self.OnToolEnter) | |
63 | self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick) # Match all | |
64 | self.Bind(wx.EVT_TIMER, self.OnClearSB) | |
65 | ||
66 | tb.AddSeparator() | |
67 | cbID = wx.NewId() | |
68 | ||
69 | tb.AddControl( | |
70 | wx.ComboBox( | |
71 | tb, cbID, "", choices=["", "This", "is a", "wxComboBox"], | |
72 | size=(150,-1), style=wx.CB_DROPDOWN | |
73 | )) | |
74 | ||
75 | self.Bind(wx.EVT_COMBOBOX, self.OnCombo, id=cbID) | |
76 | tb.AddControl(wx.TextCtrl(tb, -1, "Toolbar controls!!", size=(150, -1))) | |
77 | ||
78 | # Final thing to do for a toolbar is call the Realize() method. This | |
79 | # causes it to render (more or less, that is). | |
80 | tb.Realize() | |
81 | ||
82 | ||
83 | def OnToolClick(self, event): | |
84 | self.log.WriteText("tool %s clicked\n" % event.GetId()) | |
85 | tb = self.GetToolBar() | |
86 | tb.EnableTool(10, not tb.GetToolEnabled(10)) | |
87 | ||
88 | def OnToolRClick(self, event): | |
89 | self.log.WriteText("tool %s right-clicked\n" % event.GetId()) | |
90 | ||
91 | def OnCombo(self, event): | |
92 | self.log.WriteText("combobox item selected: %s\n" % event.GetString()) | |
93 | ||
94 | def OnToolEnter(self, event): | |
95 | self.log.WriteText('OnToolEnter: %s, %s\n' % (event.GetId(), event.GetInt())) | |
96 | ||
97 | if self.timer is None: | |
98 | self.timer = wx.Timer(self) | |
99 | ||
100 | if self.timer.IsRunning(): | |
101 | self.timer.Stop() | |
102 | ||
103 | self.timer.Start(2000) | |
104 | event.Skip() | |
105 | ||
106 | ||
107 | def OnClearSB(self, event): # called for the timer event handler | |
108 | self.SetStatusText("") | |
109 | self.timer.Stop() | |
110 | self.timer = None | |
111 | ||
112 | ||
113 | def OnCloseWindow(self, event): | |
114 | if self.timer is not None: | |
115 | self.timer.Stop() | |
116 | self.timer = None | |
117 | self.Destroy() | |
118 | ||
119 | #--------------------------------------------------------------------------- | |
120 | ||
121 | class TestPanel(wx.Panel): | |
122 | def __init__(self, parent, log): | |
123 | self.log = log | |
124 | wx.Panel.__init__(self, parent, -1) | |
125 | ||
126 | b = wx.Button(self, -1, "Show the ToolBar sample", (50,50)) | |
127 | self.Bind(wx.EVT_BUTTON, self.OnButton, b) | |
128 | ||
129 | ||
130 | def OnButton(self, evt): | |
131 | win = TestToolBar(self, self.log) | |
132 | win.Show(True) | |
133 | ||
134 | ||
135 | #--------------------------------------------------------------------------- | |
136 | ||
137 | ||
138 | def runTest(frame, nb, log): | |
139 | win = TestPanel(nb, log) | |
140 | return win | |
141 | ||
142 | #--------------------------------------------------------------------------- | |
143 | ||
144 | ||
145 | ||
146 | ||
147 | overview = """\ | |
148 | wx.ToolBar is a narrow strip of icons on one side of a frame (top, bottom, sides) | |
149 | that acts much like a menu does, except it is always visible. Additionally, actual | |
150 | wxWindows controls, such as wx.TextCtrl or wx.ComboBox, can be added to the toolbar | |
151 | and used from within it. | |
152 | ||
153 | Toolbar creation is a two-step process. First, the toolbar is defined using the | |
154 | various Add* methods of wx.ToolBar. Once all is set up, then wx.Toolbar.Realize() | |
155 | must be called to render it. | |
156 | ||
157 | wx.Toolbar events are also propogated as Menu events; this is especially handy when | |
158 | you have a menu bar that contains items that carry out the same function. For example, | |
159 | it is not uncommon to have a little 'floppy' toolbar icon to 'save' the current file | |
160 | (whatever it is) as well as a FILE/SAVE menu item that does the same thing. In this | |
161 | case, both events can be captured and acted upon using the same event handler | |
162 | with no ill effects. | |
163 | ||
164 | If there are cases where a toolbar icon should *not* be associated with a menu item, | |
165 | use a unique ID to trap it. | |
166 | ||
167 | There are a number of ways to create a toolbar for a wx.Frame. wx.Frame.CreateToolBar() | |
168 | does all the work except it adds no buttons at all unless you override the virtual method | |
169 | OnCreateToolBar(). On the other hand, you can just subclass wx.ToolBar and then use | |
170 | wx.Frame.SetToolBar() instead. | |
171 | ||
172 | Note that wx.TB_DOCKABLE is only supported under GTK. An attempt to alleviate this | |
173 | is provided in wx.lib.floatbar, but it is not formally supported. | |
174 | """ | |
175 | ||
176 | ||
177 | if __name__ == '__main__': | |
178 | import sys,os | |
179 | import run | |
180 | run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:]) | |
181 |