]> git.saurik.com Git - wxWidgets.git/commitdiff
Don't pass zero width or height to SetVirtualSize or layout is
authorJulian Smart <julian@anthemion.co.uk>
Mon, 23 Dec 2002 23:42:13 +0000 (23:42 +0000)
committerJulian Smart <julian@anthemion.co.uk>
Mon, 23 Dec 2002 23:42:13 +0000 (23:42 +0000)
messed up.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@18405 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

src/generic/scrlwing.cpp

index 8c40ecb8534b809a13c995cbb50188f6f91a62a3..efe09689d2a3304e00f242aa99e2d5de5f938cd7 100644 (file)
@@ -340,15 +340,23 @@ void wxScrollHelper::SetScrollbars(int pixelsPerUnitX,
     m_xScrollPosition = xPos;
     m_yScrollPosition = yPos;
 
+    wxSize sz = m_targetWindow->GetSize();
+    int x = noUnitsX * pixelsPerUnitX;
+    int y = noUnitsY * pixelsPerUnitY;
+    if (x == 0)
+        x = sz.x;
+    if (y == 0)
+        y = sz.y;
+    
     // For better backward compatibility we set persisting limits
     // here not just the size.  It makes SetScrollbars 'sticky'
     // emulating the old non-autoscroll behaviour.
 
-    m_targetWindow->SetVirtualSizeHints( noUnitsX * pixelsPerUnitX, noUnitsY * pixelsPerUnitY );
+    m_targetWindow->SetVirtualSizeHints( x, y );
 
     // The above should arguably be deprecated, this however we still need.
 
-    m_targetWindow->SetVirtualSize( noUnitsX * pixelsPerUnitX, noUnitsY * pixelsPerUnitY );
+    m_targetWindow->SetVirtualSize( x, y );
 
     if (do_refresh && !noRefresh)
         m_targetWindow->Refresh(TRUE, GetRect());