X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/369be443aa958ebce00f4d112f96ed7fa14c39b6..2458daa72859a8307ab18a18b38b9da6c13a8d7d:/wxPython/wx/lib/customtreectrl.py?ds=sidebyside diff --git a/wxPython/wx/lib/customtreectrl.py b/wxPython/wx/lib/customtreectrl.py index ae7b8cd69e..76f3501711 100644 --- a/wxPython/wx/lib/customtreectrl.py +++ b/wxPython/wx/lib/customtreectrl.py @@ -95,8 +95,9 @@ Base Functionalities CustomTreeCtrl supports all the wx.TreeCtrl styles, except: - TR_EXTENDED: supports for this style is on the todo list (Am I sure of this?). -Plus it has 2 more styles to handle checkbox-type items: +Plus it has 3 more styles to handle checkbox-type items: - TR_AUTO_CHECK_CHILD : automatically checks/unchecks the item children; + - TR_AUTO_CHECK_PARENT : automatically checks/unchecks the item parent; - TR_AUTO_TOGGLE_CHILD: automatically toggles the item children. All the methods available in wx.TreeCtrl are also available in CustomTreeCtrl. @@ -190,8 +191,9 @@ TR_HIDE_ROOT = wx.TR_HIDE_ROOT # don't display r TR_FULL_ROW_HIGHLIGHT = wx.TR_FULL_ROW_HIGHLIGHT # highlight full horz space -TR_AUTO_CHECK_CHILD = 0x4000 # only meaningful for checkboxes -TR_AUTO_TOGGLE_CHILD = 0x8000 # only meaningful for checkboxes +TR_AUTO_CHECK_CHILD = 0x04000 # only meaningful for checkboxes +TR_AUTO_TOGGLE_CHILD = 0x08000 # only meaningful for checkboxes +TR_AUTO_CHECK_PARENT = 0x10000 # only meaningful for checkboxes TR_DEFAULT_STYLE = wx.TR_DEFAULT_STYLE # default style for the tree control @@ -492,9 +494,9 @@ class DragImage(wx.DragImage): text = item.GetText() font = item.Attr().GetFont() colour = item.Attr().GetTextColour() - if colour is None: + if not colour: colour = wx.BLACK - if font is None: + if not font: font = treeCtrl._normalFont backcolour = treeCtrl.GetBackgroundColour() @@ -922,7 +924,7 @@ class TreeTextCtrl(wx.TextCtrl): else: - raise "\n ERROR: You Must Create An Image List To Use Images!" + raise Exception("\n ERROR: You Must Create An Image List To Use Images!") checkimage = item.GetCurrentCheckedImage() @@ -942,16 +944,12 @@ class TreeTextCtrl(wx.TextCtrl): x += image_w + wcheck w -= image_w + 4 + wcheck - if wx.Platform == "__WXMAC__": - bs = self.DoGetBestSize() - # edit control height - if h > bs.y - 8: - diff = h - ( bs.y - 8 ) - h -= diff - y += diff / 2 - wx.TextCtrl.__init__(self, self._owner, wx.ID_ANY, self._startValue, wx.Point(x - 4, y), wx.Size(w + 15, h)) + if wx.Platform == "__WXMAC__": + self.SetFont(owner.GetFont()) + bs = self.GetBestSize() + self.SetSize((-1, bs.height)) self.Bind(wx.EVT_CHAR, self.OnChar) self.Bind(wx.EVT_KEY_UP, self.OnKeyUp) @@ -1323,7 +1321,7 @@ class GenericTreeItem: """Returns whether the associated window is enabled or not.""" if not self._wnd: - raise "\nERROR: This Item Has No Window Associated" + raise Exception("\nERROR: This Item Has No Window Associated") return self._windowenabled @@ -1332,7 +1330,7 @@ class GenericTreeItem: """Sets whether the associated window is enabled or not.""" if not self._wnd: - raise "\nERROR: This Item Has No Window Associated" + raise Exception("\nERROR: This Item Has No Window Associated") self._windowenabled = enable self._wnd.Enable(enable) @@ -1735,7 +1733,7 @@ def EventFlagsToSelType(style, shiftDown=False, ctrlDown=False): # This Is The Main Class. # ----------------------------------------------------------------------------- -class CustomTreeCtrl(wx.ScrolledWindow): +class CustomTreeCtrl(wx.PyScrolledWindow): def __init__(self, parent, id=wx.ID_ANY, pos=wx.DefaultPosition, size=wx.DefaultSize, style=0, ctstyle=TR_DEFAULT_STYLE, validator=wx.DefaultValidator, @@ -1768,6 +1766,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): TR_HIDE_ROOT # don't display root node TR_FULL_ROW_HIGHLIGHT # highlight full horizontal space TR_AUTO_CHECK_CHILD # only meaningful for checkboxes + TR_AUTO_CHECK_PARENT # only meaningful for checkboxes TR_AUTO_TOGGLE_CHILD # only meaningful for checkboxes validator: window validator. @@ -1872,12 +1871,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): self._itemWithWindow = [] if wx.Platform == "__WXMAC__": - - platform, major, minor = wx.GetOsVersion() - ctstyle &= ~TR_LINES_AT_ROOT ctstyle |= TR_NO_LINES + platform, major, minor = wx.GetOsVersion() if major < 10: ctstyle |= TR_ROW_LINES @@ -1894,7 +1891,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): self._drawingfunction = wx.RendererNative.Get().DrawTreeItemButton # Create our container... at last! - wx.ScrolledWindow.__init__(self, parent, id, pos, size, style|wx.HSCROLL|wx.VSCROLL, name) + wx.PyScrolledWindow.__init__(self, parent, id, pos, size, style|wx.HSCROLL|wx.VSCROLL, name) # If the tree display has no buttons, but does have # connecting lines, we can use a narrower layout. @@ -1922,7 +1919,6 @@ class CustomTreeCtrl(wx.ScrolledWindow): self.Bind(wx.EVT_SET_FOCUS, self.OnSetFocus) self.Bind(wx.EVT_KILL_FOCUS, self.OnKillFocus) self.Bind(EVT_TREE_ITEM_GETTOOLTIP, self.OnGetToolTip) - self.Bind(wx.EVT_IDLE, self.OnInternalIdle) self.Bind(wx.EVT_WINDOW_DESTROY, self.OnDestroy) # Sets the focus to ourselves: this is useful if you have items @@ -1930,6 +1926,12 @@ class CustomTreeCtrl(wx.ScrolledWindow): self.SetFocus() + def AcceptsFocus(self): + # overridden base class method, allows this ctrl to + # participate in the tab-order, etc. It's overridable because + # of deriving this class from wx.PyScrolledWindow... + return True + def OnDestroy(self, event): """Handles the wx.EVT_WINDOW_DESTROY event.""" @@ -1991,7 +1993,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Toggles the item selection.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") self.SelectItem(item, not self.IsSelected(item)) @@ -2021,7 +2023,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Enables/disables an item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if item.IsEnabled() == enable: return @@ -2052,7 +2054,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether an item is enabled or disabled.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.IsEnabled() @@ -2074,7 +2076,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether an item is checked or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.IsChecked() @@ -2104,7 +2106,6 @@ class CustomTreeCtrl(wx.ScrolledWindow): return False item.Check(checked) - dc = wx.ClientDC(self) self.RefreshLine(item) self.EnableChildren(item, checked) e = TreeEvent(wxEVT_TREE_ITEM_CHECKED, self.GetId()) @@ -2122,7 +2123,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """ if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") # Should we raise an error here?!? if item.GetType() == 0: @@ -2156,6 +2157,9 @@ class CustomTreeCtrl(wx.ScrolledWindow): if self._windowStyle & TR_AUTO_CHECK_CHILD: ischeck = self.IsItemChecked(item) self.AutoCheckChild(item, ischeck) + if self._windowStyle & TR_AUTO_CHECK_PARENT: + ischeck = self.IsItemChecked(item) + self.AutoCheckParent(item, ischeck) elif self._windowStyle & TR_AUTO_TOGGLE_CHILD: self.AutoToggleChild(item) @@ -2169,7 +2173,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Transverses the tree and toggles the items. Meaningful only for check items.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") child, cookie = self.GetFirstChild(item) @@ -2189,7 +2193,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Transverses the tree and checks/unchecks the items. Meaningful only for check items.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") (child, cookie) = self.GetFirstChild(item) @@ -2204,11 +2208,33 @@ class CustomTreeCtrl(wx.ScrolledWindow): (child, cookie) = self.GetNextChild(item, cookie) + def AutoCheckParent(self, item, checked): + """Traverses up the tree and checks/unchecks parent items. + Meaningful only for check items.""" + + if not item: + raise Exception("\nERROR: Invalid Tree Item. ") + + parent = item.GetParent() + if not parent or parent.GetType() != 1: + return + + (child, cookie) = self.GetFirstChild(parent) + while child: + if child.GetType() == 1 and child.IsEnabled(): + if checked != child.IsChecked(): + return + (child, cookie) = self.GetNextChild(parent, cookie) + + self.CheckItem2(parent, checked, torefresh=True) + self.AutoCheckParent(parent, checked) + + def CheckChilds(self, item, checked=True): """Programatically check/uncheck item children. Does not generate EVT_TREE_CHECK* events.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if checked == None: self.AutoToggleChild(item) @@ -2244,7 +2270,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Starts editing an item label.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") self.Edit(item) @@ -2279,7 +2305,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether an item has children or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return len(item.GetChildren()) > 0 @@ -2288,7 +2314,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the item children count.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.GetChildrenCount(recursively) @@ -2337,7 +2363,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the item text.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.GetText() @@ -2346,7 +2372,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the item image.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.GetImage(which) @@ -2355,7 +2381,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the data associated to an item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.GetData() @@ -2366,7 +2392,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the item text colour.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.Attr().GetTextColour() @@ -2375,7 +2401,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the item background colour.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.Attr().GetBackgroundColour() @@ -2384,7 +2410,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the item font.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.Attr().GetFont() @@ -2393,7 +2419,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether an item is hypertext or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.IsHyperText() @@ -2402,7 +2428,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the item text.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") dc = wx.ClientDC(self) item.SetText(text) @@ -2414,7 +2440,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the item image, depending on the item state.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") item.SetImage(image, which) @@ -2427,7 +2453,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the data associated to an item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") item.SetData(data) @@ -2438,7 +2464,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Forces the appearance of the button next to the item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") item.SetHasPlus(has) self.RefreshLine(item) @@ -2448,7 +2474,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the item font bold/unbold.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") # avoid redrawing the tree if no real change if item.IsBold() != bold: @@ -2460,7 +2486,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the item font italic/non-italic.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if item.IsItalic() != italic: itemFont = self.GetItemFont(item) @@ -2482,7 +2508,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """ if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if highlight: bg = wx.SystemSettings_GetColour(wx.SYS_COLOUR_HIGHLIGHT) @@ -2497,7 +2523,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the item text colour.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if self.GetItemTextColour(item) == col: return @@ -2510,7 +2536,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the item background colour.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") item.Attr().SetBackgroundColour(col) self.RefreshLine(item) @@ -2520,7 +2546,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets whether the item is hypertext or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") item.SetHyperText(hyper) self.RefreshLine(item) @@ -2530,7 +2556,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets the item font.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if self.GetItemFont(item) == font: return @@ -2595,7 +2621,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Sets whether an hypertext item was visited.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") item.SetVisited(visited) self.RefreshLine(item) @@ -2605,7 +2631,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether an hypertext item was visited.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.GetVisited() @@ -2777,7 +2803,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the window associated to the item (if any).""" if not item: - raise "\nERROR: Invalid Item" + raise Exception("\nERROR: Invalid Item") return item.GetWindow() @@ -2786,7 +2812,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether the window associated to the item is enabled.""" if not item: - raise "\nERROR: Invalid Item" + raise Exception("\nERROR: Invalid Item") return item.GetWindowEnabled() @@ -2795,7 +2821,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Enables/disables the window associated to the item.""" if not item: - raise "\nERROR: Invalid Item" + raise Exception("\nERROR: Invalid Item") item.SetWindowEnabled(enable) @@ -2809,7 +2835,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """ if not item: - raise "\nERROR: Invalid Item" + raise Exception("\nERROR: Invalid Item") return item.GetType() @@ -2821,7 +2847,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether the item is visible or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") # An item is only visible if it's not a descendant of a collapsed item parent = item.GetParent() @@ -2854,7 +2880,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether the item has children or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") # consider that the item does have children if it has the "+" button: it # might not have them (if it had never been expanded yet) but then it @@ -2868,7 +2894,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether the item is expanded or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.IsExpanded() @@ -2877,7 +2903,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether the item is selected or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.IsSelected() @@ -2886,7 +2912,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether the item font is bold or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.IsBold() @@ -2895,7 +2921,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns whether the item font is italic or not.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.IsItalic() @@ -2908,7 +2934,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the item parent.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") return item.GetParent() @@ -2917,7 +2943,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the item first child.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") cookie = 0 return self.GetNextChild(item, cookie) @@ -2930,7 +2956,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """ if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") children = item.GetChildren() @@ -2951,7 +2977,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the item last child.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") children = item.GetChildren() return (len(children) == 0 and [None] or [children[-1]])[0] @@ -2961,7 +2987,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the next sibling of an item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") i = item parent = i.GetParent() @@ -2982,7 +3008,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the previous sibling of an item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") i = item parent = i.GetParent() @@ -3002,7 +3028,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the next item. Only for internal use right now.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") i = item @@ -3040,7 +3066,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Returns the next visible item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") id = item @@ -3055,9 +3081,9 @@ class CustomTreeCtrl(wx.ScrolledWindow): def GetPrevVisible(self, item): if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") - raise "\nERROR: Not Implemented" + raise Exception("\nERROR: Not Implemented") return None @@ -3115,13 +3141,13 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Actually inserts an item in the tree.""" if wnd is not None and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if text.find("\n") >= 0 and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if ct_type < 0 or ct_type > 2: - raise "\nERROR: Item Type Should Be 0 (Normal), 1 (CheckBox) or 2 (RadioButton). " + raise Exception("\nERROR: Item Type Should Be 0 (Normal), 1 (CheckBox) or 2 (RadioButton). ") parent = parentId @@ -3147,16 +3173,16 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Adds a root to the CustomTreeCtrl. Only one root must exist.""" if self._anchor: - raise "\nERROR: Tree Can Have Only One Root" + raise Exception("\nERROR: Tree Can Have Only One Root") if wnd is not None and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if text.find("\n") >= 0 and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if ct_type < 0 or ct_type > 2: - raise "\nERROR: Item Type Should Be 0 (Normal), 1 (CheckBox) or 2 (RadioButton). " + raise Exception("\nERROR: Item Type Should Be 0 (Normal), 1 (CheckBox) or 2 (RadioButton). ") self._dirty = True # do this first so stuff below doesn't cause flicker @@ -3186,10 +3212,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Appends an item as a first child of parent.""" if wnd is not None and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if text.find("\n") >= 0 and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") return self.DoInsertItem(parent, 0, text, ct_type, wnd, image, selImage, data) @@ -3198,10 +3224,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Auxiliary function to cope with the C++ hideous multifunction.""" if wnd is not None and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if text.find("\n") >= 0 and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") parent = parentId @@ -3215,7 +3241,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): try: index = parent.GetChildren().index(idPrevious) except: - raise "ERROR: Previous Item In CustomTreeCtrl.InsertItem() Is Not A Sibling" + raise Exception("ERROR: Previous Item In CustomTreeCtrl.InsertItem() Is Not A Sibling") return self.DoInsertItem(parentId, index+1, text, ct_type, wnd, image, selImage, data) @@ -3224,10 +3250,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Auxiliary function to cope with the C++ hideous multifunction.""" if wnd is not None and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if text.find("\n") >= 0 and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") parent = parentId @@ -3242,10 +3268,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Inserts an item after the given previous.""" if wnd is not None and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if text.find("\n") >= 0 and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if type(input) == type(1): return self.InsertItemByIndex(parentId, input, text, ct_type, wnd, image, selImage, data) @@ -3257,10 +3283,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Appends an item as a last child of its parent.""" if wnd is not None and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert Controls You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") if text.find("\n") >= 0 and not (self._windowStyle & TR_HAS_VARIABLE_ROW_HEIGHT): - raise "\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT" + raise Exception("\nERROR: In Order To Append/Insert A MultiLine Text You Have To Use The Style TR_HAS_VARIABLE_ROW_HEIGHT") parent = parentId @@ -3318,7 +3344,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Delete item children.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") self._dirty = True # do this first so stuff below doesn't cause flicker @@ -3330,7 +3356,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Delete an item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") self._dirty = True # do this first so stuff below doesn't cause flicker @@ -3407,10 +3433,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): """ if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if self.HasFlag(TR_HIDE_ROOT) and item == self.GetRootItem(): - raise "\nERROR: Can't Expand An Hidden Root. " + raise Exception("\nERROR: Can't Expand An Hidden Root. ") if not item.HasPlus(): return @@ -3443,9 +3469,9 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Expands all the items.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") - if not self.HasFlag(TR_HIDE_ROOT) or item != GetRootItem(): + if not self.HasFlag(TR_HIDE_ROOT) or item != self.GetRootItem(): self.Expand(item) if not self.IsExpanded(item): return @@ -3464,10 +3490,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): """ if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if self.HasFlag(TR_HIDE_ROOT) and item == self.GetRootItem(): - raise "\nERROR: Can't Collapse An Hidden Root. " + raise Exception("\nERROR: Can't Collapse An Hidden Root. ") if not item.IsExpanded(): return @@ -3618,7 +3644,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Actually selects/unselects an item, sending a EVT_TREE_SEL_CHANGED event.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") self._select_me = None @@ -3699,7 +3725,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Selects/deselects an item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") if select: @@ -3723,7 +3749,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): if item.IsSelected(): array.append(item) - if item.HasChildren(): + if item.HasChildren() and item.IsExpanded(): for child in item.GetChildren(): array = self.FillArray(child, array) @@ -3750,7 +3776,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Ensure that an item is visible in CustomTreeCtrl.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") # first expand all parent branches parent = item.GetParent() @@ -3834,7 +3860,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """ if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") children = item.GetChildren() @@ -4056,9 +4082,8 @@ class CustomTreeCtrl(wx.ScrolledWindow): def DrawVerticalGradient(self, dc, rect, hasfocus): """Gradient fill from colour 1 to colour 2 from top to bottom.""" - dc.DrawRectangleRect(rect) - border = self._borderPen.GetWidth() - + oldpen = dc.GetPen() + oldbrush = dc.GetBrush() dc.SetPen(wx.TRANSPARENT_PEN) # calculate gradient coefficients @@ -4080,21 +4105,25 @@ class CustomTreeCtrl(wx.ScrolledWindow): rf, gf, bf = 0, 0, 0 - for y in xrange(rect.y+border, rect.y + rect.height-border): + for y in xrange(rect.y, rect.y + rect.height): currCol = (r1 + rf, g1 + gf, b1 + bf) dc.SetBrush(wx.Brush(currCol, wx.SOLID)) - dc.DrawRectangle(rect.x+border, y, rect.width-2*border, 1) + dc.DrawRectangle(rect.x, y, rect.width, 1) rf = rf + rstep gf = gf + gstep bf = bf + bstep + dc.SetPen(oldpen) + dc.SetBrush(wx.TRANSPARENT_BRUSH) + dc.DrawRectangleRect(rect) + dc.SetBrush(oldbrush) + def DrawHorizontalGradient(self, dc, rect, hasfocus): """Gradient fill from colour 1 to colour 2 from left to right.""" - dc.DrawRectangleRect(rect) - border = self._borderPen.GetWidth() - + oldpen = dc.GetPen() + oldbrush = dc.GetBrush() dc.SetPen(wx.TRANSPARENT_PEN) # calculate gradient coefficients @@ -4116,15 +4145,20 @@ class CustomTreeCtrl(wx.ScrolledWindow): bstep = float((b2 - b1)) / flrect rf, gf, bf = 0, 0, 0 - - for x in xrange(rect.x+border, rect.x + rect.width-border): + + for x in xrange(rect.x, rect.x + rect.width): currCol = (int(r1 + rf), int(g1 + gf), int(b1 + bf)) dc.SetBrush(wx.Brush(currCol, wx.SOLID)) - dc.DrawRectangle(x, rect.y+border, 1, rect.height-2*border) + dc.DrawRectangle(x, rect.y, 1, rect.height) rf = rf + rstep gf = gf + gstep bf = bf + bstep - + + dc.SetPen(oldpen) + dc.SetBrush(wx.TRANSPARENT_BRUSH) + dc.DrawRectangleRect(rect) + dc.SetBrush(oldbrush) + def DrawVistaRectangle(self, dc, rect, hasfocus): """Draw the selected item(s) with the Windows Vista style.""" @@ -4146,18 +4180,14 @@ class CustomTreeCtrl(wx.ScrolledWindow): oldpen = dc.GetPen() oldbrush = dc.GetBrush() - dc.SetBrush(wx.TRANSPARENT_BRUSH) - dc.SetPen(wx.Pen(outer)) - dc.DrawRoundedRectangleRect(rect, 3) - rect.Deflate(1, 1) - dc.SetPen(wx.Pen(inner)) - dc.DrawRoundedRectangleRect(rect, 2) - rect.Deflate(1, 1) - + bdrRect = wx.Rect(*rect.Get()) + filRect = wx.Rect(*rect.Get()) + filRect.Deflate(1,1) + r1, g1, b1 = int(top.Red()), int(top.Green()), int(top.Blue()) r2, g2, b2 = int(bottom.Red()), int(bottom.Green()), int(bottom.Blue()) - flrect = float(rect.height) + flrect = float(filRect.height) rstep = float((r2 - r1)) / flrect gstep = float((g2 - g1)) / flrect @@ -4166,14 +4196,21 @@ class CustomTreeCtrl(wx.ScrolledWindow): rf, gf, bf = 0, 0, 0 dc.SetPen(wx.TRANSPARENT_PEN) - for y in xrange(rect.y, rect.y + rect.height): + for y in xrange(filRect.y, filRect.y + filRect.height): currCol = (r1 + rf, g1 + gf, b1 + bf) dc.SetBrush(wx.Brush(currCol, wx.SOLID)) - dc.DrawRectangle(rect.x, y, rect.width, 1) + dc.DrawRectangle(filRect.x, y, filRect.width, 1) rf = rf + rstep gf = gf + gstep bf = bf + bstep + dc.SetBrush(wx.TRANSPARENT_BRUSH) + dc.SetPen(wx.Pen(outer)) + dc.DrawRoundedRectangleRect(bdrRect, 3) + bdrRect.Deflate(1, 1) + dc.SetPen(wx.Pen(inner)) + dc.DrawRoundedRectangleRect(bdrRect, 2) + dc.SetPen(oldpen) dc.SetBrush(oldbrush) @@ -4219,7 +4256,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): total_h = self.GetLineHeight(item) drawItemBackground = False - + if item.IsSelected(): # under mac selections are only a rectangle in case they don't have the focus @@ -4243,13 +4280,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): dc.SetPen(wx.TRANSPARENT_PEN) offset = (self.HasFlag(TR_ROW_LINES) and [1] or [0])[0] - + if self.HasFlag(TR_FULL_ROW_HIGHLIGHT): - - oldpen = dc.GetPen() - dc.SetPen(wx.TRANSPARENT_PEN) x = 0 - w, h = self.GetSize() + w, h = self.GetClientSize() itemrect = wx.Rect(x, item.GetY()+offset, w, total_h-offset) @@ -4262,13 +4296,16 @@ class CustomTreeCtrl(wx.ScrolledWindow): elif self._vistaselection: self.DrawVistaRectangle(dc, itemrect, self._hasFocus) else: - dc.DrawRectangleRect(itemrect) + if wx.Platform in ["__WXGTK2__", "__WXMAC__"]: + flags = wx.CONTROL_SELECTED + if self._hasFocus: flags = flags | wx.CONTROL_FOCUSED + wx.RendererNative.Get().DrawItemSelectionRect(self, dc, itemrect, flags) + else: + dc.DrawRectangleRect(itemrect) - dc.SetPen(oldpen) - else: - - if item.IsSelected() and image != _NO_IMAGE: + + if item.IsSelected(): # If it's selected, and there's an image, then we should # take care to leave the area under the image painted in the @@ -4279,9 +4316,11 @@ class CustomTreeCtrl(wx.ScrolledWindow): if wnd: wndx, wndy = item.GetWindowSize() - itemrect = wx.Rect(item.GetX() + wcheck + image_w - 2, item.GetY()+offset, - item.GetWidth() - image_w - wcheck + 2 - wndx, total_h-offset) - + itemrect = wx.Rect(item.GetX() + wcheck + image_w - 2, + item.GetY()+offset, + item.GetWidth() - image_w - wcheck + 2 - wndx, + total_h-offset) + if self._usegradients: if self._gradientstyle == 0: # Horizontal self.DrawHorizontalGradient(dc, itemrect, self._hasFocus) @@ -4290,7 +4329,12 @@ class CustomTreeCtrl(wx.ScrolledWindow): elif self._vistaselection: self.DrawVistaRectangle(dc, itemrect, self._hasFocus) else: - dc.DrawRectangleRect(itemrect) + if wx.Platform in ["__WXGTK2__", "__WXMAC__"]: + flags = wx.CONTROL_SELECTED + if self._hasFocus: flags = flags | wx.CONTROL_FOCUSED + wx.RendererNative.Get().DrawItemSelectionRect(self, dc, itemrect, flags) + else: + dc.DrawRectangleRect(itemrect) # On GTK+ 2, drawing a 'normal' background is wrong for themes that # don't allow backgrounds to be customized. Not drawing the background, @@ -4298,7 +4342,10 @@ class CustomTreeCtrl(wx.ScrolledWindow): elif drawItemBackground: minusicon = wcheck + image_w - 2 - itemrect = wx.Rect(item.GetX()+minusicon, item.GetY()+offset, item.GetWidth()-minusicon, total_h-offset) + itemrect = wx.Rect(item.GetX()+minusicon, + item.GetY()+offset, + item.GetWidth()-minusicon, + total_h-offset) if self._usegradients and self._hasFocus: if self._gradientstyle == 0: # Horizontal @@ -4345,6 +4392,8 @@ class CustomTreeCtrl(wx.ScrolledWindow): dc.DrawLabel(item.GetText(), textrect) dc.SetTextForeground(foreground) else: + if wx.Platform == "__WXMAC__" and item.IsSelected() and self._hasFocus: + dc.SetTextForeground(wx.WHITE) dc.DrawLabel(item.GetText(), textrect) wnd = item.GetWindow() @@ -4806,7 +4855,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): current = self.GetItemParent(current) if current: next = self.GetNextSibling(current) - if not self.IsEnabled(next): + if not next or not self.IsEnabled(next): next = None else: @@ -4976,7 +5025,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Gets the bounding rectangle of the item.""" if not item: - raise "\nERROR: Invalid Tree Item. " + raise Exception("\nERROR: Invalid Tree Item. ") i = item @@ -5081,7 +5130,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): underMouse = thisItem underMouseChanged = underMouse != self._underMouse - if underMouse and (flags & TREE_HITTEST_ONITEMBUTTON) and not event.LeftIsDown() and \ + if underMouse and (flags & TREE_HITTEST_ONITEM) and not event.LeftIsDown() and \ not self._isDragging and (not self._renameTimer or not self._renameTimer.IsRunning()): underMouse = underMouse else: @@ -5404,7 +5453,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): self.Toggle(item) - def OnInternalIdle(self, event): + def OnInternalIdle(self): """Performs operations in idle time (essentially drawing).""" # Check if we need to select the root item @@ -5614,7 +5663,7 @@ class CustomTreeCtrl(wx.ScrolledWindow): """Thaw CustomTreeCtrl.""" if self._freezeCount == 0: - raise "\nERROR: Thawing Unfrozen Tree Control?" + raise Exception("\nERROR: Thawing Unfrozen Tree Control?") self._freezeCount = self._freezeCount - 1