X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/52ad59c2e9ec4237636cecd864961bcde35ca84b..2e839e966d29c4e91394d28dd21e00387a33c184:/wxPython/demo/SplitTree.py diff --git a/wxPython/demo/SplitTree.py b/wxPython/demo/SplitTree.py index a7abb1ab9b..9f12a935bc 100644 --- a/wxPython/demo/SplitTree.py +++ b/wxPython/demo/SplitTree.py @@ -1,26 +1,42 @@ -from wxPython.wx import * -from wxPython.gizmos import * - -import images +# 11/13/2003 - Jeff Grimmett (grimmtooth@softhome.net) +# +# o Updated for wx namespace +# +# 11/26/2003 - Jeff Grimmett (grimmtooth@softhome.net) +# +# o Bigtime errors on startup. Blows up with a program error. +# Error: +# +# 21:04:11: Debug: ..\..\src\msw\treectrl.cpp(1508): assert "IsVisible(item)" +# failed: The item you call GetNextVisible() for must be visible itself! +# +# I suspect this error is in the lib itself. +# + +import wx +import wx.gizmos as gizmos + +import images #---------------------------------------------------------------------- -class TestTree(wxRemotelyScrolledTreeCtrl): - def __init__(self, parent, ID, pos=wxDefaultPosition, size=wxDefaultSize, - style=wxTR_HAS_BUTTONS): - wxRemotelyScrolledTreeCtrl.__init__(self, parent, ID, pos, size, style) +class TestTree(gizmos.RemotelyScrolledTreeCtrl): + def __init__(self, parent, style=wx.TR_HAS_BUTTONS): + gizmos.RemotelyScrolledTreeCtrl.__init__(self, parent, -1, style=style) # make an image list im1 = im2 = -1 - self.il = wxImageList(16, 16) + self.il = wx.ImageList(16, 16) im1 = self.il.Add(images.getFolder1Bitmap()) im2 = self.il.Add(images.getFile1Bitmap()) self.SetImageList(self.il) # Add some items root = self.AddRoot("Root") + for i in range(30): item = self.AppendItem(root, "Item %d" % i, im1) + for j in range(10): child = self.AppendItem(item, "Child %d" % j, im2) @@ -28,11 +44,11 @@ class TestTree(wxRemotelyScrolledTreeCtrl): -class TestValueWindow(wxTreeCompanionWindow): - def __init__(self, parent, ID, pos=wxDefaultPosition, size=wxDefaultSize, style=0): - wxTreeCompanionWindow.__init__(self, parent, ID, pos, size, style) +class TestValueWindow(gizmos.TreeCompanionWindow): + def __init__(self, parent, style=0): + gizmos.TreeCompanionWindow.__init__(self, parent, -1, style=style) self.SetBackgroundColour("WHITE") - EVT_ERASE_BACKGROUND(self, self.OEB) + self.Bind(wx.EVT_ERASE_BACKGROUND, self.OEB) def OEB(self, evt): pass @@ -40,19 +56,26 @@ class TestValueWindow(wxTreeCompanionWindow): # This method is called to draw each item in the value window def DrawItem(self, dc, itemId, rect): tree = self.GetTreeCtrl() + if tree: text = "This is " parent = tree.GetItemParent(itemId) + if parent.IsOk(): ptext = tree.GetItemText(parent) text = text + ptext + " --> " + text = text + tree.GetItemText(itemId) - pen = wxPen(wxSystemSettings_GetSystemColour(wxSYS_COLOUR_3DLIGHT), 1, wxSOLID) + pen = wx.Pen( + wx.SystemSettings_GetColour(wx.SYS_COLOUR_3DLIGHT), + 1, wx.SOLID + ) + dc.SetPen(pen) - dc.SetBrush(wxBrush(self.GetBackgroundColour(), wxSOLID)) + dc.SetBrush(wx.Brush(self.GetBackgroundColour(), wx.SOLID)) dc.DrawRectangle(rect.x, rect.y, rect.width+1, rect.height+1) dc.SetTextForeground("BLACK") - dc.SetBackgroundMode(wxTRANSPARENT) + dc.SetBackgroundMode(wx.TRANSPARENT) tw, th = dc.GetTextExtent(text) x = 5 y = rect.y + max(0, (rect.height - th) / 2) @@ -60,34 +83,48 @@ class TestValueWindow(wxTreeCompanionWindow): -class TestPanel(wxPanel): +class TestPanel(wx.Panel): def __init__(self, parent, log): - wxPanel.__init__(self, parent, -1) + wx.Panel.__init__(self, parent, -1) self.log = log - scroller = wxSplitterScrolledWindow(self, -1, (50,50), (350, 250), - style=wxNO_BORDER | wxCLIP_CHILDREN | wxVSCROLL) - splitter = wxThinSplitterWindow(scroller, -1, style=wxSP_3DBORDER | wxCLIP_CHILDREN) + scroller = gizmos.SplitterScrolledWindow( + self, -1, style=wx.NO_BORDER | wx.CLIP_CHILDREN | wx.VSCROLL + ) + + splitter = gizmos.ThinSplitterWindow( + scroller, -1, style=wx.SP_3DBORDER | wx.CLIP_CHILDREN + ) + splitter.SetSashSize(2) - tree = TestTree(splitter, -1, style = wxTR_HAS_BUTTONS | - wxTR_NO_LINES | - wxTR_ROW_LINES | - wxNO_BORDER ) - valueWindow = TestValueWindow(splitter, -1, style=wxNO_BORDER) - - splitter.SplitVertically(tree, valueWindow) - splitter.SetSashPosition(150) + tree = TestTree(splitter, style = wx.TR_HAS_BUTTONS | + wx.TR_NO_LINES | + wx.TR_ROW_LINES | + #wx.TR_HIDE_ROOT | + wx.NO_BORDER ) + + valueWindow = TestValueWindow(splitter, style=wx.NO_BORDER) + + splitter.SplitVertically(tree, valueWindow, 150) scroller.SetTargetWindow(tree) - scroller.EnableScrolling(FALSE, FALSE) + scroller.EnableScrolling(False, False) valueWindow.SetTreeCtrl(tree) tree.SetCompanionWindow(valueWindow) + sizer = wx.BoxSizer(wx.VERTICAL) + sizer.Add(scroller, 1, wx.EXPAND|wx.ALL, 25) + self.SetAutoLayout(True) + self.SetSizer(sizer) #---------------------------------------------------------------------- def runTest(frame, nb, log): + if wx.Platform == "__WXMAC__": + wx.MessageBox("This demo currently fails on the Mac. The problem is being looked into...", "Sorry") + return + win = TestPanel(nb, log) return win @@ -95,15 +132,18 @@ def runTest(frame, nb, log): #---------------------------------------------------------------------- - - - overview = """\ This demo shows a collection of classes that were designed to operate together and provide a tree control with additional columns for each -item. The classes are wxRemotelyScrolledTreeCtrl, wxTreeCompanionWindow, -wxThinSplitterWindow, and wxSplitterScrolledWindow, some of which may +item. The classes are wx.RemotelyScrolledTreeCtrl, wx.TreeCompanionWindow, +wx.ThinSplitterWindow, and wx.SplitterScrolledWindow, some of which may also be useful by themselves. """ + +if __name__ == '__main__': + import sys,os + import run + run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:]) +