X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/3e748fca4462fcd6d5265c5ced82ee70a69dc448..00ea969c97188b12e7fc23d560a1d7b21d3bb048:/src/common/treebase.cpp diff --git a/src/common/treebase.cpp b/src/common/treebase.cpp index bf992729d4..4d9c1094e6 100644 --- a/src/common/treebase.cpp +++ b/src/common/treebase.cpp @@ -106,16 +106,14 @@ 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; @@ -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 )