Fix wxWrapSizer minimal size calculation.

Add a unit test checking that wxWrapSizer::CalcMin() returns the expected
results.

Closes #12464.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@66862 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin 2011-02-08 13:36:13 +00:00
parent 8de6a0270d
commit e4c903b2ea
15 changed files with 228 additions and 54 deletions

View File

@ -461,6 +461,7 @@ All (GUI):
- wxPropertyGrid: Added "HasAlpha" attribute for wxColourProperty. - wxPropertyGrid: Added "HasAlpha" attribute for wxColourProperty.
- Added support for saving PNG files with palette (troelsk). - Added support for saving PNG files with palette (troelsk).
- Added support for saving as GIF and animated GIF (troelsk). - Added support for saving as GIF and animated GIF (troelsk).
- Fix wxWrapSizer minimal size calculation (Catalin Raceanu).
GTK: GTK:

View File

@ -665,6 +665,10 @@ public:
m_position = pos; m_position = pos;
m_size = size; m_size = size;
Layout(); Layout();
// This call is required for wxWrapSizer to be able to calculate its
// minimal size correctly.
InformFirstDirection(wxHORIZONTAL, size.x, size.y);
} }
void SetDimension(int x, int y, int width, int height) void SetDimension(int x, int y, int width, int height)
{ SetDimension(wxPoint(x, y), wxSize(width, height)); } { SetDimension(wxPoint(x, y), wxSize(width, height)); }

View File

@ -525,12 +525,7 @@ public:
// tells the item how much more space there is available in the opposite // tells the item how much more space there is available in the opposite
// direction (-1 if unknown). // direction (-1 if unknown).
virtual bool virtual bool
InformFirstDirection(int WXUNUSED(direction), InformFirstDirection(int direction, int size, int availableOtherDir);
int WXUNUSED(size),
int WXUNUSED(availableOtherDir))
{
return false;
}
// sends a size event to the window using its current size -- this has an // sends a size event to the window using its current size -- this has an
// effect of refreshing the window layout // effect of refreshing the window layout

View File

@ -853,6 +853,16 @@ wxSize wxWindowBase::GetWindowBorderSize() const
return size*2; return size*2;
} }
bool
wxWindowBase::InformFirstDirection(int direction,
int size,
int availableOtherDir)
{
return GetSizer() && GetSizer()->InformFirstDirection(direction,
size,
availableOtherDir);
}
wxSize wxWindowBase::GetEffectiveMinSize() const wxSize wxWindowBase::GetEffectiveMinSize() const
{ {
// merge the best size with the min size, giving priority to the min size // merge the best size with the min size, giving priority to the min size

View File

@ -213,6 +213,7 @@ TEST_GUI_OBJECTS = \
test_gui_settings.o \ test_gui_settings.o \
test_gui_socket.o \ test_gui_socket.o \
test_gui_boxsizer.o \ test_gui_boxsizer.o \
test_gui_wrapsizer.o \
test_gui_valnum.o \ test_gui_valnum.o \
test_gui_clientsize.o \ test_gui_clientsize.o \
test_gui_setsize.o \ test_gui_setsize.o \
@ -868,6 +869,9 @@ test_gui_socket.o: $(srcdir)/net/socket.cpp $(TEST_GUI_ODEP)
test_gui_boxsizer.o: $(srcdir)/sizers/boxsizer.cpp $(TEST_GUI_ODEP) test_gui_boxsizer.o: $(srcdir)/sizers/boxsizer.cpp $(TEST_GUI_ODEP)
$(CXXC) -c -o $@ $(TEST_GUI_CXXFLAGS) $(srcdir)/sizers/boxsizer.cpp $(CXXC) -c -o $@ $(TEST_GUI_CXXFLAGS) $(srcdir)/sizers/boxsizer.cpp
test_gui_wrapsizer.o: $(srcdir)/sizers/wrapsizer.cpp $(TEST_GUI_ODEP)
$(CXXC) -c -o $@ $(TEST_GUI_CXXFLAGS) $(srcdir)/sizers/wrapsizer.cpp
test_gui_valnum.o: $(srcdir)/validators/valnum.cpp $(TEST_GUI_ODEP) test_gui_valnum.o: $(srcdir)/validators/valnum.cpp $(TEST_GUI_ODEP)
$(CXXC) -c -o $@ $(TEST_GUI_CXXFLAGS) $(srcdir)/validators/valnum.cpp $(CXXC) -c -o $@ $(TEST_GUI_CXXFLAGS) $(srcdir)/validators/valnum.cpp

View File

@ -195,12 +195,13 @@ TEST_GUI_OBJECTS = \
$(OBJS)\test_gui_guifuncs.obj \ $(OBJS)\test_gui_guifuncs.obj \
$(OBJS)\test_gui_selstoretest.obj \ $(OBJS)\test_gui_selstoretest.obj \
$(OBJS)\test_gui_garbage.obj \ $(OBJS)\test_gui_garbage.obj \
$(OBJS)\test_gui_settings.obj \ $(OBJS)\test_gui_settings.obj \
$(OBJS)\test_gui_socket.obj \ $(OBJS)\test_gui_socket.obj \
$(OBJS)\test_gui_boxsizer.obj \ $(OBJS)\test_gui_boxsizer.obj \
$(OBJS)\test_gui_valnum.obj \ $(OBJS)\test_gui_wrapsizer.obj \
$(OBJS)\test_gui_clientsize.obj \ $(OBJS)\test_gui_valnum.obj \
$(OBJS)\test_gui_setsize.obj \ $(OBJS)\test_gui_clientsize.obj \
$(OBJS)\test_gui_setsize.obj \
$(OBJS)\test_gui_xrctest.obj $(OBJS)\test_gui_xrctest.obj
### Conditionally set variables: ### ### Conditionally set variables: ###
@ -913,12 +914,15 @@ $(OBJS)\test_gui_settings.obj: .\misc\settings.cpp
$(OBJS)\test_gui_socket.obj: .\net\socket.cpp $(OBJS)\test_gui_socket.obj: .\net\socket.cpp
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\net\socket.cpp $(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\net\socket.cpp
$(OBJS)\test_gui_boxsizer.obj: .\sizers\boxsizer.cpp $(OBJS)\test_gui_boxsizer.obj: .\sizers\boxsizer.cpp
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\sizers\boxsizer.cpp $(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\sizers\boxsizer.cpp
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp $(OBJS)\test_gui_wrapsizer.obj: .\sizers\wrapsizer.cpp
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp $(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\sizers\wrapsizer.cpp
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp
$(OBJS)\test_gui_clientsize.obj: .\window\clientsize.cpp $(OBJS)\test_gui_clientsize.obj: .\window\clientsize.cpp
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\window\clientsize.cpp $(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\window\clientsize.cpp

View File

@ -188,12 +188,13 @@ TEST_GUI_OBJECTS = \
$(OBJS)\test_gui_guifuncs.o \ $(OBJS)\test_gui_guifuncs.o \
$(OBJS)\test_gui_selstoretest.o \ $(OBJS)\test_gui_selstoretest.o \
$(OBJS)\test_gui_garbage.o \ $(OBJS)\test_gui_garbage.o \
$(OBJS)\test_gui_settings.o \ $(OBJS)\test_gui_settings.o \
$(OBJS)\test_gui_socket.o \ $(OBJS)\test_gui_socket.o \
$(OBJS)\test_gui_boxsizer.o \ $(OBJS)\test_gui_boxsizer.o \
$(OBJS)\test_gui_valnum.o \ $(OBJS)\test_gui_wrapsizer.o \
$(OBJS)\test_gui_clientsize.o \ $(OBJS)\test_gui_valnum.o \
$(OBJS)\test_gui_setsize.o \ $(OBJS)\test_gui_clientsize.o \
$(OBJS)\test_gui_setsize.o \
$(OBJS)\test_gui_xrctest.o $(OBJS)\test_gui_xrctest.o
### Conditionally set variables: ### ### Conditionally set variables: ###
@ -894,12 +895,15 @@ $(OBJS)\test_gui_settings.o: ./misc/settings.cpp
$(OBJS)\test_gui_socket.o: ./net/socket.cpp $(OBJS)\test_gui_socket.o: ./net/socket.cpp
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $< $(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<
$(OBJS)\test_gui_boxsizer.o: ./sizers/boxsizer.cpp $(OBJS)\test_gui_boxsizer.o: ./sizers/boxsizer.cpp
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $< $(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<
$(OBJS)\test_gui_valnum.o: ./validators/valnum.cpp $(OBJS)\test_gui_wrapsizer.o: ./sizers/wrapsizer.cpp
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $< $(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<
$(OBJS)\test_gui_valnum.o: ./validators/valnum.cpp
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<
$(OBJS)\test_gui_clientsize.o: ./window/clientsize.cpp $(OBJS)\test_gui_clientsize.o: ./window/clientsize.cpp
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $< $(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<

View File

@ -190,12 +190,13 @@ TEST_GUI_OBJECTS = \
$(OBJS)\test_gui_guifuncs.obj \ $(OBJS)\test_gui_guifuncs.obj \
$(OBJS)\test_gui_selstoretest.obj \ $(OBJS)\test_gui_selstoretest.obj \
$(OBJS)\test_gui_garbage.obj \ $(OBJS)\test_gui_garbage.obj \
$(OBJS)\test_gui_settings.obj \ $(OBJS)\test_gui_settings.obj \
$(OBJS)\test_gui_socket.obj \ $(OBJS)\test_gui_socket.obj \
$(OBJS)\test_gui_boxsizer.obj \ $(OBJS)\test_gui_boxsizer.obj \
$(OBJS)\test_gui_valnum.obj \ $(OBJS)\test_gui_wrapsizer.obj \
$(OBJS)\test_gui_clientsize.obj \ $(OBJS)\test_gui_valnum.obj \
$(OBJS)\test_gui_setsize.obj \ $(OBJS)\test_gui_clientsize.obj \
$(OBJS)\test_gui_setsize.obj \
$(OBJS)\test_gui_xrctest.obj $(OBJS)\test_gui_xrctest.obj
TEST_GUI_RESOURCES = \ TEST_GUI_RESOURCES = \
$(OBJS)\test_gui_sample.res $(OBJS)\test_gui_sample.res
@ -1039,12 +1040,15 @@ $(OBJS)\test_gui_settings.obj: .\misc\settings.cpp
$(OBJS)\test_gui_socket.obj: .\net\socket.cpp $(OBJS)\test_gui_socket.obj: .\net\socket.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\net\socket.cpp $(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\net\socket.cpp
$(OBJS)\test_gui_boxsizer.obj: .\sizers\boxsizer.cpp $(OBJS)\test_gui_boxsizer.obj: .\sizers\boxsizer.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\sizers\boxsizer.cpp $(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\sizers\boxsizer.cpp
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp $(OBJS)\test_gui_wrapsizer.obj: .\sizers\wrapsizer.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp $(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\sizers\wrapsizer.cpp
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp
$(OBJS)\test_gui_clientsize.obj: .\window\clientsize.cpp $(OBJS)\test_gui_clientsize.obj: .\window\clientsize.cpp
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\window\clientsize.cpp $(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\window\clientsize.cpp

View File

@ -434,12 +434,13 @@ TEST_GUI_OBJECTS = &
$(OBJS)\test_gui_guifuncs.obj & $(OBJS)\test_gui_guifuncs.obj &
$(OBJS)\test_gui_selstoretest.obj & $(OBJS)\test_gui_selstoretest.obj &
$(OBJS)\test_gui_garbage.obj & $(OBJS)\test_gui_garbage.obj &
$(OBJS)\test_gui_settings.obj & $(OBJS)\test_gui_settings.obj &
$(OBJS)\test_gui_socket.obj & $(OBJS)\test_gui_socket.obj &
$(OBJS)\test_gui_boxsizer.obj & $(OBJS)\test_gui_boxsizer.obj &
$(OBJS)\test_gui_valnum.obj & $(OBJS)\test_gui_wrapsizer.obj &
$(OBJS)\test_gui_clientsize.obj & $(OBJS)\test_gui_valnum.obj &
$(OBJS)\test_gui_setsize.obj & $(OBJS)\test_gui_clientsize.obj &
$(OBJS)\test_gui_setsize.obj &
$(OBJS)\test_gui_xrctest.obj $(OBJS)\test_gui_xrctest.obj
@ -953,12 +954,15 @@ $(OBJS)\test_gui_settings.obj : .AUTODEPEND .\misc\settings.cpp
$(OBJS)\test_gui_socket.obj : .AUTODEPEND .\net\socket.cpp $(OBJS)\test_gui_socket.obj : .AUTODEPEND .\net\socket.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $< $(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<
$(OBJS)\test_gui_boxsizer.obj : .AUTODEPEND .\sizers\boxsizer.cpp $(OBJS)\test_gui_boxsizer.obj : .AUTODEPEND .\sizers\boxsizer.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $< $(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<
$(OBJS)\test_gui_valnum.obj : .AUTODEPEND .\validators\valnum.cpp $(OBJS)\test_gui_wrapsizer.obj : .AUTODEPEND .\sizers\wrapsizer.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $< $(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<
$(OBJS)\test_gui_valnum.obj : .AUTODEPEND .\validators\valnum.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<
$(OBJS)\test_gui_clientsize.obj : .AUTODEPEND .\window\clientsize.cpp $(OBJS)\test_gui_clientsize.obj : .AUTODEPEND .\window\clientsize.cpp
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $< $(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<

128
tests/sizers/wrapsizer.cpp Normal file
View File

@ -0,0 +1,128 @@
///////////////////////////////////////////////////////////////////////////////
// Name: tests/sizers/wrapsizer.cpp
// Purpose: Unit tests for wxWrapSizer
// Author: Catalin Raceanu
// Created: 2010-10-23
// RCS-ID: $Id:$
// Copyright: (c) 2010 wxWidgets development team
///////////////////////////////////////////////////////////////////////////////
// ----------------------------------------------------------------------------
// headers
// ----------------------------------------------------------------------------
#include "testprec.h"
#ifdef __BORLANDC__
#pragma hdrstop
#endif
#ifndef WX_PRECOMP
#include "wx/app.h"
#endif // WX_PRECOMP
#include "wx/wrapsizer.h"
#include "asserthelper.h"
// ----------------------------------------------------------------------------
// test class
// ----------------------------------------------------------------------------
class WrapSizerTestCase : public CppUnit::TestCase
{
public:
WrapSizerTestCase() { }
virtual void setUp();
virtual void tearDown();
private:
CPPUNIT_TEST_SUITE( WrapSizerTestCase );
CPPUNIT_TEST( CalcMin );
CPPUNIT_TEST_SUITE_END();
void CalcMin();
wxWindow *m_win;
wxSizer *m_sizer;
DECLARE_NO_COPY_CLASS(WrapSizerTestCase)
};
// register in the unnamed registry so that these tests are run by default
CPPUNIT_TEST_SUITE_REGISTRATION( WrapSizerTestCase );
// also include in it's own registry so that these tests can be run alone
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( WrapSizerTestCase, "WrapSizerTestCase" );
// ----------------------------------------------------------------------------
// test initialization
// ----------------------------------------------------------------------------
void WrapSizerTestCase::setUp()
{
m_win = new wxWindow(wxTheApp->GetTopWindow(), wxID_ANY);
m_win->SetClientSize(180, 240);
m_sizer = new wxWrapSizer(wxHORIZONTAL);
m_win->SetSizer(m_sizer);
}
void WrapSizerTestCase::tearDown()
{
delete m_win;
m_win = NULL;
m_sizer = NULL;
}
// ----------------------------------------------------------------------------
// tests themselves
// ----------------------------------------------------------------------------
void WrapSizerTestCase::CalcMin()
{
const wxSize sizeTotal = m_win->GetClientSize();
wxSize sizeMinExpected;
// With a single child the min size must be the same as child size.
const wxSize sizeChild1 = wxSize(sizeTotal.x/2 - 10, sizeTotal.y/4);
sizeMinExpected = sizeChild1;
wxWindow * const
child1 = new wxWindow(m_win, wxID_ANY, wxDefaultPosition, sizeChild1);
child1->SetBackgroundColour(*wxRED);
m_sizer->Add(child1);
m_win->Layout();
CPPUNIT_ASSERT_EQUAL( sizeMinExpected, m_sizer->CalcMin() );
// If both children can fit in the same row, the minimal size of the sizer
// is determined by the sum of their minimal horizontal dimensions and
// the maximum of their minimal vertical dimensions.
const wxSize sizeChild2 = wxSize(sizeTotal.x/2 + 10, sizeTotal.y/3);
sizeMinExpected.x += sizeChild2.x;
sizeMinExpected.y = wxMax(sizeChild1.y, sizeChild2.y);
wxWindow * const
child2 = new wxWindow(m_win, wxID_ANY, wxDefaultPosition, sizeChild2);
child2->SetBackgroundColour(*wxYELLOW);
m_sizer->Add(child2);
m_win->Layout();
CPPUNIT_ASSERT_EQUAL( sizeMinExpected, m_sizer->CalcMin() );
// Three children will take at least two rows so the minimal size in
// vertical direction must increase.
const wxSize sizeChild3 = wxSize(sizeTotal.x/2, sizeTotal.y/5);
sizeMinExpected.y += sizeChild3.y;
wxWindow * const
child3 = new wxWindow(m_win, wxID_ANY, wxDefaultPosition, sizeChild3);
child3->SetBackgroundColour(*wxGREEN);
m_sizer->Add(child3);
m_win->Layout();
CPPUNIT_ASSERT_EQUAL( sizeMinExpected, m_sizer->CalcMin() );
}

View File

@ -199,6 +199,7 @@
--> -->
net/socket.cpp net/socket.cpp
sizers/boxsizer.cpp sizers/boxsizer.cpp
sizers/wrapsizer.cpp
validators/valnum.cpp validators/valnum.cpp
window/clientsize.cpp window/clientsize.cpp
window/setsize.cpp window/setsize.cpp

View File

@ -529,6 +529,10 @@ SOURCE=.\controls\windowtest.cpp
# End Source File # End Source File
# Begin Source File # Begin Source File
SOURCE=.\sizers\wrapsizer.cpp
# End Source File
# Begin Source File
SOURCE=.\xml\xrctest.cpp SOURCE=.\xml\xrctest.cpp
# End Source File # End Source File
# End Group # End Group

View File

@ -830,6 +830,9 @@
RelativePath=".\controls\windowtest.cpp"> RelativePath=".\controls\windowtest.cpp">
</File> </File>
<File <File
RelativePath=".\sizers\wrapsizer.cpp">
</File>
<File
RelativePath=".\xml\xrctest.cpp"> RelativePath=".\xml\xrctest.cpp">
</File> </File>
</Filter> </Filter>

View File

@ -1180,6 +1180,10 @@
> >
</File> </File>
<File <File
RelativePath=".\sizers\wrapsizer.cpp"
>
</File>
<File
RelativePath=".\xml\xrctest.cpp" RelativePath=".\xml\xrctest.cpp"
> >
</File> </File>

View File

@ -1152,6 +1152,10 @@
> >
</File> </File>
<File <File
RelativePath=".\sizers\wrapsizer.cpp"
>
</File>
<File
RelativePath=".\xml\xrctest.cpp" RelativePath=".\xml\xrctest.cpp"
> >
</File> </File>