X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/299647acac7960652aadb008775429c1f8ea9b8d..089bac8ed4a8acaf27cfc4cd270f58cc0be9df29:/wxPython/demo/ToolBar.py diff --git a/wxPython/demo/ToolBar.py b/wxPython/demo/ToolBar.py index b609061504..750ae637f4 100644 --- a/wxPython/demo/ToolBar.py +++ b/wxPython/demo/ToolBar.py @@ -1,7 +1,3 @@ -# 11/21/2003 - Jeff Grimmett (grimmtooth@softhome.net) -# -# o Updated for wx namespace -# import wx import images @@ -35,21 +31,29 @@ class TestToolBar(wx.Frame): self.CreateStatusBar() - tb.AddSimpleTool(10, images.getNewBitmap(), "New", "Long help for 'New'") - #tb.AddLabelTool(10, "New", images.getNewBitmap(), shortHelp="New", longHelp="Long help for 'New'") + tsize = (16,16) + new_bmp = wx.ArtProvider.GetBitmap(wx.ART_NEW, wx.ART_TOOLBAR, tsize) + open_bmp = wx.ArtProvider.GetBitmap(wx.ART_FILE_OPEN, wx.ART_TOOLBAR, tsize) + copy_bmp = wx.ArtProvider.GetBitmap(wx.ART_COPY, wx.ART_TOOLBAR, tsize) + paste_bmp= wx.ArtProvider.GetBitmap(wx.ART_PASTE, wx.ART_TOOLBAR, tsize) + + tb.SetToolBitmapSize(tsize) + + tb.AddSimpleTool(10, new_bmp, "New", "Long help for 'New'") + #tb.AddLabelTool(10, "New", new_bmp, shortHelp="New", longHelp="Long help for 'New'") self.Bind(wx.EVT_TOOL, self.OnToolClick, id=10) self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=10) - tb.AddSimpleTool(20, images.getOpenBitmap(), "Open", "Long help for 'Open'") + tb.AddSimpleTool(20, open_bmp, "Open", "Long help for 'Open'") self.Bind(wx.EVT_TOOL, self.OnToolClick, id=20) self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=20) tb.AddSeparator() - tb.AddSimpleTool(30, images.getCopyBitmap(), "Copy", "Long help for 'Copy'") + tb.AddSimpleTool(30, copy_bmp, "Copy", "Long help for 'Copy'") self.Bind(wx.EVT_TOOL, self.OnToolClick, id=30) self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=30) - tb.AddSimpleTool(40, images.getPasteBitmap(), "Paste", "Long help for 'Paste'") + tb.AddSimpleTool(40, paste_bmp, "Paste", "Long help for 'Paste'") self.Bind(wx.EVT_TOOL, self.OnToolClick, id=40) self.Bind(wx.EVT_TOOL_RCLICKED, self.OnToolRClick, id=40) @@ -122,22 +126,64 @@ class TestToolBar(wx.Frame): #--------------------------------------------------------------------------- +class TestPanel(wx.Panel): + def __init__(self, parent, log): + self.log = log + wx.Panel.__init__(self, parent, -1) + + b = wx.Button(self, -1, "Show the ToolBar sample", (50,50)) + self.Bind(wx.EVT_BUTTON, self.OnButton, b) + + + def OnButton(self, evt): + win = TestToolBar(self, self.log) + win.Show(True) + + +#--------------------------------------------------------------------------- + + def runTest(frame, nb, log): - win = TestToolBar(frame, log) - frame.otherWin = win - win.Show(True) + win = TestPanel(nb, log) + return win #--------------------------------------------------------------------------- -overview = """\ +overview = """\ +wx.ToolBar is a narrow strip of icons on one side of a frame (top, bottom, sides) +that acts much like a menu does, except it is always visible. Additionally, actual +wxWindows controls, such as wx.TextCtrl or wx.ComboBox, can be added to the toolbar +and used from within it. + +Toolbar creation is a two-step process. First, the toolbar is defined using the +various Add* methods of wx.ToolBar. Once all is set up, then wx.Toolbar.Realize() +must be called to render it. + +wx.Toolbar events are also propogated as Menu events; this is especially handy when +you have a menu bar that contains items that carry out the same function. For example, +it is not uncommon to have a little 'floppy' toolbar icon to 'save' the current file +(whatever it is) as well as a FILE/SAVE menu item that does the same thing. In this +case, both events can be captured and acted upon using the same event handler +with no ill effects. + +If there are cases where a toolbar icon should *not* be associated with a menu item, +use a unique ID to trap it. + +There are a number of ways to create a toolbar for a wx.Frame. wx.Frame.CreateToolBar() +does all the work except it adds no buttons at all unless you override the virtual method +OnCreateToolBar(). On the other hand, you can just subclass wx.ToolBar and then use +wx.Frame.SetToolBar() instead. + +Note that wx.TB_DOCKABLE is only supported under GTK. An attempt to alleviate this +is provided in wx.lib.floatbar, but it is not formally supported. """ 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:])