]> git.saurik.com Git - wxWidgets.git/commitdiff
implemented GetBestSize() (TODO: make this available in generic version as well)
authorVadim Zeitlin <vadim@wxwidgets.org>
Sun, 9 Oct 2005 13:38:15 +0000 (13:38 +0000)
committerVadim Zeitlin <vadim@wxwidgets.org>
Sun, 9 Oct 2005 13:38:15 +0000 (13:38 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@35856 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

include/wx/msw/treectrl.h
src/msw/treectrl.cpp

index b4c5c756167f4dcd7f99a7a360ce5a4d15eab613..310d4cb34d96c3043f2987ada327dc495abea87d 100644 (file)
@@ -429,6 +429,9 @@ public:
     int GetState(const wxTreeItemId& node);
 
 protected:
     int GetState(const wxTreeItemId& node);
 
 protected:
+    virtual wxSize DoGetBestSize() const;
+
+    
     // SetImageList helper
     void SetAnyImageList(wxImageList *imageList, int which);
 
     // SetImageList helper
     void SetAnyImageList(wxImageList *imageList, int which);
 
index 13edcec7c3d447eee797f7ebded6d8392cf55861..7f17ef8bbbefb274fdf3c2b9b1df7f486cf7c33a 100644 (file)
@@ -2137,6 +2137,26 @@ bool wxTreeCtrl::GetBoundingRect(const wxTreeItemId& item,
     }
 }
 
     }
 }
 
+wxSize wxTreeCtrl::DoGetBestSize() const
+{
+    wxSize size;
+    wxRect rect;
+    for ( wxTreeItemId node = GetFirstVisibleItem();
+          node.IsOk();
+          node = GetNextVisible(node) )
+    {
+        if ( GetBoundingRect(node, rect) )
+        {
+            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;
+        }
+    }
+
+    return size;
+}
+
 // ----------------------------------------------------------------------------
 // sorting stuff
 // ----------------------------------------------------------------------------
 // ----------------------------------------------------------------------------
 // sorting stuff
 // ----------------------------------------------------------------------------