]> git.saurik.com Git - wxWidgets.git/commitdiff
Added support for the wxAUI Notebook
authorRobin Dunn <robin@alldunn.com>
Sat, 22 Jul 2006 23:02:47 +0000 (23:02 +0000)
committerRobin Dunn <robin@alldunn.com>
Sat, 22 Jul 2006 23:02:47 +0000 (23:02 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@40243 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

wxPython/demo/AUI.py [deleted file]
wxPython/demo/AUI_DockingWindowMgr.py [new file with mode: 0644]
wxPython/demo/AUI_Notebook.py [new file with mode: 0644]
wxPython/demo/Main.py
wxPython/setup.py
wxPython/src/aui.i

diff --git a/wxPython/demo/AUI.py b/wxPython/demo/AUI.py
deleted file mode 100755 (executable)
index 44d05a7..0000000
+++ /dev/null
@@ -1,1114 +0,0 @@
-import wx
-import wx.grid
-import wx.html
-import wx.aui
-
-import cStringIO
-
-ID_CreateTree = wx.ID_HIGHEST+1
-ID_CreateGrid = ID_CreateTree+2
-ID_CreateText = ID_CreateTree+3
-ID_CreateHTML = ID_CreateTree+4
-ID_CreateSizeReport = ID_CreateTree+5
-ID_GridContent = ID_CreateTree+6
-ID_TextContent = ID_CreateTree+7
-ID_TreeContent = ID_CreateTree+8
-ID_HTMLContent = ID_CreateTree+9
-ID_SizeReportContent = ID_CreateTree+10
-ID_CreatePerspective = ID_CreateTree+11
-ID_CopyPerspective = ID_CreateTree+12
-ID_AllowFloating = ID_CreateTree+13
-ID_AllowActivePane = ID_CreateTree+14
-ID_TransparentHint = ID_CreateTree+15
-ID_TransparentHintFade = ID_CreateTree+16
-ID_TransparentDrag = ID_CreateTree+17
-ID_NoGradient = ID_CreateTree+18
-ID_VerticalGradient = ID_CreateTree+19
-ID_HorizontalGradient = ID_CreateTree+20
-ID_Settings = ID_CreateTree+21
-ID_About = ID_CreateTree+22
-ID_FirstPerspective = ID_CreatePerspective+1000
-
-#----------------------------------------------------------------------
-def GetMondrianData():
-    return \
-'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x00 \x00\x00\x00 \x08\x06\x00\
-\x00\x00szz\xf4\x00\x00\x00\x04sBIT\x08\x08\x08\x08|\x08d\x88\x00\x00\x00qID\
-ATX\x85\xed\xd6;\n\x800\x10E\xd1{\xc5\x8d\xb9r\x97\x16\x0b\xad$\x8a\x82:\x16\
-o\xda\x84pB2\x1f\x81Fa\x8c\x9c\x08\x04Z{\xcf\xa72\xbcv\xfa\xc5\x08 \x80r\x80\
-\xfc\xa2\x0e\x1c\xe4\xba\xfaX\x1d\xd0\xde]S\x07\x02\xd8>\xe1wa-`\x9fQ\xe9\
-\x86\x01\x04\x10\x00\\(Dk\x1b-\x04\xdc\x1d\x07\x14\x98;\x0bS\x7f\x7f\xf9\x13\
-\x04\x10@\xf9X\xbe\x00\xc9 \x14K\xc1<={\x00\x00\x00\x00IEND\xaeB`\x82' 
-
-
-def GetMondrianBitmap():
-    return wx.BitmapFromImage(GetMondrianImage())
-
-
-def GetMondrianImage():
-    stream = cStringIO.StringIO(GetMondrianData())
-    return wx.ImageFromStream(stream)
-
-
-def GetMondrianIcon():
-    icon = wx.EmptyIcon()
-    icon.CopyFromBitmap(GetMondrianBitmap())
-    return icon
-
-
-class PyAUIFrame(wx.Frame):
-    
-    def __init__(self, parent, id=-1, title="", pos=wx.DefaultPosition,
-                 size=wx.DefaultSize, style=wx.DEFAULT_FRAME_STYLE |
-                                            wx.SUNKEN_BORDER |
-                                            wx.CLIP_CHILDREN):
-
-        wx.Frame.__init__(self, parent, id, title, pos, size, style)
-        
-        # tell FrameManager to manage this frame        
-        self._mgr = wx.aui.FrameManager()
-        self._mgr.SetFrame(self)
-        
-        self._perspectives = []
-        self.n = 0
-        self.x = 0
-        
-        self.SetIcon(GetMondrianIcon())
-
-        # create menu
-        mb = wx.MenuBar()
-
-        file_menu = wx.Menu()
-        file_menu.Append(wx.ID_EXIT, "Exit")
-
-        view_menu = wx.Menu()
-        view_menu.Append(ID_CreateText, "Create Text Control")
-        view_menu.Append(ID_CreateHTML, "Create HTML Control")
-        view_menu.Append(ID_CreateTree, "Create Tree")
-        view_menu.Append(ID_CreateGrid, "Create Grid")
-        view_menu.Append(ID_CreateSizeReport, "Create Size Reporter")
-        view_menu.AppendSeparator()
-        view_menu.Append(ID_GridContent, "Use a Grid for the Content Pane")
-        view_menu.Append(ID_TextContent, "Use a Text Control for the Content Pane")
-        view_menu.Append(ID_HTMLContent, "Use an HTML Control for the Content Pane")
-        view_menu.Append(ID_TreeContent, "Use a Tree Control for the Content Pane")
-        view_menu.Append(ID_SizeReportContent, "Use a Size Reporter for the Content Pane")    
-           
-        options_menu = wx.Menu()
-        options_menu.AppendCheckItem(ID_AllowFloating, "Allow Floating")
-        options_menu.AppendCheckItem(ID_TransparentHint, "Transparent Hint")
-        options_menu.AppendCheckItem(ID_TransparentHintFade, "Transparent Hint Fade-in")
-        options_menu.AppendCheckItem(ID_TransparentDrag, "Transparent Drag")
-        options_menu.AppendCheckItem(ID_AllowActivePane, "Allow Active Pane")
-        options_menu.AppendSeparator()
-        options_menu.AppendRadioItem(ID_NoGradient, "No Caption Gradient")
-        options_menu.AppendRadioItem(ID_VerticalGradient, "Vertical Caption Gradient")
-        options_menu.AppendRadioItem(ID_HorizontalGradient, "Horizontal Caption Gradient")
-        options_menu.AppendSeparator()
-        options_menu.Append(ID_Settings, "Settings Pane")
-        
-        self._perspectives_menu = wx.Menu()
-        self._perspectives_menu.Append(ID_CreatePerspective, "Create Perspective")
-        self._perspectives_menu.Append(ID_CopyPerspective, "Copy Perspective Data To Clipboard")
-        self._perspectives_menu.AppendSeparator()
-        self._perspectives_menu.Append(ID_FirstPerspective+0, "Default Startup")
-        self._perspectives_menu.Append(ID_FirstPerspective+1, "All Panes")
-        self._perspectives_menu.Append(ID_FirstPerspective+2, "Vertical Toolbar")
-
-        help_menu = wx.Menu()
-        help_menu.Append(ID_About, "About...")
-        
-        mb.Append(file_menu, "File")
-        mb.Append(view_menu, "View")
-        mb.Append(self._perspectives_menu, "Perspectives")
-        mb.Append(options_menu, "Options")
-        mb.Append(help_menu, "Help")
-        
-        self.SetMenuBar(mb)
-
-        self.statusbar = self.CreateStatusBar(2, wx.ST_SIZEGRIP)
-        self.statusbar.SetStatusWidths([-2, -3])
-        self.statusbar.SetStatusText("Ready", 0)
-        self.statusbar.SetStatusText("Welcome To wxPython!", 1)
-
-        # min size for the frame itself isn't completely done.
-        # see the end up FrameManager::Update() for the test
-        # code. For now, just hard code a frame minimum size
-        self.SetMinSize(wx.Size(400, 300))
-
-        # create some toolbars
-        tb1 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
-                         wx.TB_FLAT | wx.TB_NODIVIDER)
-        tb1.SetToolBitmapSize(wx.Size(48,48))
-        tb1.AddLabelTool(101, "Test", wx.ArtProvider_GetBitmap(wx.ART_ERROR))
-        tb1.AddSeparator()
-        tb1.AddLabelTool(102, "Test", wx.ArtProvider_GetBitmap(wx.ART_QUESTION))
-        tb1.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_INFORMATION))
-        tb1.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_WARNING))
-        tb1.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_MISSING_IMAGE))
-        tb1.Realize()
-
-        tb2 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
-                         wx.TB_FLAT | wx.TB_NODIVIDER)
-        tb2.SetToolBitmapSize(wx.Size(16,16))
-        tb2_bmp1 = wx.ArtProvider_GetBitmap(wx.ART_QUESTION, wx.ART_OTHER, wx.Size(16, 16))
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddSeparator()
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddSeparator()
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.AddLabelTool(101, "Test", tb2_bmp1)
-        tb2.Realize()
-       
-        tb3 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
-                         wx.TB_FLAT | wx.TB_NODIVIDER)
-        tb3.SetToolBitmapSize(wx.Size(16,16))
-        tb3_bmp1 = wx.ArtProvider_GetBitmap(wx.ART_FOLDER, wx.ART_OTHER, wx.Size(16, 16))
-        tb3.AddLabelTool(101, "Test", tb3_bmp1)
-        tb3.AddLabelTool(101, "Test", tb3_bmp1)
-        tb3.AddLabelTool(101, "Test", tb3_bmp1)
-        tb3.AddLabelTool(101, "Test", tb3_bmp1)
-        tb3.AddSeparator()
-        tb3.AddLabelTool(101, "Test", tb3_bmp1)
-        tb3.AddLabelTool(101, "Test", tb3_bmp1)
-        tb3.Realize()
-
-        tb4 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
-                         wx.TB_FLAT | wx.TB_NODIVIDER | wx.TB_HORZ_TEXT)
-        tb4.SetToolBitmapSize(wx.Size(16,16))
-        tb4_bmp1 = wx.ArtProvider_GetBitmap(wx.ART_NORMAL_FILE, wx.ART_OTHER, wx.Size(16, 16))
-        tb4.AddLabelTool(101, "Item 1", tb4_bmp1)
-        tb4.AddLabelTool(101, "Item 2", tb4_bmp1)
-        tb4.AddLabelTool(101, "Item 3", tb4_bmp1)
-        tb4.AddLabelTool(101, "Item 4", tb4_bmp1)
-        tb4.AddSeparator()
-        tb4.AddLabelTool(101, "Item 5", tb4_bmp1)
-        tb4.AddLabelTool(101, "Item 6", tb4_bmp1)
-        tb4.AddLabelTool(101, "Item 7", tb4_bmp1)
-        tb4.AddLabelTool(101, "Item 8", tb4_bmp1)
-        tb4.Realize()
-
-        tb5 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
-                         wx.TB_FLAT | wx.TB_NODIVIDER | wx.TB_VERTICAL)
-        tb5.SetToolBitmapSize(wx.Size(48, 48))
-        tb5.AddLabelTool(101, "Test", wx.ArtProvider_GetBitmap(wx.ART_ERROR)) 
-        tb5.AddSeparator()
-        tb5.AddLabelTool(102, "Test", wx.ArtProvider_GetBitmap(wx.ART_QUESTION))
-        tb5.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_INFORMATION))
-        tb5.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_WARNING))
-        tb5.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_MISSING_IMAGE))
-        tb5.Realize()
-
-        # add a bunch of panes
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test1").Caption("Pane Caption").Top())
-
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test2").Caption("Client Size Reporter").
-                          Bottom().Position(1))
-
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test3").Caption("Client Size Reporter").
-                          Bottom())
-     
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test4").Caption("Pane Caption").
-                          Left())
-                      
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test5").Caption("Pane Caption").
-                          Right())
-                      
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test6").Caption("Client Size Reporter").
-                          Right().Row(1))
-
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test7").Caption("Client Size Reporter").
-                          Left().Layer(1))
-                      
-        self._mgr.AddPane(self.CreateTreeCtrl(), wx.aui.PaneInfo().
-                          Name("test8").Caption("Tree Pane").
-                          Left().Layer(1).Position(1))
-                      
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test9").Caption("Min Size 200x100").
-                          BestSize(wx.Size(200,100)).MinSize(wx.Size(200,100)).
-                          Bottom().Layer(1))
-
-        self._mgr.AddPane(self.CreateTextCtrl(), wx.aui.PaneInfo().
-                          Name("test10").Caption("Text Pane").
-                          Bottom().Layer(1).Position(1))
-                                      
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("test11").Caption("Fixed Pane").
-                          Bottom().Layer(1).Position(2).Fixed())
-
-        self._mgr.AddPane(SettingsPanel(self, self), wx.aui.PaneInfo().
-                          Name("settings").Caption("Dock Manager Settings").
-                          Dockable(False).Float().Hide())
-
-        # create some center panes
-
-        self._mgr.AddPane(self.CreateGrid(), wx.aui.PaneInfo().Name("grid_content").
-                          CenterPane().Hide())
-
-        self._mgr.AddPane(self.CreateTreeCtrl(), wx.aui.PaneInfo().Name("tree_content").
-                          CenterPane().Hide())
-                      
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().Name("sizereport_content").
-                          CenterPane().Hide())
-
-        self._mgr.AddPane(self.CreateTextCtrl(), wx.aui.PaneInfo().Name("text_content").
-                          CenterPane().Hide())
-
-        self._mgr.AddPane(self.CreateHTMLCtrl(), wx.aui.PaneInfo().Name("html_content").
-                          CenterPane())
-                                
-        # add the toolbars to the manager
-                        
-        self._mgr.AddPane(tb1, wx.aui.PaneInfo().
-                          Name("tb1").Caption("Big Toolbar").
-                          ToolbarPane().Top().
-                          LeftDockable(False).RightDockable(False))
-
-        self._mgr.AddPane(tb2, wx.aui.PaneInfo().
-                          Name("tb2").Caption("Toolbar 2").
-                          ToolbarPane().Top().Row(1).
-                          LeftDockable(False).RightDockable(False))
-                      
-        self._mgr.AddPane(tb3, wx.aui.PaneInfo().
-                          Name("tb3").Caption("Toolbar 3").
-                          ToolbarPane().Top().Row(1).Position(1).
-                          LeftDockable(False).RightDockable(False))
-                      
-        self._mgr.AddPane(tb4, wx.aui.PaneInfo().
-                          Name("tb4").Caption("Sample Bookmark Toolbar").
-                          ToolbarPane().Top().Row(2).
-                          LeftDockable(False).RightDockable(False))
-
-        self._mgr.AddPane(tb5, wx.aui.PaneInfo().
-                          Name("tbvert").Caption("Sample Vertical Toolbar").
-                          ToolbarPane().Left().GripperTop().
-                          TopDockable(False).BottomDockable(False))
-                      
-        self._mgr.AddPane(wx.Button(self, -1, "Test Button"),
-                          wx.aui.PaneInfo().Name("tb5").
-                          ToolbarPane().Top().Row(2).Position(1).
-                          LeftDockable(False).RightDockable(False))
-
-        # make some default perspectives
-
-        self._mgr.GetPane("tbvert").Hide()
-        
-        perspective_all = self._mgr.SavePerspective()
-        
-        all_panes = self._mgr.GetAllPanes()
-        
-        for ii in xrange(len(all_panes)):
-            if not all_panes[ii].IsToolbar():
-                all_panes[ii].Hide()
-                
-        self._mgr.GetPane("tb1").Hide()
-        self._mgr.GetPane("tb5").Hide()
-        self._mgr.GetPane("test8").Show().Left().Layer(0).Row(0).Position(0)
-        self._mgr.GetPane("test10").Show().Bottom().Layer(0).Row(0).Position(0)
-        self._mgr.GetPane("html_content").Show()
-
-        perspective_default = self._mgr.SavePerspective()
-
-        for ii in xrange(len(all_panes)):
-            if not all_panes[ii].IsToolbar():
-                all_panes[ii].Hide()
-
-        self._mgr.GetPane("tb1").Hide()
-        self._mgr.GetPane("tb5").Hide()
-        self._mgr.GetPane("tbvert").Show()
-        self._mgr.GetPane("grid_content").Show()
-        self._mgr.GetPane("test8").Show().Left().Layer(0).Row(0).Position(0)
-        self._mgr.GetPane("test10").Show().Bottom().Layer(0).Row(0).Position(0)
-        self._mgr.GetPane("html_content").Show()
-
-        perspective_vert = self._mgr.SavePerspective()
-        
-        self._perspectives.append(perspective_default)
-        self._perspectives.append(perspective_all)
-        self._perspectives.append(perspective_vert)
-
-        self._mgr.GetPane("tbvert").Hide()
-        self._mgr.GetPane("grid_content").Hide()
-
-        # "commit" all changes made to FrameManager   
-        self._mgr.Update()
-
-        self.Bind(wx.EVT_ERASE_BACKGROUND, self.OnEraseBackground)
-        self.Bind(wx.EVT_SIZE, self.OnSize)
-        self.Bind(wx.EVT_CLOSE, self.OnClose)
-
-        # Show How To Use The Closing Panes Event
-        self.Bind(wx.aui.EVT_AUI_PANEBUTTON, self.OnPaneButton)
-        
-        self.Bind(wx.EVT_MENU, self.OnCreateTree, id=ID_CreateTree)
-        self.Bind(wx.EVT_MENU, self.OnCreateGrid, id=ID_CreateGrid)
-        self.Bind(wx.EVT_MENU, self.OnCreateText, id=ID_CreateText)
-        self.Bind(wx.EVT_MENU, self.OnCreateHTML, id=ID_CreateHTML)
-        self.Bind(wx.EVT_MENU, self.OnCreateSizeReport, id=ID_CreateSizeReport)
-        self.Bind(wx.EVT_MENU, self.OnCreatePerspective, id=ID_CreatePerspective)
-        self.Bind(wx.EVT_MENU, self.OnCopyPerspective, id=ID_CopyPerspective)
-        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_AllowFloating)
-        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_TransparentHint)
-        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_TransparentHintFade)
-        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_TransparentDrag)
-        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_AllowActivePane)
-        self.Bind(wx.EVT_MENU, self.OnGradient, id=ID_NoGradient)
-        self.Bind(wx.EVT_MENU, self.OnGradient, id=ID_VerticalGradient)
-        self.Bind(wx.EVT_MENU, self.OnGradient, id=ID_HorizontalGradient)
-        self.Bind(wx.EVT_MENU, self.OnSettings, id=ID_Settings)
-        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_GridContent)
-        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_TreeContent)
-        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_TextContent)
-        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_SizeReportContent)
-        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_HTMLContent)
-        self.Bind(wx.EVT_MENU, self.OnClose, id=wx.ID_EXIT)
-        self.Bind(wx.EVT_MENU, self.OnAbout, id=ID_About)
-
-        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_AllowFloating)
-        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_TransparentHint)
-        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_TransparentHintFade)
-        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_TransparentDrag)
-        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_NoGradient)
-        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_VerticalGradient)
-        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_HorizontalGradient)
-    
-        self.Bind(wx.EVT_MENU_RANGE, self.OnRestorePerspective, id=ID_FirstPerspective,
-                  id2=ID_FirstPerspective+1000)
-
-
-    def OnPaneButton(self, event):
-
-        caption = event.GetPane().caption
-
-        if caption in ["Tree Pane", "Dock Manager Settings", "Fixed Pane"]:
-            msg = "Are You Sure You Want To Close This Pane?"
-            dlg = wx.MessageDialog(self, msg, "PyAUI Question",
-                                   wx.YES_NO | wx.NO_DEFAULT | wx.CANCEL | wx.ICON_QUESTION)
-
-            if dlg.ShowModal() in [wx.ID_NO, wx.ID_CANCEL]:
-                dlg.Destroy()
-                return
-
-            dlg.Destroy()
-            
-        event.Skip()
-        
-
-    def OnClose(self, event):
-        
-        self._mgr.UnInit()
-        self.Destroy()
-
-        event.Skip()        
-
-
-    def OnAbout(self, event):
-
-        msg = "wx.aui Demo\n" + \
-              "An advanced window management library for wxWidgets\n" + \
-              "(c) Copyright 2005-2006, Kirix Corporation"
-        dlg = wx.MessageDialog(self, msg, "About wx.aui Demo",
-                               wx.OK | wx.ICON_INFORMATION)
-        dlg.ShowModal()
-        dlg.Destroy()        
-
-
-    def GetDockArt(self):
-
-        return self._mgr.GetArtProvider()
-
-
-    def DoUpdate(self):
-
-        self._mgr.Update()
-
-
-    def OnEraseBackground(self, event):
-
-        event.Skip()
-
-
-    def OnSize(self, event):
-
-        event.Skip()
-
-
-    def OnSettings(self, event):
-
-        # show the settings pane, and float it
-        floating_pane = self._mgr.GetPane("settings").Float().Show()
-
-        if floating_pane.floating_pos == wx.DefaultPosition:
-            floating_pane.FloatingPosition(self.GetStartPosition())
-
-        self._mgr.Update()
-
-
-    def OnGradient(self, event):
-
-        gradient = 0
-
-        if event.GetId() == ID_NoGradient:
-            gradient = wx.aui.AUI_GRADIENT_NONE
-        elif event.GetId() == ID_VerticalGradient:
-            gradient = wx.aui.AUI_GRADIENT_VERTICAL
-        elif event.GetId() == ID_HorizontalGradient:
-            gradient = wx.aui.AUI_GRADIENT_HORIZONTAL
-
-        self._mgr.GetArtProvider().SetMetric(wx.aui.AUI_ART_GRADIENT_TYPE, gradient)
-        self._mgr.Update()
-
-
-    def OnManagerFlag(self, event):
-
-        flag = 0
-        
-        if wx.Platform != "__WXMSW__" and wx.Platform != '__WXMAC__':
-            if event.GetId() == ID_TransparentDrag or \
-               event.GetId() == ID_TransparentHint or \
-               event.GetId() == ID_TransparentHintFade:
-            
-                wx.MessageBox("This option is presently only available on wxMSW and wxMac")
-                return
-
-        if event.GetId() == ID_AllowFloating:
-            flag = wx.aui.AUI_MGR_ALLOW_FLOATING
-
-        elif event.GetId() == ID_TransparentDrag:
-            flag = wx.aui.AUI_MGR_TRANSPARENT_DRAG
-
-        elif event.GetId() == ID_TransparentHint:
-            flag = wx.aui.AUI_MGR_TRANSPARENT_HINT
-
-        elif event.GetId() == ID_TransparentHintFade:
-            flag = wx.aui.AUI_MGR_TRANSPARENT_HINT_FADE
-
-        elif event.GetId() == ID_AllowActivePane:
-            flag = wx.aui.AUI_MGR_ALLOW_ACTIVE_PANE
-            
-        self._mgr.SetFlags(self._mgr.GetFlags() ^ flag)
-
-
-    def OnUpdateUI(self, event):
-
-        flags = self._mgr.GetFlags()
-
-        if event.GetId() == ID_NoGradient:
-            event.Check(((self._mgr.GetArtProvider().GetMetric(wx.aui.AUI_ART_GRADIENT_TYPE) == wx.aui.AUI_GRADIENT_NONE) and \
-                        [True] or [False])[0])
-
-        elif event.GetId() == ID_VerticalGradient:
-            event.Check(((self._mgr.GetArtProvider().GetMetric(wx.aui.AUI_ART_GRADIENT_TYPE) == wx.aui.AUI_GRADIENT_VERTICAL) and \
-                        [True] or [False])[0])
-
-        elif event.GetId() == ID_HorizontalGradient:
-            event.Check(((self._mgr.GetArtProvider().GetMetric(wx.aui.AUI_ART_GRADIENT_TYPE) == wx.aui.AUI_GRADIENT_HORIZONTAL) and \
-                        [True] or [False])[0])
-
-        elif event.GetId() == ID_AllowFloating:
-            event.Check(((flags & wx.aui.AUI_MGR_ALLOW_FLOATING) and [True] or [False])[0])
-
-        elif event.GetId() == ID_TransparentDrag:
-            event.Check(((flags & wx.aui.AUI_MGR_TRANSPARENT_DRAG) and [True] or [False])[0])
-
-        elif event.GetId() == ID_TransparentHint:
-            event.Check(((flags & wx.aui.AUI_MGR_TRANSPARENT_HINT) and [True] or [False])[0])
-
-        elif event.GetId() == ID_TransparentHintFade:
-            event.Check(((flags & wx.aui.AUI_MGR_TRANSPARENT_HINT_FADE) and [True] or [False])[0])
-                
-
-    def OnCreatePerspective(self, event):
-
-        dlg = wx.TextEntryDialog(self, "Enter a name for the new perspective:", "AUI Test")
-        
-        dlg.SetValue(("Perspective %d")%(len(self._perspectives)+1))
-        if dlg.ShowModal() != wx.ID_OK:
-            return
-        
-        if len(self._perspectives) == 0:
-            self._perspectives_menu.AppendSeparator()
-        
-        self._perspectives_menu.Append(ID_FirstPerspective + len(self._perspectives), dlg.GetValue())
-        self._perspectives.append(self._mgr.SavePerspective())
-
-
-    def OnCopyPerspective(self, event):
-
-        s = self._mgr.SavePerspective()
-        
-        if wx.TheClipboard.Open():
-        
-            wx.TheClipboard.SetData(wx.TextDataObject(s))
-            wx.TheClipboard.Close()
-        
-    def OnRestorePerspective(self, event):
-
-        self._mgr.LoadPerspective(self._perspectives[event.GetId() - ID_FirstPerspective])
-
-
-    def GetStartPosition(self):
-
-        self.x = self.x + 20
-        x = self.x
-        pt = self.ClientToScreen(wx.Point(0, 0))
-        
-        return wx.Point(pt.x + x, pt.y + x)
-
-
-    def OnCreateTree(self, event):
-
-        self._mgr.AddPane(self.CreateTreeCtrl(), wx.aui.PaneInfo().
-                          Name("Test").Caption("Tree Control").
-                          Float().FloatingPosition(self.GetStartPosition()).
-                          FloatingSize(wx.Size(150, 300)))
-        self._mgr.Update()
-
-
-    def OnCreateGrid(self, event):
-
-        self._mgr.AddPane(self.CreateGrid(), wx.aui.PaneInfo().
-                          Name("Test").Caption("Grid").
-                          Float().FloatingPosition(self.GetStartPosition()).
-                          FloatingSize(wx.Size(300, 200)))
-        self._mgr.Update()
-
-
-    def OnCreateHTML(self, event):
-
-        self._mgr.AddPane(self.CreateHTMLCtrl(), wx.aui.PaneInfo().
-                          Name("Test").Caption("HTML Content").
-                          Float().FloatingPosition(self.GetStartPosition()).
-                          FloatingSize(wx.Size(300, 200)))
-        self._mgr.Update()
-
-
-    def OnCreateText(self, event):
-
-        self._mgr.AddPane(self.CreateTextCtrl(), wx.aui.PaneInfo().
-                          Name("Test").Caption("Text Control").
-                          Float().FloatingPosition(self.GetStartPosition()))
-        self._mgr.Update()
-
-
-    def OnCreateSizeReport(self, event):
-
-        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
-                          Name("Test").Caption("Client Size Reporter").
-                          Float().FloatingPosition(self.GetStartPosition()))
-        self._mgr.Update()
-
-
-    def OnChangeContentPane(self, event):
-
-        self._mgr.GetPane("grid_content").Show(event.GetId() == ID_GridContent)
-        self._mgr.GetPane("text_content").Show(event.GetId() == ID_TextContent)
-        self._mgr.GetPane("tree_content").Show(event.GetId() == ID_TreeContent)
-        self._mgr.GetPane("sizereport_content").Show(event.GetId() == ID_SizeReportContent)
-        self._mgr.GetPane("html_content").Show(event.GetId() == ID_HTMLContent)
-        self._mgr.Update()
-
-
-    def CreateTextCtrl(self):
-
-        text = ("This is text box %d")%(self.n + 1)
-
-        return wx.TextCtrl(self,-1, text, wx.Point(0, 0), wx.Size(150, 90),
-                           wx.NO_BORDER | wx.TE_MULTILINE)
-
-
-
-    def CreateGrid(self):
-
-        grid = wx.grid.Grid(self, -1, wx.Point(0, 0), wx.Size(150, 250),
-                            wx.NO_BORDER | wx.WANTS_CHARS)
-        
-        grid.CreateGrid(50, 20)
-
-        return grid
-
-
-    def CreateTreeCtrl(self):
-
-        tree = wx.TreeCtrl(self, -1, wx.Point(0, 0), wx.Size(160, 250),
-                           wx.TR_DEFAULT_STYLE | wx.NO_BORDER)
-        
-        root = tree.AddRoot("PyAUI Project")
-        items = []
-
-        imglist = wx.ImageList(16, 16, True, 2)
-        imglist.Add(wx.ArtProvider_GetBitmap(wx.ART_FOLDER, wx.ART_OTHER, wx.Size(16,16)))
-        imglist.Add(wx.ArtProvider_GetBitmap(wx.ART_NORMAL_FILE, wx.ART_OTHER, wx.Size(16,16)))
-        tree.AssignImageList(imglist)
-
-        items.append(tree.AppendItem(root, "Item 1", 0))
-        items.append(tree.AppendItem(root, "Item 2", 0))
-        items.append(tree.AppendItem(root, "Item 3", 0))
-        items.append(tree.AppendItem(root, "Item 4", 0))
-        items.append(tree.AppendItem(root, "Item 5", 0))
-
-        for ii in xrange(len(items)):
-        
-            id = items[ii]
-            tree.AppendItem(id, "Subitem 1", 1)
-            tree.AppendItem(id, "Subitem 2", 1)
-            tree.AppendItem(id, "Subitem 3", 1)
-            tree.AppendItem(id, "Subitem 4", 1)
-            tree.AppendItem(id, "Subitem 5", 1)
-        
-        tree.Expand(root)
-
-        return tree
-
-
-    def CreateSizeReportCtrl(self, width=80, height=80):
-
-        ctrl = SizeReportCtrl(self, -1, wx.DefaultPosition,
-                              wx.Size(width, height), self._mgr)
-        return ctrl
-
-
-    def CreateHTMLCtrl(self):
-        ctrl = wx.html.HtmlWindow(self, -1, wx.DefaultPosition, wx.Size(400, 300))
-        if "gtk2" in wx.PlatformInfo:
-            ctrl.SetStandardFonts()
-        ctrl.SetPage(self.GetIntroText())        
-        return ctrl
-
-
-    def GetIntroText(self):
-        return overview
-
-
-# -- wx.SizeReportCtrl --
-# (a utility control that always reports it's client size)
-
-class SizeReportCtrl(wx.PyControl):
-
-    def __init__(self, parent, id=wx.ID_ANY, pos=wx.DefaultPosition,
-                 size=wx.DefaultSize, mgr=None):
-
-        wx.PyControl.__init__(self, parent, id, pos, size, wx.NO_BORDER)
-            
-        self._mgr = mgr
-
-        self.Bind(wx.EVT_PAINT, self.OnPaint)
-        self.Bind(wx.EVT_SIZE, self.OnSize)
-        self.Bind(wx.EVT_ERASE_BACKGROUND, self.OnEraseBackground)
-
-
-    def OnPaint(self, event):
-
-        dc = wx.PaintDC(self)
-        
-        size = self.GetClientSize()
-        s = ("Size: %d x %d")%(size.x, size.y)
-
-        dc.SetFont(wx.NORMAL_FONT)
-        w, height = dc.GetTextExtent(s)
-        height = height + 3
-        dc.SetBrush(wx.WHITE_BRUSH)
-        dc.SetPen(wx.WHITE_PEN)
-        dc.DrawRectangle(0, 0, size.x, size.y)
-        dc.SetPen(wx.LIGHT_GREY_PEN)
-        dc.DrawLine(0, 0, size.x, size.y)
-        dc.DrawLine(0, size.y, size.x, 0)
-        dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2))
-        
-        if self._mgr:
-        
-            pi = self._mgr.GetPane(self)
-            
-            s = ("Layer: %d")%pi.dock_layer
-            w, h = dc.GetTextExtent(s)
-            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*1))
-           
-            s = ("Dock: %d Row: %d")%(pi.dock_direction, pi.dock_row)
-            w, h = dc.GetTextExtent(s)
-            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*2))
-            
-            s = ("Position: %d")%pi.dock_pos
-            w, h = dc.GetTextExtent(s)
-            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*3))
-            
-            s = ("Proportion: %d")%pi.dock_proportion
-            w, h = dc.GetTextExtent(s)
-            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*4))
-        
-
-    def OnEraseBackground(self, event):
-        # intentionally empty
-        pass        
-    
-
-    def OnSize(self, event):
-    
-        self.Refresh()
-        event.Skip()
-    
-
-ID_PaneBorderSize = wx.ID_HIGHEST + 1
-ID_SashSize = ID_PaneBorderSize + 1
-ID_CaptionSize = ID_PaneBorderSize + 2
-ID_BackgroundColor = ID_PaneBorderSize + 3
-ID_SashColor = ID_PaneBorderSize + 4
-ID_InactiveCaptionColor =  ID_PaneBorderSize + 5
-ID_InactiveCaptionGradientColor = ID_PaneBorderSize + 6
-ID_InactiveCaptionTextColor = ID_PaneBorderSize + 7
-ID_ActiveCaptionColor = ID_PaneBorderSize + 8
-ID_ActiveCaptionGradientColor = ID_PaneBorderSize + 9
-ID_ActiveCaptionTextColor = ID_PaneBorderSize + 10
-ID_BorderColor = ID_PaneBorderSize + 11
-ID_GripperColor = ID_PaneBorderSize + 12
-    
-class SettingsPanel(wx.Panel):
-    
-    def __init__(self, parent, frame):
-
-        wx.Panel.__init__(self, parent, wx.ID_ANY, wx.DefaultPosition,
-                          wx.DefaultSize)
-
-        self._frame = frame
-        
-        vert = wx.BoxSizer(wx.VERTICAL)
-
-        s1 = wx.BoxSizer(wx.HORIZONTAL)
-        self._border_size = wx.SpinCtrl(self, ID_PaneBorderSize, "", wx.DefaultPosition, wx.Size(50,20))
-        s1.Add((1, 1), 1, wx.EXPAND)
-        s1.Add(wx.StaticText(self, -1, "Pane Border Size:"))
-        s1.Add(self._border_size)
-        s1.Add((1, 1), 1, wx.EXPAND)
-        s1.SetItemMinSize(1, (180, 20))
-        #vert.Add(s1, 0, wx.EXPAND | wxLEFT | wxBOTTOM, 5)
-
-        s2 = wx.BoxSizer(wx.HORIZONTAL)
-        self._sash_size = wx.SpinCtrl(self, ID_SashSize, "", wx.DefaultPosition, wx.Size(50,20))
-        s2.Add((1, 1), 1, wx.EXPAND)
-        s2.Add(wx.StaticText(self, -1, "Sash Size:"))
-        s2.Add(self._sash_size)
-        s2.Add((1, 1), 1, wx.EXPAND)
-        s2.SetItemMinSize(1, (180, 20))
-        #vert.Add(s2, 0, wx.EXPAND | wxLEFT | wxBOTTOM, 5)
-
-        s3 = wx.BoxSizer(wx.HORIZONTAL)
-        self._caption_size = wx.SpinCtrl(self, ID_CaptionSize, "", wx.DefaultPosition, wx.Size(50,20))
-        s3.Add((1, 1), 1, wx.EXPAND)
-        s3.Add(wx.StaticText(self, -1, "Caption Size:"))
-        s3.Add(self._caption_size)
-        s3.Add((1, 1), 1, wx.EXPAND)
-        s3.SetItemMinSize(1, (180, 20))
-        #vert.Add(s3, 0, wx.EXPAND | wxLEFT | wxBOTTOM, 5)
-
-        #vert.Add(1, 1, 1, wx.EXPAND)
-
-        b = self.CreateColorBitmap(wx.BLACK)
-
-        s4 = wx.BoxSizer(wx.HORIZONTAL)
-        self._background_color = wx.BitmapButton(self, ID_BackgroundColor, b, wx.DefaultPosition, wx.Size(50,25))
-        s4.Add((1, 1), 1, wx.EXPAND)
-        s4.Add(wx.StaticText(self, -1, "Background Color:"))
-        s4.Add(self._background_color)
-        s4.Add((1, 1), 1, wx.EXPAND)
-        s4.SetItemMinSize(1, (180, 20))
-
-        s5 = wx.BoxSizer(wx.HORIZONTAL)
-        self._sash_color = wx.BitmapButton(self, ID_SashColor, b, wx.DefaultPosition, wx.Size(50,25))
-        s5.Add((1, 1), 1, wx.EXPAND)
-        s5.Add(wx.StaticText(self, -1, "Sash Color:"))
-        s5.Add(self._sash_color)
-        s5.Add((1, 1), 1, wx.EXPAND)
-        s5.SetItemMinSize(1, (180, 20))
-
-        s6 = wx.BoxSizer(wx.HORIZONTAL)
-        self._inactive_caption_color = wx.BitmapButton(self, ID_InactiveCaptionColor, b,
-                                                       wx.DefaultPosition, wx.Size(50,25))
-        s6.Add((1, 1), 1, wx.EXPAND)
-        s6.Add(wx.StaticText(self, -1, "Normal Caption:"))
-        s6.Add(self._inactive_caption_color)
-        s6.Add((1, 1), 1, wx.EXPAND)
-        s6.SetItemMinSize(1, (180, 20))
-
-        s7 = wx.BoxSizer(wx.HORIZONTAL)
-        self._inactive_caption_gradient_color = wx.BitmapButton(self, ID_InactiveCaptionGradientColor,
-                                                                b, wx.DefaultPosition, wx.Size(50,25))
-        s7.Add((1, 1), 1, wx.EXPAND)
-        s7.Add(wx.StaticText(self, -1, "Normal Caption Gradient:"))
-        s7.Add(self._inactive_caption_gradient_color)
-        s7.Add((1, 1), 1, wx.EXPAND)
-        s7.SetItemMinSize(1, (180, 20))
-
-        s8 = wx.BoxSizer(wx.HORIZONTAL)
-        self._inactive_caption_text_color = wx.BitmapButton(self, ID_InactiveCaptionTextColor, b,
-                                                            wx.DefaultPosition, wx.Size(50,25))
-        s8.Add((1, 1), 1, wx.EXPAND)
-        s8.Add(wx.StaticText(self, -1, "Normal Caption Text:"))
-        s8.Add(self._inactive_caption_text_color)
-        s8.Add((1, 1), 1, wx.EXPAND)
-        s8.SetItemMinSize(1, (180, 20))
-
-        s9 = wx.BoxSizer(wx.HORIZONTAL)
-        self._active_caption_color = wx.BitmapButton(self, ID_ActiveCaptionColor, b,
-                                                     wx.DefaultPosition, wx.Size(50,25))
-        s9.Add((1, 1), 1, wx.EXPAND)
-        s9.Add(wx.StaticText(self, -1, "Active Caption:"))
-        s9.Add(self._active_caption_color)
-        s9.Add((1, 1), 1, wx.EXPAND)
-        s9.SetItemMinSize(1, (180, 20))
-
-        s10 = wx.BoxSizer(wx.HORIZONTAL)
-        self._active_caption_gradient_color = wx.BitmapButton(self, ID_ActiveCaptionGradientColor,
-                                                              b, wx.DefaultPosition, wx.Size(50,25))
-        s10.Add((1, 1), 1, wx.EXPAND)
-        s10.Add(wx.StaticText(self, -1, "Active Caption Gradient:"))
-        s10.Add(self._active_caption_gradient_color)
-        s10.Add((1, 1), 1, wx.EXPAND)
-        s10.SetItemMinSize(1, (180, 20))
-
-        s11 = wx.BoxSizer(wx.HORIZONTAL)
-        self._active_caption_text_color = wx.BitmapButton(self, ID_ActiveCaptionTextColor,
-                                                          b, wx.DefaultPosition, wx.Size(50,25))
-        s11.Add((1, 1), 1, wx.EXPAND)
-        s11.Add(wx.StaticText(self, -1, "Active Caption Text:"))
-        s11.Add(self._active_caption_text_color)
-        s11.Add((1, 1), 1, wx.EXPAND)
-        s11.SetItemMinSize(1, (180, 20))
-
-        s12 = wx.BoxSizer(wx.HORIZONTAL)
-        self._border_color = wx.BitmapButton(self, ID_BorderColor, b, wx.DefaultPosition,
-                                             wx.Size(50,25))
-        s12.Add((1, 1), 1, wx.EXPAND)
-        s12.Add(wx.StaticText(self, -1, "Border Color:"))
-        s12.Add(self._border_color)
-        s12.Add((1, 1), 1, wx.EXPAND)
-        s12.SetItemMinSize(1, (180, 20))
-
-        s13 = wx.BoxSizer(wx.HORIZONTAL)
-        self._gripper_color = wx.BitmapButton(self, ID_GripperColor, b, wx.DefaultPosition,
-                                              wx.Size(50,25))
-        s13.Add((1, 1), 1, wx.EXPAND)
-        s13.Add(wx.StaticText(self, -1, "Gripper Color:"))
-        s13.Add(self._gripper_color)
-        s13.Add((1, 1), 1, wx.EXPAND)
-        s13.SetItemMinSize(1, (180, 20))
-        
-        grid_sizer = wx.GridSizer(0, 2)
-        grid_sizer.SetHGap(5)
-        grid_sizer.Add(s1)
-        grid_sizer.Add(s4)
-        grid_sizer.Add(s2)
-        grid_sizer.Add(s5)
-        grid_sizer.Add(s3)
-        grid_sizer.Add(s13)
-        grid_sizer.Add((1, 1))
-        grid_sizer.Add(s12)
-        grid_sizer.Add(s6)
-        grid_sizer.Add(s9)
-        grid_sizer.Add(s7)
-        grid_sizer.Add(s10)
-        grid_sizer.Add(s8)
-        grid_sizer.Add(s11)
-         
-        cont_sizer = wx.BoxSizer(wx.VERTICAL)
-        cont_sizer.Add(grid_sizer, 1, wx.EXPAND | wx.ALL, 5)
-        self.SetSizer(cont_sizer)
-        self.GetSizer().SetSizeHints(self)
-
-        self._border_size.SetValue(frame.GetDockArt().GetMetric(wx.aui.AUI_ART_PANE_BORDER_SIZE))
-        self._sash_size.SetValue(frame.GetDockArt().GetMetric(wx.aui.AUI_ART_SASH_SIZE))
-        self._caption_size.SetValue(frame.GetDockArt().GetMetric(wx.aui.AUI_ART_CAPTION_SIZE))
-        
-        self.UpdateColors()
-
-        self.Bind(wx.EVT_SPINCTRL, self.OnPaneBorderSize, id=ID_PaneBorderSize)
-        self.Bind(wx.EVT_SPINCTRL, self.OnSashSize, id=ID_SashSize)
-        self.Bind(wx.EVT_SPINCTRL, self.OnCaptionSize, id=ID_CaptionSize)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_BackgroundColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_SashColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_InactiveCaptionColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_InactiveCaptionGradientColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_InactiveCaptionTextColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_ActiveCaptionColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_ActiveCaptionGradientColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_ActiveCaptionTextColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_BorderColor)
-        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_GripperColor)
-    
-    
-    def CreateColorBitmap(self, c):
-        image = wx.EmptyImage(25, 14)
-        
-        for x in xrange(25):
-            for y in xrange(14):
-                pixcol = c
-                if x == 0 or x == 24 or y == 0 or y == 13:
-                    pixcol = wx.BLACK
-                    
-                image.SetRGB(x, y, pixcol.Red(), pixcol.Green(), pixcol.Blue())
-            
-        return image.ConvertToBitmap()
-    
-    
-    def UpdateColors(self):
-    
-        bk = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_BACKGROUND_COLOUR)
-        self._background_color.SetBitmapLabel(self.CreateColorBitmap(bk))
-        
-        cap = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_INACTIVE_CAPTION_COLOUR)
-        self._inactive_caption_color.SetBitmapLabel(self.CreateColorBitmap(cap))
-        
-        capgrad = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_INACTIVE_CAPTION_GRADIENT_COLOUR)
-        self._inactive_caption_gradient_color.SetBitmapLabel(self.CreateColorBitmap(capgrad))
-        
-        captxt = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_INACTIVE_CAPTION_TEXT_COLOUR)
-        self._inactive_caption_text_color.SetBitmapLabel(self.CreateColorBitmap(captxt))
-        
-        acap = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_ACTIVE_CAPTION_COLOUR)
-        self._active_caption_color.SetBitmapLabel(self.CreateColorBitmap(acap))
-        
-        acapgrad = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_ACTIVE_CAPTION_GRADIENT_COLOUR)
-        self._active_caption_gradient_color.SetBitmapLabel(self.CreateColorBitmap(acapgrad))
-        
-        acaptxt = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_ACTIVE_CAPTION_TEXT_COLOUR)
-        self._active_caption_text_color.SetBitmapLabel(self.CreateColorBitmap(acaptxt))
-        
-        sash = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_SASH_COLOUR)
-        self._sash_color.SetBitmapLabel(self.CreateColorBitmap(sash))
-        
-        border = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_BORDER_COLOUR)
-        self._border_color.SetBitmapLabel(self.CreateColorBitmap(border))
-        
-        gripper = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_GRIPPER_COLOUR)
-        self._gripper_color.SetBitmapLabel(self.CreateColorBitmap(gripper))
-    
-    
-    def OnPaneBorderSize(self, event):
-    
-        self._frame.GetDockArt().SetMetric(wx.aui.AUI_ART_PANE_BORDER_SIZE,
-                                           event.GetInt())
-        self._frame.DoUpdate()
-
-
-    def OnSashSize(self, event):
-
-        self._frame.GetDockArt().SetMetric(wx.aui.AUI_ART_SASH_SIZE,
-                                           event.GetInt())
-        self._frame.DoUpdate()
-    
-
-    def OnCaptionSize(self, event):
-    
-        self._frame.GetDockArt().SetMetric(wx.aui.AUI_ART_CAPTION_SIZE,
-                                           event.GetInt())
-        self._frame.DoUpdate()
-    
-
-    def OnSetColor(self, event):
-    
-        dlg = wx.ColourDialog(self._frame)
-        
-        dlg.SetTitle("Color Picker")
-        
-        if dlg.ShowModal() != wx.ID_OK:
-            return
-        
-        var = 0
-        if event.GetId() == ID_BackgroundColor:
-            var = wx.aui.AUI_ART_BACKGROUND_COLOUR
-        elif event.GetId() == ID_SashColor:
-            var = wx.aui.AUI_ART_SASH_COLOUR
-        elif event.GetId() == ID_InactiveCaptionColor:
-            var = wx.aui.AUI_ART_INACTIVE_CAPTION_COLOUR
-        elif event.GetId() == ID_InactiveCaptionGradientColor:
-            var = wx.aui.AUI_ART_INACTIVE_CAPTION_GRADIENT_COLOUR
-        elif event.GetId() == ID_InactiveCaptionTextColor:
-            var = wx.aui.AUI_ART_INACTIVE_CAPTION_TEXT_COLOUR
-        elif event.GetId() == ID_ActiveCaptionColor:
-            var = wx.aui.AUI_ART_ACTIVE_CAPTION_COLOUR
-        elif event.GetId() == ID_ActiveCaptionGradientColor:
-            var = wx.aui.AUI_ART_ACTIVE_CAPTION_GRADIENT_COLOUR
-        elif event.GetId() == ID_ActiveCaptionTextColor:
-            var = wx.aui.AUI_ART_ACTIVE_CAPTION_TEXT_COLOUR
-        elif event.GetId() == ID_BorderColor:
-            var = wx.aui.AUI_ART_BORDER_COLOUR
-        elif event.GetId() == ID_GripperColor:
-            var = wx.aui.AUI_ART_GRIPPER_COLOUR
-        else:
-            return        
-        
-        self._frame.GetDockArt().SetColor(var, dlg.GetColourData().GetColour())
-        self._frame.DoUpdate()
-        self.UpdateColors()
-
-
-
-#----------------------------------------------------------------------
-
-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 wx.aui Demo Frame", (50,50))
-        self.Bind(wx.EVT_BUTTON, self.OnButton, b)
-
-    def OnButton(self, evt):
-        frame = PyAUIFrame(self, wx.ID_ANY, "wx.aui wxPython Demo", size=(750, 590))
-        frame.Show()
-
-#----------------------------------------------------------------------
-
-def runTest(frame, nb, log):
-    win = TestPanel(nb, log)
-    return win
-
-#----------------------------------------------------------------------
-
-
-
-overview = """\
-<html><body>
-<h3>wx.aui, the Advanced User Interface module</h3>
-
-<br/><b>Overview</b><br/>
-
-<p>wx.aui is an Advanced User Interface library for the wxWidgets toolkit 
-that allows developers to create high-quality, cross-platform user 
-interfaces quickly and easily.</p>
-
-<p><b>Features</b></p>
-
-<p>With wx.aui developers can create application frameworks with:</p>
-
-<ul>
-<li>Native, dockable floating frames</li>
-<li>Perspective saving and loading</li>
-<li>Native toolbars incorporating real-time, &quot;spring-loaded&quot; dragging</li>
-<li>Customizable floating/docking behavior</li>
-<li>Completely customizable look-and-feel</li>
-<li>Optional transparent window effects (while dragging or docking)</li>
-</ul>
-
-</body></html>
-"""
-
-
-
-
-if __name__ == '__main__':
-    import sys,os
-    import run
-    run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
-
diff --git a/wxPython/demo/AUI_DockingWindowMgr.py b/wxPython/demo/AUI_DockingWindowMgr.py
new file mode 100644 (file)
index 0000000..7fd8ab6
--- /dev/null
@@ -0,0 +1,1114 @@
+import wx
+import wx.grid
+import wx.html
+import wx.aui
+
+import cStringIO
+
+ID_CreateTree = wx.ID_HIGHEST+1
+ID_CreateGrid = ID_CreateTree+2
+ID_CreateText = ID_CreateTree+3
+ID_CreateHTML = ID_CreateTree+4
+ID_CreateSizeReport = ID_CreateTree+5
+ID_GridContent = ID_CreateTree+6
+ID_TextContent = ID_CreateTree+7
+ID_TreeContent = ID_CreateTree+8
+ID_HTMLContent = ID_CreateTree+9
+ID_SizeReportContent = ID_CreateTree+10
+ID_CreatePerspective = ID_CreateTree+11
+ID_CopyPerspective = ID_CreateTree+12
+ID_AllowFloating = ID_CreateTree+13
+ID_AllowActivePane = ID_CreateTree+14
+ID_TransparentHint = ID_CreateTree+15
+ID_TransparentHintFade = ID_CreateTree+16
+ID_TransparentDrag = ID_CreateTree+17
+ID_NoGradient = ID_CreateTree+18
+ID_VerticalGradient = ID_CreateTree+19
+ID_HorizontalGradient = ID_CreateTree+20
+ID_Settings = ID_CreateTree+21
+ID_About = ID_CreateTree+22
+ID_FirstPerspective = ID_CreatePerspective+1000
+
+#----------------------------------------------------------------------
+def GetMondrianData():
+    return \
+'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x00 \x00\x00\x00 \x08\x06\x00\
+\x00\x00szz\xf4\x00\x00\x00\x04sBIT\x08\x08\x08\x08|\x08d\x88\x00\x00\x00qID\
+ATX\x85\xed\xd6;\n\x800\x10E\xd1{\xc5\x8d\xb9r\x97\x16\x0b\xad$\x8a\x82:\x16\
+o\xda\x84pB2\x1f\x81Fa\x8c\x9c\x08\x04Z{\xcf\xa72\xbcv\xfa\xc5\x08 \x80r\x80\
+\xfc\xa2\x0e\x1c\xe4\xba\xfaX\x1d\xd0\xde]S\x07\x02\xd8>\xe1wa-`\x9fQ\xe9\
+\x86\x01\x04\x10\x00\\(Dk\x1b-\x04\xdc\x1d\x07\x14\x98;\x0bS\x7f\x7f\xf9\x13\
+\x04\x10@\xf9X\xbe\x00\xc9 \x14K\xc1<={\x00\x00\x00\x00IEND\xaeB`\x82' 
+
+
+def GetMondrianBitmap():
+    return wx.BitmapFromImage(GetMondrianImage())
+
+
+def GetMondrianImage():
+    stream = cStringIO.StringIO(GetMondrianData())
+    return wx.ImageFromStream(stream)
+
+
+def GetMondrianIcon():
+    icon = wx.EmptyIcon()
+    icon.CopyFromBitmap(GetMondrianBitmap())
+    return icon
+
+
+class PyAUIFrame(wx.Frame):
+    
+    def __init__(self, parent, id=-1, title="", pos=wx.DefaultPosition,
+                 size=wx.DefaultSize, style=wx.DEFAULT_FRAME_STYLE |
+                                            wx.SUNKEN_BORDER |
+                                            wx.CLIP_CHILDREN):
+
+        wx.Frame.__init__(self, parent, id, title, pos, size, style)
+        
+        # tell FrameManager to manage this frame        
+        self._mgr = wx.aui.FrameManager()
+        self._mgr.SetManagedWindow(self)
+        
+        self._perspectives = []
+        self.n = 0
+        self.x = 0
+        
+        self.SetIcon(GetMondrianIcon())
+
+        # create menu
+        mb = wx.MenuBar()
+
+        file_menu = wx.Menu()
+        file_menu.Append(wx.ID_EXIT, "Exit")
+
+        view_menu = wx.Menu()
+        view_menu.Append(ID_CreateText, "Create Text Control")
+        view_menu.Append(ID_CreateHTML, "Create HTML Control")
+        view_menu.Append(ID_CreateTree, "Create Tree")
+        view_menu.Append(ID_CreateGrid, "Create Grid")
+        view_menu.Append(ID_CreateSizeReport, "Create Size Reporter")
+        view_menu.AppendSeparator()
+        view_menu.Append(ID_GridContent, "Use a Grid for the Content Pane")
+        view_menu.Append(ID_TextContent, "Use a Text Control for the Content Pane")
+        view_menu.Append(ID_HTMLContent, "Use an HTML Control for the Content Pane")
+        view_menu.Append(ID_TreeContent, "Use a Tree Control for the Content Pane")
+        view_menu.Append(ID_SizeReportContent, "Use a Size Reporter for the Content Pane")    
+           
+        options_menu = wx.Menu()
+        options_menu.AppendCheckItem(ID_AllowFloating, "Allow Floating")
+        options_menu.AppendCheckItem(ID_TransparentHint, "Transparent Hint")
+        options_menu.AppendCheckItem(ID_TransparentHintFade, "Transparent Hint Fade-in")
+        options_menu.AppendCheckItem(ID_TransparentDrag, "Transparent Drag")
+        options_menu.AppendCheckItem(ID_AllowActivePane, "Allow Active Pane")
+        options_menu.AppendSeparator()
+        options_menu.AppendRadioItem(ID_NoGradient, "No Caption Gradient")
+        options_menu.AppendRadioItem(ID_VerticalGradient, "Vertical Caption Gradient")
+        options_menu.AppendRadioItem(ID_HorizontalGradient, "Horizontal Caption Gradient")
+        options_menu.AppendSeparator()
+        options_menu.Append(ID_Settings, "Settings Pane")
+        
+        self._perspectives_menu = wx.Menu()
+        self._perspectives_menu.Append(ID_CreatePerspective, "Create Perspective")
+        self._perspectives_menu.Append(ID_CopyPerspective, "Copy Perspective Data To Clipboard")
+        self._perspectives_menu.AppendSeparator()
+        self._perspectives_menu.Append(ID_FirstPerspective+0, "Default Startup")
+        self._perspectives_menu.Append(ID_FirstPerspective+1, "All Panes")
+        self._perspectives_menu.Append(ID_FirstPerspective+2, "Vertical Toolbar")
+
+        help_menu = wx.Menu()
+        help_menu.Append(ID_About, "About...")
+        
+        mb.Append(file_menu, "File")
+        mb.Append(view_menu, "View")
+        mb.Append(self._perspectives_menu, "Perspectives")
+        mb.Append(options_menu, "Options")
+        mb.Append(help_menu, "Help")
+        
+        self.SetMenuBar(mb)
+
+        self.statusbar = self.CreateStatusBar(2, wx.ST_SIZEGRIP)
+        self.statusbar.SetStatusWidths([-2, -3])
+        self.statusbar.SetStatusText("Ready", 0)
+        self.statusbar.SetStatusText("Welcome To wxPython!", 1)
+
+        # min size for the frame itself isn't completely done.
+        # see the end up FrameManager::Update() for the test
+        # code. For now, just hard code a frame minimum size
+        self.SetMinSize(wx.Size(400, 300))
+
+        # create some toolbars
+        tb1 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
+                         wx.TB_FLAT | wx.TB_NODIVIDER)
+        tb1.SetToolBitmapSize(wx.Size(48,48))
+        tb1.AddLabelTool(101, "Test", wx.ArtProvider_GetBitmap(wx.ART_ERROR))
+        tb1.AddSeparator()
+        tb1.AddLabelTool(102, "Test", wx.ArtProvider_GetBitmap(wx.ART_QUESTION))
+        tb1.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_INFORMATION))
+        tb1.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_WARNING))
+        tb1.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_MISSING_IMAGE))
+        tb1.Realize()
+
+        tb2 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
+                         wx.TB_FLAT | wx.TB_NODIVIDER)
+        tb2.SetToolBitmapSize(wx.Size(16,16))
+        tb2_bmp1 = wx.ArtProvider_GetBitmap(wx.ART_QUESTION, wx.ART_OTHER, wx.Size(16, 16))
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddSeparator()
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddSeparator()
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.AddLabelTool(101, "Test", tb2_bmp1)
+        tb2.Realize()
+       
+        tb3 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
+                         wx.TB_FLAT | wx.TB_NODIVIDER)
+        tb3.SetToolBitmapSize(wx.Size(16,16))
+        tb3_bmp1 = wx.ArtProvider_GetBitmap(wx.ART_FOLDER, wx.ART_OTHER, wx.Size(16, 16))
+        tb3.AddLabelTool(101, "Test", tb3_bmp1)
+        tb3.AddLabelTool(101, "Test", tb3_bmp1)
+        tb3.AddLabelTool(101, "Test", tb3_bmp1)
+        tb3.AddLabelTool(101, "Test", tb3_bmp1)
+        tb3.AddSeparator()
+        tb3.AddLabelTool(101, "Test", tb3_bmp1)
+        tb3.AddLabelTool(101, "Test", tb3_bmp1)
+        tb3.Realize()
+
+        tb4 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
+                         wx.TB_FLAT | wx.TB_NODIVIDER | wx.TB_HORZ_TEXT)
+        tb4.SetToolBitmapSize(wx.Size(16,16))
+        tb4_bmp1 = wx.ArtProvider_GetBitmap(wx.ART_NORMAL_FILE, wx.ART_OTHER, wx.Size(16, 16))
+        tb4.AddLabelTool(101, "Item 1", tb4_bmp1)
+        tb4.AddLabelTool(101, "Item 2", tb4_bmp1)
+        tb4.AddLabelTool(101, "Item 3", tb4_bmp1)
+        tb4.AddLabelTool(101, "Item 4", tb4_bmp1)
+        tb4.AddSeparator()
+        tb4.AddLabelTool(101, "Item 5", tb4_bmp1)
+        tb4.AddLabelTool(101, "Item 6", tb4_bmp1)
+        tb4.AddLabelTool(101, "Item 7", tb4_bmp1)
+        tb4.AddLabelTool(101, "Item 8", tb4_bmp1)
+        tb4.Realize()
+
+        tb5 = wx.ToolBar(self, -1, wx.DefaultPosition, wx.DefaultSize,
+                         wx.TB_FLAT | wx.TB_NODIVIDER | wx.TB_VERTICAL)
+        tb5.SetToolBitmapSize(wx.Size(48, 48))
+        tb5.AddLabelTool(101, "Test", wx.ArtProvider_GetBitmap(wx.ART_ERROR)) 
+        tb5.AddSeparator()
+        tb5.AddLabelTool(102, "Test", wx.ArtProvider_GetBitmap(wx.ART_QUESTION))
+        tb5.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_INFORMATION))
+        tb5.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_WARNING))
+        tb5.AddLabelTool(103, "Test", wx.ArtProvider_GetBitmap(wx.ART_MISSING_IMAGE))
+        tb5.Realize()
+
+        # add a bunch of panes
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test1").Caption("Pane Caption").Top())
+
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test2").Caption("Client Size Reporter").
+                          Bottom().Position(1))
+
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test3").Caption("Client Size Reporter").
+                          Bottom())
+     
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test4").Caption("Pane Caption").
+                          Left())
+                      
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test5").Caption("Pane Caption").
+                          Right())
+                      
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test6").Caption("Client Size Reporter").
+                          Right().Row(1))
+
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test7").Caption("Client Size Reporter").
+                          Left().Layer(1))
+                      
+        self._mgr.AddPane(self.CreateTreeCtrl(), wx.aui.PaneInfo().
+                          Name("test8").Caption("Tree Pane").
+                          Left().Layer(1).Position(1))
+                      
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test9").Caption("Min Size 200x100").
+                          BestSize(wx.Size(200,100)).MinSize(wx.Size(200,100)).
+                          Bottom().Layer(1))
+
+        self._mgr.AddPane(self.CreateTextCtrl(), wx.aui.PaneInfo().
+                          Name("test10").Caption("Text Pane").
+                          Bottom().Layer(1).Position(1))
+                                      
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("test11").Caption("Fixed Pane").
+                          Bottom().Layer(1).Position(2).Fixed())
+
+        self._mgr.AddPane(SettingsPanel(self, self), wx.aui.PaneInfo().
+                          Name("settings").Caption("Dock Manager Settings").
+                          Dockable(False).Float().Hide())
+
+        # create some center panes
+
+        self._mgr.AddPane(self.CreateGrid(), wx.aui.PaneInfo().Name("grid_content").
+                          CenterPane().Hide())
+
+        self._mgr.AddPane(self.CreateTreeCtrl(), wx.aui.PaneInfo().Name("tree_content").
+                          CenterPane().Hide())
+                      
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().Name("sizereport_content").
+                          CenterPane().Hide())
+
+        self._mgr.AddPane(self.CreateTextCtrl(), wx.aui.PaneInfo().Name("text_content").
+                          CenterPane().Hide())
+
+        self._mgr.AddPane(self.CreateHTMLCtrl(), wx.aui.PaneInfo().Name("html_content").
+                          CenterPane())
+                                
+        # add the toolbars to the manager
+                        
+        self._mgr.AddPane(tb1, wx.aui.PaneInfo().
+                          Name("tb1").Caption("Big Toolbar").
+                          ToolbarPane().Top().
+                          LeftDockable(False).RightDockable(False))
+
+        self._mgr.AddPane(tb2, wx.aui.PaneInfo().
+                          Name("tb2").Caption("Toolbar 2").
+                          ToolbarPane().Top().Row(1).
+                          LeftDockable(False).RightDockable(False))
+                      
+        self._mgr.AddPane(tb3, wx.aui.PaneInfo().
+                          Name("tb3").Caption("Toolbar 3").
+                          ToolbarPane().Top().Row(1).Position(1).
+                          LeftDockable(False).RightDockable(False))
+                      
+        self._mgr.AddPane(tb4, wx.aui.PaneInfo().
+                          Name("tb4").Caption("Sample Bookmark Toolbar").
+                          ToolbarPane().Top().Row(2).
+                          LeftDockable(False).RightDockable(False))
+
+        self._mgr.AddPane(tb5, wx.aui.PaneInfo().
+                          Name("tbvert").Caption("Sample Vertical Toolbar").
+                          ToolbarPane().Left().GripperTop().
+                          TopDockable(False).BottomDockable(False))
+                      
+        self._mgr.AddPane(wx.Button(self, -1, "Test Button"),
+                          wx.aui.PaneInfo().Name("tb5").
+                          ToolbarPane().Top().Row(2).Position(1).
+                          LeftDockable(False).RightDockable(False))
+
+        # make some default perspectives
+
+        self._mgr.GetPane("tbvert").Hide()
+        
+        perspective_all = self._mgr.SavePerspective()
+        
+        all_panes = self._mgr.GetAllPanes()
+        
+        for ii in xrange(len(all_panes)):
+            if not all_panes[ii].IsToolbar():
+                all_panes[ii].Hide()
+                
+        self._mgr.GetPane("tb1").Hide()
+        self._mgr.GetPane("tb5").Hide()
+        self._mgr.GetPane("test8").Show().Left().Layer(0).Row(0).Position(0)
+        self._mgr.GetPane("test10").Show().Bottom().Layer(0).Row(0).Position(0)
+        self._mgr.GetPane("html_content").Show()
+
+        perspective_default = self._mgr.SavePerspective()
+
+        for ii in xrange(len(all_panes)):
+            if not all_panes[ii].IsToolbar():
+                all_panes[ii].Hide()
+
+        self._mgr.GetPane("tb1").Hide()
+        self._mgr.GetPane("tb5").Hide()
+        self._mgr.GetPane("tbvert").Show()
+        self._mgr.GetPane("grid_content").Show()
+        self._mgr.GetPane("test8").Show().Left().Layer(0).Row(0).Position(0)
+        self._mgr.GetPane("test10").Show().Bottom().Layer(0).Row(0).Position(0)
+        self._mgr.GetPane("html_content").Show()
+
+        perspective_vert = self._mgr.SavePerspective()
+        
+        self._perspectives.append(perspective_default)
+        self._perspectives.append(perspective_all)
+        self._perspectives.append(perspective_vert)
+
+        self._mgr.GetPane("tbvert").Hide()
+        self._mgr.GetPane("grid_content").Hide()
+
+        # "commit" all changes made to FrameManager   
+        self._mgr.Update()
+
+        self.Bind(wx.EVT_ERASE_BACKGROUND, self.OnEraseBackground)
+        self.Bind(wx.EVT_SIZE, self.OnSize)
+        self.Bind(wx.EVT_CLOSE, self.OnClose)
+
+        # Show How To Use The Closing Panes Event
+        self.Bind(wx.aui.EVT_AUI_PANEBUTTON, self.OnPaneButton)
+        
+        self.Bind(wx.EVT_MENU, self.OnCreateTree, id=ID_CreateTree)
+        self.Bind(wx.EVT_MENU, self.OnCreateGrid, id=ID_CreateGrid)
+        self.Bind(wx.EVT_MENU, self.OnCreateText, id=ID_CreateText)
+        self.Bind(wx.EVT_MENU, self.OnCreateHTML, id=ID_CreateHTML)
+        self.Bind(wx.EVT_MENU, self.OnCreateSizeReport, id=ID_CreateSizeReport)
+        self.Bind(wx.EVT_MENU, self.OnCreatePerspective, id=ID_CreatePerspective)
+        self.Bind(wx.EVT_MENU, self.OnCopyPerspective, id=ID_CopyPerspective)
+        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_AllowFloating)
+        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_TransparentHint)
+        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_TransparentHintFade)
+        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_TransparentDrag)
+        self.Bind(wx.EVT_MENU, self.OnManagerFlag, id=ID_AllowActivePane)
+        self.Bind(wx.EVT_MENU, self.OnGradient, id=ID_NoGradient)
+        self.Bind(wx.EVT_MENU, self.OnGradient, id=ID_VerticalGradient)
+        self.Bind(wx.EVT_MENU, self.OnGradient, id=ID_HorizontalGradient)
+        self.Bind(wx.EVT_MENU, self.OnSettings, id=ID_Settings)
+        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_GridContent)
+        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_TreeContent)
+        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_TextContent)
+        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_SizeReportContent)
+        self.Bind(wx.EVT_MENU, self.OnChangeContentPane, id=ID_HTMLContent)
+        self.Bind(wx.EVT_MENU, self.OnClose, id=wx.ID_EXIT)
+        self.Bind(wx.EVT_MENU, self.OnAbout, id=ID_About)
+
+        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_AllowFloating)
+        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_TransparentHint)
+        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_TransparentHintFade)
+        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_TransparentDrag)
+        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_NoGradient)
+        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_VerticalGradient)
+        self.Bind(wx.EVT_UPDATE_UI, self.OnUpdateUI, id=ID_HorizontalGradient)
+    
+        self.Bind(wx.EVT_MENU_RANGE, self.OnRestorePerspective, id=ID_FirstPerspective,
+                  id2=ID_FirstPerspective+1000)
+
+
+    def OnPaneButton(self, event):
+
+        caption = event.GetPane().caption
+
+        if caption in ["Tree Pane", "Dock Manager Settings", "Fixed Pane"]:
+            msg = "Are You Sure You Want To Close This Pane?"
+            dlg = wx.MessageDialog(self, msg, "PyAUI Question",
+                                   wx.YES_NO | wx.NO_DEFAULT | wx.CANCEL | wx.ICON_QUESTION)
+
+            if dlg.ShowModal() in [wx.ID_NO, wx.ID_CANCEL]:
+                dlg.Destroy()
+                return
+
+            dlg.Destroy()
+            
+        event.Skip()
+        
+
+    def OnClose(self, event):
+        
+        self._mgr.UnInit()
+        self.Destroy()
+
+        event.Skip()        
+
+
+    def OnAbout(self, event):
+
+        msg = "wx.aui Demo\n" + \
+              "An advanced window management library for wxWidgets\n" + \
+              "(c) Copyright 2005-2006, Kirix Corporation"
+        dlg = wx.MessageDialog(self, msg, "About wx.aui Demo",
+                               wx.OK | wx.ICON_INFORMATION)
+        dlg.ShowModal()
+        dlg.Destroy()        
+
+
+    def GetDockArt(self):
+
+        return self._mgr.GetArtProvider()
+
+
+    def DoUpdate(self):
+
+        self._mgr.Update()
+
+
+    def OnEraseBackground(self, event):
+
+        event.Skip()
+
+
+    def OnSize(self, event):
+
+        event.Skip()
+
+
+    def OnSettings(self, event):
+
+        # show the settings pane, and float it
+        floating_pane = self._mgr.GetPane("settings").Float().Show()
+
+        if floating_pane.floating_pos == wx.DefaultPosition:
+            floating_pane.FloatingPosition(self.GetStartPosition())
+
+        self._mgr.Update()
+
+
+    def OnGradient(self, event):
+
+        gradient = 0
+
+        if event.GetId() == ID_NoGradient:
+            gradient = wx.aui.AUI_GRADIENT_NONE
+        elif event.GetId() == ID_VerticalGradient:
+            gradient = wx.aui.AUI_GRADIENT_VERTICAL
+        elif event.GetId() == ID_HorizontalGradient:
+            gradient = wx.aui.AUI_GRADIENT_HORIZONTAL
+
+        self._mgr.GetArtProvider().SetMetric(wx.aui.AUI_ART_GRADIENT_TYPE, gradient)
+        self._mgr.Update()
+
+
+    def OnManagerFlag(self, event):
+
+        flag = 0
+        
+##         if wx.Platform != "__WXMSW__" and wx.Platform != '__WXMAC__':
+##             if event.GetId() == ID_TransparentDrag or \
+##                event.GetId() == ID_TransparentHint or \
+##                event.GetId() == ID_TransparentHintFade:
+            
+##                 wx.MessageBox("This option is presently only available on wxMSW and wxMac")
+##                 return
+
+        if event.GetId() == ID_AllowFloating:
+            flag = wx.aui.AUI_MGR_ALLOW_FLOATING
+
+        elif event.GetId() == ID_TransparentDrag:
+            flag = wx.aui.AUI_MGR_TRANSPARENT_DRAG
+
+        elif event.GetId() == ID_TransparentHint:
+            flag = wx.aui.AUI_MGR_TRANSPARENT_HINT
+
+        elif event.GetId() == ID_TransparentHintFade:
+            flag = wx.aui.AUI_MGR_TRANSPARENT_HINT_FADE
+
+        elif event.GetId() == ID_AllowActivePane:
+            flag = wx.aui.AUI_MGR_ALLOW_ACTIVE_PANE
+            
+        self._mgr.SetFlags(self._mgr.GetFlags() ^ flag)
+
+
+    def OnUpdateUI(self, event):
+
+        flags = self._mgr.GetFlags()
+
+        if event.GetId() == ID_NoGradient:
+            event.Check(((self._mgr.GetArtProvider().GetMetric(wx.aui.AUI_ART_GRADIENT_TYPE) == wx.aui.AUI_GRADIENT_NONE) and \
+                        [True] or [False])[0])
+
+        elif event.GetId() == ID_VerticalGradient:
+            event.Check(((self._mgr.GetArtProvider().GetMetric(wx.aui.AUI_ART_GRADIENT_TYPE) == wx.aui.AUI_GRADIENT_VERTICAL) and \
+                        [True] or [False])[0])
+
+        elif event.GetId() == ID_HorizontalGradient:
+            event.Check(((self._mgr.GetArtProvider().GetMetric(wx.aui.AUI_ART_GRADIENT_TYPE) == wx.aui.AUI_GRADIENT_HORIZONTAL) and \
+                        [True] or [False])[0])
+
+        elif event.GetId() == ID_AllowFloating:
+            event.Check(((flags & wx.aui.AUI_MGR_ALLOW_FLOATING) and [True] or [False])[0])
+
+        elif event.GetId() == ID_TransparentDrag:
+            event.Check(((flags & wx.aui.AUI_MGR_TRANSPARENT_DRAG) and [True] or [False])[0])
+
+        elif event.GetId() == ID_TransparentHint:
+            event.Check(((flags & wx.aui.AUI_MGR_TRANSPARENT_HINT) and [True] or [False])[0])
+
+        elif event.GetId() == ID_TransparentHintFade:
+            event.Check(((flags & wx.aui.AUI_MGR_TRANSPARENT_HINT_FADE) and [True] or [False])[0])
+                
+
+    def OnCreatePerspective(self, event):
+
+        dlg = wx.TextEntryDialog(self, "Enter a name for the new perspective:", "AUI Test")
+        
+        dlg.SetValue(("Perspective %d")%(len(self._perspectives)+1))
+        if dlg.ShowModal() != wx.ID_OK:
+            return
+        
+        if len(self._perspectives) == 0:
+            self._perspectives_menu.AppendSeparator()
+        
+        self._perspectives_menu.Append(ID_FirstPerspective + len(self._perspectives), dlg.GetValue())
+        self._perspectives.append(self._mgr.SavePerspective())
+
+
+    def OnCopyPerspective(self, event):
+
+        s = self._mgr.SavePerspective()
+        
+        if wx.TheClipboard.Open():
+        
+            wx.TheClipboard.SetData(wx.TextDataObject(s))
+            wx.TheClipboard.Close()
+        
+    def OnRestorePerspective(self, event):
+
+        self._mgr.LoadPerspective(self._perspectives[event.GetId() - ID_FirstPerspective])
+
+
+    def GetStartPosition(self):
+
+        self.x = self.x + 20
+        x = self.x
+        pt = self.ClientToScreen(wx.Point(0, 0))
+        
+        return wx.Point(pt.x + x, pt.y + x)
+
+
+    def OnCreateTree(self, event):
+
+        self._mgr.AddPane(self.CreateTreeCtrl(), wx.aui.PaneInfo().
+                          Name("Test").Caption("Tree Control").
+                          Float().FloatingPosition(self.GetStartPosition()).
+                          FloatingSize(wx.Size(150, 300)))
+        self._mgr.Update()
+
+
+    def OnCreateGrid(self, event):
+
+        self._mgr.AddPane(self.CreateGrid(), wx.aui.PaneInfo().
+                          Name("Test").Caption("Grid").
+                          Float().FloatingPosition(self.GetStartPosition()).
+                          FloatingSize(wx.Size(300, 200)))
+        self._mgr.Update()
+
+
+    def OnCreateHTML(self, event):
+
+        self._mgr.AddPane(self.CreateHTMLCtrl(), wx.aui.PaneInfo().
+                          Name("Test").Caption("HTML Content").
+                          Float().FloatingPosition(self.GetStartPosition()).
+                          FloatingSize(wx.Size(300, 200)))
+        self._mgr.Update()
+
+
+    def OnCreateText(self, event):
+
+        self._mgr.AddPane(self.CreateTextCtrl(), wx.aui.PaneInfo().
+                          Name("Test").Caption("Text Control").
+                          Float().FloatingPosition(self.GetStartPosition()))
+        self._mgr.Update()
+
+
+    def OnCreateSizeReport(self, event):
+
+        self._mgr.AddPane(self.CreateSizeReportCtrl(), wx.aui.PaneInfo().
+                          Name("Test").Caption("Client Size Reporter").
+                          Float().FloatingPosition(self.GetStartPosition()))
+        self._mgr.Update()
+
+
+    def OnChangeContentPane(self, event):
+
+        self._mgr.GetPane("grid_content").Show(event.GetId() == ID_GridContent)
+        self._mgr.GetPane("text_content").Show(event.GetId() == ID_TextContent)
+        self._mgr.GetPane("tree_content").Show(event.GetId() == ID_TreeContent)
+        self._mgr.GetPane("sizereport_content").Show(event.GetId() == ID_SizeReportContent)
+        self._mgr.GetPane("html_content").Show(event.GetId() == ID_HTMLContent)
+        self._mgr.Update()
+
+
+    def CreateTextCtrl(self):
+
+        text = ("This is text box %d")%(self.n + 1)
+
+        return wx.TextCtrl(self,-1, text, wx.Point(0, 0), wx.Size(150, 90),
+                           wx.NO_BORDER | wx.TE_MULTILINE)
+
+
+
+    def CreateGrid(self):
+
+        grid = wx.grid.Grid(self, -1, wx.Point(0, 0), wx.Size(150, 250),
+                            wx.NO_BORDER | wx.WANTS_CHARS)
+        
+        grid.CreateGrid(50, 20)
+
+        return grid
+
+
+    def CreateTreeCtrl(self):
+
+        tree = wx.TreeCtrl(self, -1, wx.Point(0, 0), wx.Size(160, 250),
+                           wx.TR_DEFAULT_STYLE | wx.NO_BORDER)
+        
+        root = tree.AddRoot("PyAUI Project")
+        items = []
+
+        imglist = wx.ImageList(16, 16, True, 2)
+        imglist.Add(wx.ArtProvider_GetBitmap(wx.ART_FOLDER, wx.ART_OTHER, wx.Size(16,16)))
+        imglist.Add(wx.ArtProvider_GetBitmap(wx.ART_NORMAL_FILE, wx.ART_OTHER, wx.Size(16,16)))
+        tree.AssignImageList(imglist)
+
+        items.append(tree.AppendItem(root, "Item 1", 0))
+        items.append(tree.AppendItem(root, "Item 2", 0))
+        items.append(tree.AppendItem(root, "Item 3", 0))
+        items.append(tree.AppendItem(root, "Item 4", 0))
+        items.append(tree.AppendItem(root, "Item 5", 0))
+
+        for ii in xrange(len(items)):
+        
+            id = items[ii]
+            tree.AppendItem(id, "Subitem 1", 1)
+            tree.AppendItem(id, "Subitem 2", 1)
+            tree.AppendItem(id, "Subitem 3", 1)
+            tree.AppendItem(id, "Subitem 4", 1)
+            tree.AppendItem(id, "Subitem 5", 1)
+        
+        tree.Expand(root)
+
+        return tree
+
+
+    def CreateSizeReportCtrl(self, width=80, height=80):
+
+        ctrl = SizeReportCtrl(self, -1, wx.DefaultPosition,
+                              wx.Size(width, height), self._mgr)
+        return ctrl
+
+
+    def CreateHTMLCtrl(self):
+        ctrl = wx.html.HtmlWindow(self, -1, wx.DefaultPosition, wx.Size(400, 300))
+        if "gtk2" in wx.PlatformInfo:
+            ctrl.SetStandardFonts()
+        ctrl.SetPage(self.GetIntroText())        
+        return ctrl
+
+
+    def GetIntroText(self):
+        return overview
+
+
+# -- wx.SizeReportCtrl --
+# (a utility control that always reports it's client size)
+
+class SizeReportCtrl(wx.PyControl):
+
+    def __init__(self, parent, id=wx.ID_ANY, pos=wx.DefaultPosition,
+                 size=wx.DefaultSize, mgr=None):
+
+        wx.PyControl.__init__(self, parent, id, pos, size, wx.NO_BORDER)
+            
+        self._mgr = mgr
+
+        self.Bind(wx.EVT_PAINT, self.OnPaint)
+        self.Bind(wx.EVT_SIZE, self.OnSize)
+        self.Bind(wx.EVT_ERASE_BACKGROUND, self.OnEraseBackground)
+
+
+    def OnPaint(self, event):
+
+        dc = wx.PaintDC(self)
+        
+        size = self.GetClientSize()
+        s = ("Size: %d x %d")%(size.x, size.y)
+
+        dc.SetFont(wx.NORMAL_FONT)
+        w, height = dc.GetTextExtent(s)
+        height = height + 3
+        dc.SetBrush(wx.WHITE_BRUSH)
+        dc.SetPen(wx.WHITE_PEN)
+        dc.DrawRectangle(0, 0, size.x, size.y)
+        dc.SetPen(wx.LIGHT_GREY_PEN)
+        dc.DrawLine(0, 0, size.x, size.y)
+        dc.DrawLine(0, size.y, size.x, 0)
+        dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2))
+        
+        if self._mgr:
+        
+            pi = self._mgr.GetPane(self)
+            
+            s = ("Layer: %d")%pi.dock_layer
+            w, h = dc.GetTextExtent(s)
+            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*1))
+           
+            s = ("Dock: %d Row: %d")%(pi.dock_direction, pi.dock_row)
+            w, h = dc.GetTextExtent(s)
+            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*2))
+            
+            s = ("Position: %d")%pi.dock_pos
+            w, h = dc.GetTextExtent(s)
+            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*3))
+            
+            s = ("Proportion: %d")%pi.dock_proportion
+            w, h = dc.GetTextExtent(s)
+            dc.DrawText(s, (size.x-w)/2, ((size.y-(height*5))/2)+(height*4))
+        
+
+    def OnEraseBackground(self, event):
+        # intentionally empty
+        pass        
+    
+
+    def OnSize(self, event):
+    
+        self.Refresh()
+        event.Skip()
+    
+
+ID_PaneBorderSize = wx.ID_HIGHEST + 1
+ID_SashSize = ID_PaneBorderSize + 1
+ID_CaptionSize = ID_PaneBorderSize + 2
+ID_BackgroundColor = ID_PaneBorderSize + 3
+ID_SashColor = ID_PaneBorderSize + 4
+ID_InactiveCaptionColor =  ID_PaneBorderSize + 5
+ID_InactiveCaptionGradientColor = ID_PaneBorderSize + 6
+ID_InactiveCaptionTextColor = ID_PaneBorderSize + 7
+ID_ActiveCaptionColor = ID_PaneBorderSize + 8
+ID_ActiveCaptionGradientColor = ID_PaneBorderSize + 9
+ID_ActiveCaptionTextColor = ID_PaneBorderSize + 10
+ID_BorderColor = ID_PaneBorderSize + 11
+ID_GripperColor = ID_PaneBorderSize + 12
+    
+class SettingsPanel(wx.Panel):
+    
+    def __init__(self, parent, frame):
+
+        wx.Panel.__init__(self, parent, wx.ID_ANY, wx.DefaultPosition,
+                          wx.DefaultSize)
+
+        self._frame = frame
+        
+        vert = wx.BoxSizer(wx.VERTICAL)
+
+        s1 = wx.BoxSizer(wx.HORIZONTAL)
+        self._border_size = wx.SpinCtrl(self, ID_PaneBorderSize, "", wx.DefaultPosition, wx.Size(50,20))
+        s1.Add((1, 1), 1, wx.EXPAND)
+        s1.Add(wx.StaticText(self, -1, "Pane Border Size:"))
+        s1.Add(self._border_size)
+        s1.Add((1, 1), 1, wx.EXPAND)
+        s1.SetItemMinSize(1, (180, 20))
+        #vert.Add(s1, 0, wx.EXPAND | wxLEFT | wxBOTTOM, 5)
+
+        s2 = wx.BoxSizer(wx.HORIZONTAL)
+        self._sash_size = wx.SpinCtrl(self, ID_SashSize, "", wx.DefaultPosition, wx.Size(50,20))
+        s2.Add((1, 1), 1, wx.EXPAND)
+        s2.Add(wx.StaticText(self, -1, "Sash Size:"))
+        s2.Add(self._sash_size)
+        s2.Add((1, 1), 1, wx.EXPAND)
+        s2.SetItemMinSize(1, (180, 20))
+        #vert.Add(s2, 0, wx.EXPAND | wxLEFT | wxBOTTOM, 5)
+
+        s3 = wx.BoxSizer(wx.HORIZONTAL)
+        self._caption_size = wx.SpinCtrl(self, ID_CaptionSize, "", wx.DefaultPosition, wx.Size(50,20))
+        s3.Add((1, 1), 1, wx.EXPAND)
+        s3.Add(wx.StaticText(self, -1, "Caption Size:"))
+        s3.Add(self._caption_size)
+        s3.Add((1, 1), 1, wx.EXPAND)
+        s3.SetItemMinSize(1, (180, 20))
+        #vert.Add(s3, 0, wx.EXPAND | wxLEFT | wxBOTTOM, 5)
+
+        #vert.Add(1, 1, 1, wx.EXPAND)
+
+        b = self.CreateColorBitmap(wx.BLACK)
+
+        s4 = wx.BoxSizer(wx.HORIZONTAL)
+        self._background_color = wx.BitmapButton(self, ID_BackgroundColor, b, wx.DefaultPosition, wx.Size(50,25))
+        s4.Add((1, 1), 1, wx.EXPAND)
+        s4.Add(wx.StaticText(self, -1, "Background Color:"))
+        s4.Add(self._background_color)
+        s4.Add((1, 1), 1, wx.EXPAND)
+        s4.SetItemMinSize(1, (180, 20))
+
+        s5 = wx.BoxSizer(wx.HORIZONTAL)
+        self._sash_color = wx.BitmapButton(self, ID_SashColor, b, wx.DefaultPosition, wx.Size(50,25))
+        s5.Add((1, 1), 1, wx.EXPAND)
+        s5.Add(wx.StaticText(self, -1, "Sash Color:"))
+        s5.Add(self._sash_color)
+        s5.Add((1, 1), 1, wx.EXPAND)
+        s5.SetItemMinSize(1, (180, 20))
+
+        s6 = wx.BoxSizer(wx.HORIZONTAL)
+        self._inactive_caption_color = wx.BitmapButton(self, ID_InactiveCaptionColor, b,
+                                                       wx.DefaultPosition, wx.Size(50,25))
+        s6.Add((1, 1), 1, wx.EXPAND)
+        s6.Add(wx.StaticText(self, -1, "Normal Caption:"))
+        s6.Add(self._inactive_caption_color)
+        s6.Add((1, 1), 1, wx.EXPAND)
+        s6.SetItemMinSize(1, (180, 20))
+
+        s7 = wx.BoxSizer(wx.HORIZONTAL)
+        self._inactive_caption_gradient_color = wx.BitmapButton(self, ID_InactiveCaptionGradientColor,
+                                                                b, wx.DefaultPosition, wx.Size(50,25))
+        s7.Add((1, 1), 1, wx.EXPAND)
+        s7.Add(wx.StaticText(self, -1, "Normal Caption Gradient:"))
+        s7.Add(self._inactive_caption_gradient_color)
+        s7.Add((1, 1), 1, wx.EXPAND)
+        s7.SetItemMinSize(1, (180, 20))
+
+        s8 = wx.BoxSizer(wx.HORIZONTAL)
+        self._inactive_caption_text_color = wx.BitmapButton(self, ID_InactiveCaptionTextColor, b,
+                                                            wx.DefaultPosition, wx.Size(50,25))
+        s8.Add((1, 1), 1, wx.EXPAND)
+        s8.Add(wx.StaticText(self, -1, "Normal Caption Text:"))
+        s8.Add(self._inactive_caption_text_color)
+        s8.Add((1, 1), 1, wx.EXPAND)
+        s8.SetItemMinSize(1, (180, 20))
+
+        s9 = wx.BoxSizer(wx.HORIZONTAL)
+        self._active_caption_color = wx.BitmapButton(self, ID_ActiveCaptionColor, b,
+                                                     wx.DefaultPosition, wx.Size(50,25))
+        s9.Add((1, 1), 1, wx.EXPAND)
+        s9.Add(wx.StaticText(self, -1, "Active Caption:"))
+        s9.Add(self._active_caption_color)
+        s9.Add((1, 1), 1, wx.EXPAND)
+        s9.SetItemMinSize(1, (180, 20))
+
+        s10 = wx.BoxSizer(wx.HORIZONTAL)
+        self._active_caption_gradient_color = wx.BitmapButton(self, ID_ActiveCaptionGradientColor,
+                                                              b, wx.DefaultPosition, wx.Size(50,25))
+        s10.Add((1, 1), 1, wx.EXPAND)
+        s10.Add(wx.StaticText(self, -1, "Active Caption Gradient:"))
+        s10.Add(self._active_caption_gradient_color)
+        s10.Add((1, 1), 1, wx.EXPAND)
+        s10.SetItemMinSize(1, (180, 20))
+
+        s11 = wx.BoxSizer(wx.HORIZONTAL)
+        self._active_caption_text_color = wx.BitmapButton(self, ID_ActiveCaptionTextColor,
+                                                          b, wx.DefaultPosition, wx.Size(50,25))
+        s11.Add((1, 1), 1, wx.EXPAND)
+        s11.Add(wx.StaticText(self, -1, "Active Caption Text:"))
+        s11.Add(self._active_caption_text_color)
+        s11.Add((1, 1), 1, wx.EXPAND)
+        s11.SetItemMinSize(1, (180, 20))
+
+        s12 = wx.BoxSizer(wx.HORIZONTAL)
+        self._border_color = wx.BitmapButton(self, ID_BorderColor, b, wx.DefaultPosition,
+                                             wx.Size(50,25))
+        s12.Add((1, 1), 1, wx.EXPAND)
+        s12.Add(wx.StaticText(self, -1, "Border Color:"))
+        s12.Add(self._border_color)
+        s12.Add((1, 1), 1, wx.EXPAND)
+        s12.SetItemMinSize(1, (180, 20))
+
+        s13 = wx.BoxSizer(wx.HORIZONTAL)
+        self._gripper_color = wx.BitmapButton(self, ID_GripperColor, b, wx.DefaultPosition,
+                                              wx.Size(50,25))
+        s13.Add((1, 1), 1, wx.EXPAND)
+        s13.Add(wx.StaticText(self, -1, "Gripper Color:"))
+        s13.Add(self._gripper_color)
+        s13.Add((1, 1), 1, wx.EXPAND)
+        s13.SetItemMinSize(1, (180, 20))
+        
+        grid_sizer = wx.GridSizer(0, 2)
+        grid_sizer.SetHGap(5)
+        grid_sizer.Add(s1)
+        grid_sizer.Add(s4)
+        grid_sizer.Add(s2)
+        grid_sizer.Add(s5)
+        grid_sizer.Add(s3)
+        grid_sizer.Add(s13)
+        grid_sizer.Add((1, 1))
+        grid_sizer.Add(s12)
+        grid_sizer.Add(s6)
+        grid_sizer.Add(s9)
+        grid_sizer.Add(s7)
+        grid_sizer.Add(s10)
+        grid_sizer.Add(s8)
+        grid_sizer.Add(s11)
+         
+        cont_sizer = wx.BoxSizer(wx.VERTICAL)
+        cont_sizer.Add(grid_sizer, 1, wx.EXPAND | wx.ALL, 5)
+        self.SetSizer(cont_sizer)
+        self.GetSizer().SetSizeHints(self)
+
+        self._border_size.SetValue(frame.GetDockArt().GetMetric(wx.aui.AUI_ART_PANE_BORDER_SIZE))
+        self._sash_size.SetValue(frame.GetDockArt().GetMetric(wx.aui.AUI_ART_SASH_SIZE))
+        self._caption_size.SetValue(frame.GetDockArt().GetMetric(wx.aui.AUI_ART_CAPTION_SIZE))
+        
+        self.UpdateColors()
+
+        self.Bind(wx.EVT_SPINCTRL, self.OnPaneBorderSize, id=ID_PaneBorderSize)
+        self.Bind(wx.EVT_SPINCTRL, self.OnSashSize, id=ID_SashSize)
+        self.Bind(wx.EVT_SPINCTRL, self.OnCaptionSize, id=ID_CaptionSize)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_BackgroundColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_SashColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_InactiveCaptionColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_InactiveCaptionGradientColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_InactiveCaptionTextColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_ActiveCaptionColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_ActiveCaptionGradientColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_ActiveCaptionTextColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_BorderColor)
+        self.Bind(wx.EVT_BUTTON, self.OnSetColor, id=ID_GripperColor)
+    
+    
+    def CreateColorBitmap(self, c):
+        image = wx.EmptyImage(25, 14)
+        
+        for x in xrange(25):
+            for y in xrange(14):
+                pixcol = c
+                if x == 0 or x == 24 or y == 0 or y == 13:
+                    pixcol = wx.BLACK
+                    
+                image.SetRGB(x, y, pixcol.Red(), pixcol.Green(), pixcol.Blue())
+            
+        return image.ConvertToBitmap()
+    
+    
+    def UpdateColors(self):
+    
+        bk = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_BACKGROUND_COLOUR)
+        self._background_color.SetBitmapLabel(self.CreateColorBitmap(bk))
+        
+        cap = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_INACTIVE_CAPTION_COLOUR)
+        self._inactive_caption_color.SetBitmapLabel(self.CreateColorBitmap(cap))
+        
+        capgrad = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_INACTIVE_CAPTION_GRADIENT_COLOUR)
+        self._inactive_caption_gradient_color.SetBitmapLabel(self.CreateColorBitmap(capgrad))
+        
+        captxt = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_INACTIVE_CAPTION_TEXT_COLOUR)
+        self._inactive_caption_text_color.SetBitmapLabel(self.CreateColorBitmap(captxt))
+        
+        acap = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_ACTIVE_CAPTION_COLOUR)
+        self._active_caption_color.SetBitmapLabel(self.CreateColorBitmap(acap))
+        
+        acapgrad = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_ACTIVE_CAPTION_GRADIENT_COLOUR)
+        self._active_caption_gradient_color.SetBitmapLabel(self.CreateColorBitmap(acapgrad))
+        
+        acaptxt = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_ACTIVE_CAPTION_TEXT_COLOUR)
+        self._active_caption_text_color.SetBitmapLabel(self.CreateColorBitmap(acaptxt))
+        
+        sash = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_SASH_COLOUR)
+        self._sash_color.SetBitmapLabel(self.CreateColorBitmap(sash))
+        
+        border = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_BORDER_COLOUR)
+        self._border_color.SetBitmapLabel(self.CreateColorBitmap(border))
+        
+        gripper = self._frame.GetDockArt().GetColour(wx.aui.AUI_ART_GRIPPER_COLOUR)
+        self._gripper_color.SetBitmapLabel(self.CreateColorBitmap(gripper))
+    
+    
+    def OnPaneBorderSize(self, event):
+    
+        self._frame.GetDockArt().SetMetric(wx.aui.AUI_ART_PANE_BORDER_SIZE,
+                                           event.GetInt())
+        self._frame.DoUpdate()
+
+
+    def OnSashSize(self, event):
+
+        self._frame.GetDockArt().SetMetric(wx.aui.AUI_ART_SASH_SIZE,
+                                           event.GetInt())
+        self._frame.DoUpdate()
+    
+
+    def OnCaptionSize(self, event):
+    
+        self._frame.GetDockArt().SetMetric(wx.aui.AUI_ART_CAPTION_SIZE,
+                                           event.GetInt())
+        self._frame.DoUpdate()
+    
+
+    def OnSetColor(self, event):
+    
+        dlg = wx.ColourDialog(self._frame)
+        
+        dlg.SetTitle("Color Picker")
+        
+        if dlg.ShowModal() != wx.ID_OK:
+            return
+        
+        var = 0
+        if event.GetId() == ID_BackgroundColor:
+            var = wx.aui.AUI_ART_BACKGROUND_COLOUR
+        elif event.GetId() == ID_SashColor:
+            var = wx.aui.AUI_ART_SASH_COLOUR
+        elif event.GetId() == ID_InactiveCaptionColor:
+            var = wx.aui.AUI_ART_INACTIVE_CAPTION_COLOUR
+        elif event.GetId() == ID_InactiveCaptionGradientColor:
+            var = wx.aui.AUI_ART_INACTIVE_CAPTION_GRADIENT_COLOUR
+        elif event.GetId() == ID_InactiveCaptionTextColor:
+            var = wx.aui.AUI_ART_INACTIVE_CAPTION_TEXT_COLOUR
+        elif event.GetId() == ID_ActiveCaptionColor:
+            var = wx.aui.AUI_ART_ACTIVE_CAPTION_COLOUR
+        elif event.GetId() == ID_ActiveCaptionGradientColor:
+            var = wx.aui.AUI_ART_ACTIVE_CAPTION_GRADIENT_COLOUR
+        elif event.GetId() == ID_ActiveCaptionTextColor:
+            var = wx.aui.AUI_ART_ACTIVE_CAPTION_TEXT_COLOUR
+        elif event.GetId() == ID_BorderColor:
+            var = wx.aui.AUI_ART_BORDER_COLOUR
+        elif event.GetId() == ID_GripperColor:
+            var = wx.aui.AUI_ART_GRIPPER_COLOUR
+        else:
+            return        
+        
+        self._frame.GetDockArt().SetColor(var, dlg.GetColourData().GetColour())
+        self._frame.DoUpdate()
+        self.UpdateColors()
+
+
+
+#----------------------------------------------------------------------
+
+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 wx.aui Demo Frame", (50,50))
+        self.Bind(wx.EVT_BUTTON, self.OnButton, b)
+
+    def OnButton(self, evt):
+        frame = PyAUIFrame(self, wx.ID_ANY, "wx.aui wxPython Demo", size=(750, 590))
+        frame.Show()
+
+#----------------------------------------------------------------------
+
+def runTest(frame, nb, log):
+    win = TestPanel(nb, log)
+    return win
+
+#----------------------------------------------------------------------
+
+
+
+overview = """\
+<html><body>
+<h3>wx.aui, the Advanced User Interface module</h3>
+
+<br/><b>Overview</b><br/>
+
+<p>wx.aui is an Advanced User Interface library for the wxWidgets toolkit 
+that allows developers to create high-quality, cross-platform user 
+interfaces quickly and easily.</p>
+
+<p><b>Features</b></p>
+
+<p>With wx.aui developers can create application frameworks with:</p>
+
+<ul>
+<li>Native, dockable floating frames</li>
+<li>Perspective saving and loading</li>
+<li>Native toolbars incorporating real-time, &quot;spring-loaded&quot; dragging</li>
+<li>Customizable floating/docking behavior</li>
+<li>Completely customizable look-and-feel</li>
+<li>Optional transparent window effects (while dragging or docking)</li>
+</ul>
+
+</body></html>
+"""
+
+
+
+
+if __name__ == '__main__':
+    import sys,os
+    import run
+    run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
+
diff --git a/wxPython/demo/AUI_Notebook.py b/wxPython/demo/AUI_Notebook.py
new file mode 100644 (file)
index 0000000..458e143
--- /dev/null
@@ -0,0 +1,60 @@
+
+import wx
+import wx.aui
+
+
+text = """\
+Hello!
+
+Welcome to this little demo of draggable tabs using the wx.aui module.
+
+To try it out, drag a tab from the top of the window all the way to
+the bottom.  After releasing the mouse, the tab will dock at the
+hinted position.  Then try it again with the remaining tabs in various
+other positions.  Finally, try dragging a tab to an existing tab ctrl.
+You'll soon see that very complex tab layouts may be achieved.
+"""
+
+#----------------------------------------------------------------------
+
+class TestPanel(wx.Panel):
+    def __init__(self, parent, log):
+        self.log = log
+        wx.Panel.__init__(self, parent, -1)
+
+        self.nb = wx.aui.AuiMultiNotebook(self)
+        page = wx.TextCtrl(self.nb, -1, text, style=wx.TE_MULTILINE)
+        self.nb.AddPage(page, "Welcome")
+
+        for num in range(1, 5):
+            page = wx.TextCtrl(self.nb, -1, "This is page %d" % num ,
+                               style=wx.TE_MULTILINE)
+            self.nb.AddPage(page, "Tab Number %d" % num)
+            
+        sizer = wx.BoxSizer()
+        sizer.Add(self.nb, 1, wx.EXPAND)
+        self.SetSizer(sizer)
+
+#----------------------------------------------------------------------
+
+def runTest(frame, nb, log):
+    win = TestPanel(nb, log)
+    return win
+
+#----------------------------------------------------------------------
+
+
+
+overview = """<html><body>
+<h2><center>Say something nice here</center></h2>
+
+</body></html>
+"""
+
+
+
+if __name__ == '__main__':
+    import sys,os
+    import run
+    run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
+
index c89232c97951dac3f882585c93c421ae5dc83d08..041678483a8f747668fe989452f122c80ac96797 100644 (file)
@@ -48,7 +48,8 @@ _treeList = [
     # new stuff
     ('Recent Additions/Updates', [
         'AnalogClock',
-        'AUI',
+        'AUI_DockingWindowMgr',
+        'AUI_Notebook',
         'CheckListCtrlMixin',
         'Pickers',
         'PseudoDC',
@@ -59,7 +60,7 @@ _treeList = [
 
     # managed windows == things with a (optional) caption you can close
     ('Frames and Dialogs', [
-        'AUI',
+        'AUI_DockingWindowMgr',
         'Dialog',
         'Frame',
         'MDIWindows',
@@ -128,6 +129,7 @@ _treeList = [
         ]),
     
     ('"Book" Controls', [
+        'AUI_Notebook',
         'Choicebook',
         'Listbook',
         'Notebook',
index 26a60965568728dec509bb95e17628b2652527c5..7710b73271f9be78ef264ee16ff0463ce9dd7b18 100755 (executable)
@@ -495,6 +495,7 @@ swig_sources = run_swig(['aui.i'], 'src', GENDIR, PKGDIR,
                                      opj(WXDIR, 'include/wx/aui/framemanager.h'),
                                      opj(WXDIR, 'include/wx/aui/floatpane.h'),
                                      opj(WXDIR, 'include/wx/aui/dockart.h'),
+                                     opj(WXDIR, 'include/wx/aui/auibook.h'),
                                      ])
 if not MONOLITHIC:
     auiLib = makeLibName('aui')
index e5047351e1e9178f6804ddf27abeb071e6dcc2f6..2c5857c6f4f87d37cdeb067499c9f60eed35c0c1 100755 (executable)
@@ -139,7 +139,8 @@ The following example shows a simple implementation that utilizes
 #define wxDEPRECATED(decl)
 
 
-// We'll let SWIG handle the function overloading for these
+// We'll skip making wrappers for these, they have overloads that take a
+// wxSize or wxPoint
 %ignore wxPaneInfo::MaxSize(int x, int y);
 %ignore wxPaneInfo::MinSize(int x, int y);
 %ignore wxPaneInfo::BestSize(int x, int y);
@@ -169,12 +170,21 @@ The following example shows a simple implementation that utilizes
 }
 
 
+%nokwargs wxAuiTabContainer::SetActivePage;
+
+%pythonAppend wxAuiTabCtrl::wxAuiTabCtrl "self._setOORInfo(self)";
+
+%pythonAppend wxAuiMultiNotebook::wxAuiMultiNotebook    "self._setOORInfo(self)";
+%pythonAppend wxAuiMultiNotebook::wxAuiMultiNotebook()  "self._setOORInfo(self)";
+%ignore wxAuiMultiNotebook::~wxAuiMultiNotebook;
+%rename(PreAuiMultiNotebook) wxAuiMultiNotebook::wxAuiMultiNotebook();
+
 //---------------------------------------------------------------------------
 // Get all our defs from the REAL header files.
 %include framemanager.h
 %include dockart.h
 %include floatpane.h
-
+%include auibook.h
 
 //---------------------------------------------------------------------------
 // Methods to inject into the FrameManager class that will sort out calls to
@@ -241,6 +251,7 @@ The following example shows a simple implementation that utilizes
 //---------------------------------------------------------------------------
 
 %{
+// A wxDocArt lcass that knows how to forward virtuals to Python methods  
 class wxPyDockArt :  public wxDefaultDockArt
 {
     wxPyDockArt() : wxDefaultDockArt() {}