X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/49b6ebb7e15f76f6a2076e43dfda10a13de3e605..05d9753817cac280b05d14b0aeb26018700d1764:/src/common/treebase.cpp?ds=sidebyside diff --git a/src/common/treebase.cpp b/src/common/treebase.cpp index 8048795fc5..4d9c1094e6 100644 --- a/src/common/treebase.cpp +++ b/src/common/treebase.cpp @@ -106,22 +106,20 @@ wxTreeCtrlBase::~wxTreeCtrlBase() delete m_imageListState; } -static void wxGetBestTreeSize(const wxTreeCtrlBase* treeCtrl, const wxTreeItemId& id, wxSize& size) +static void +wxGetBestTreeSize(const wxTreeCtrlBase* treeCtrl, wxTreeItemId id, wxSize& size) { wxRect rect; - - if ( treeCtrl->GetBoundingRect(id, rect, true) ) + + if ( treeCtrl->GetBoundingRect(id, rect, true /* just the item */) ) { - if ( size.x < rect.x + rect.width ) - size.x = rect.x + rect.width; - if ( size.y < rect.y + rect.height ) - size.y = rect.y + rect.height; + size.IncTo(wxSize(rect.GetRight(), rect.GetBottom())); } wxTreeItemIdValue cookie; for ( wxTreeItemId item = treeCtrl->GetFirstChild(id, cookie); item.IsOk(); - item = treeCtrl->GetNextChild(item, cookie) ) + item = treeCtrl->GetNextChild(id, cookie) ) { wxGetBestTreeSize(treeCtrl, item, size); } @@ -134,7 +132,7 @@ wxSize wxTreeCtrlBase::DoGetBestSize() const // this doesn't really compute the total bounding rectangle of all items // but a not too bad guess of it which has the advantage of not having to // examine all (potentially hundreds or thousands) items in the control - + if (GetQuickBestSize()) { for ( wxTreeItemId item = GetRootItem(); @@ -155,8 +153,11 @@ wxSize wxTreeCtrlBase::DoGetBestSize() const } } } - else + else // use precise, if potentially slow, size computation method + { + // iterate over all items recursively wxGetBestTreeSize(this, GetRootItem(), size); + } // need some minimal size even for empty tree if ( !size.x || !size.y ) @@ -167,5 +168,26 @@ wxSize wxTreeCtrlBase::DoGetBestSize() const return size; } +void wxTreeCtrlBase::ExpandAll() +{ + ExpandAllChildren(GetRootItem()); +} + +void wxTreeCtrlBase::ExpandAllChildren(const wxTreeItemId& item) +{ + // expand this item first, this might result in its children being added on + // the fly + Expand(item); + + // then (recursively) expand all the children + wxTreeItemIdValue cookie; + for ( wxTreeItemId idCurr = GetFirstChild(item, cookie); + idCurr.IsOk(); + idCurr = GetNextChild(item, cookie) ) + { + ExpandAllChildren(idCurr); + } +} + #endif // wxUSE_TREECTRL