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:
parent
8de6a0270d
commit
e4c903b2ea
@ -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:
|
||||||
|
|
||||||
|
@ -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)); }
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
|
||||||
|
@ -198,6 +198,7 @@ TEST_GUI_OBJECTS = \
|
|||||||
$(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_wrapsizer.obj \
|
||||||
$(OBJS)\test_gui_valnum.obj \
|
$(OBJS)\test_gui_valnum.obj \
|
||||||
$(OBJS)\test_gui_clientsize.obj \
|
$(OBJS)\test_gui_clientsize.obj \
|
||||||
$(OBJS)\test_gui_setsize.obj \
|
$(OBJS)\test_gui_setsize.obj \
|
||||||
@ -916,6 +917,9 @@ $(OBJS)\test_gui_socket.obj: .\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_wrapsizer.obj: .\sizers\wrapsizer.cpp
|
||||||
|
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\sizers\wrapsizer.cpp
|
||||||
|
|
||||||
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp
|
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp
|
||||||
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp
|
$(CXX) -q -c -P -o$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp
|
||||||
|
|
||||||
|
@ -191,6 +191,7 @@ TEST_GUI_OBJECTS = \
|
|||||||
$(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_wrapsizer.o \
|
||||||
$(OBJS)\test_gui_valnum.o \
|
$(OBJS)\test_gui_valnum.o \
|
||||||
$(OBJS)\test_gui_clientsize.o \
|
$(OBJS)\test_gui_clientsize.o \
|
||||||
$(OBJS)\test_gui_setsize.o \
|
$(OBJS)\test_gui_setsize.o \
|
||||||
@ -897,6 +898,9 @@ $(OBJS)\test_gui_socket.o: ./net/socket.cpp
|
|||||||
$(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_wrapsizer.o: ./sizers/wrapsizer.cpp
|
||||||
|
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<
|
||||||
|
|
||||||
$(OBJS)\test_gui_valnum.o: ./validators/valnum.cpp
|
$(OBJS)\test_gui_valnum.o: ./validators/valnum.cpp
|
||||||
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<
|
$(CXX) -c -o $@ $(TEST_GUI_CXXFLAGS) $(CPPDEPS) $<
|
||||||
|
|
||||||
|
@ -193,6 +193,7 @@ TEST_GUI_OBJECTS = \
|
|||||||
$(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_wrapsizer.obj \
|
||||||
$(OBJS)\test_gui_valnum.obj \
|
$(OBJS)\test_gui_valnum.obj \
|
||||||
$(OBJS)\test_gui_clientsize.obj \
|
$(OBJS)\test_gui_clientsize.obj \
|
||||||
$(OBJS)\test_gui_setsize.obj \
|
$(OBJS)\test_gui_setsize.obj \
|
||||||
@ -1042,6 +1043,9 @@ $(OBJS)\test_gui_socket.obj: .\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_wrapsizer.obj: .\sizers\wrapsizer.cpp
|
||||||
|
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\sizers\wrapsizer.cpp
|
||||||
|
|
||||||
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp
|
$(OBJS)\test_gui_valnum.obj: .\validators\valnum.cpp
|
||||||
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp
|
$(CXX) /c /nologo /TP /Fo$@ $(TEST_GUI_CXXFLAGS) .\validators\valnum.cpp
|
||||||
|
|
||||||
|
@ -437,6 +437,7 @@ TEST_GUI_OBJECTS = &
|
|||||||
$(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_wrapsizer.obj &
|
||||||
$(OBJS)\test_gui_valnum.obj &
|
$(OBJS)\test_gui_valnum.obj &
|
||||||
$(OBJS)\test_gui_clientsize.obj &
|
$(OBJS)\test_gui_clientsize.obj &
|
||||||
$(OBJS)\test_gui_setsize.obj &
|
$(OBJS)\test_gui_setsize.obj &
|
||||||
@ -956,6 +957,9 @@ $(OBJS)\test_gui_socket.obj : .AUTODEPEND .\net\socket.cpp
|
|||||||
$(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_wrapsizer.obj : .AUTODEPEND .\sizers\wrapsizer.cpp
|
||||||
|
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<
|
||||||
|
|
||||||
$(OBJS)\test_gui_valnum.obj : .AUTODEPEND .\validators\valnum.cpp
|
$(OBJS)\test_gui_valnum.obj : .AUTODEPEND .\validators\valnum.cpp
|
||||||
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<
|
$(CXX) -bt=nt -zq -fo=$^@ $(TEST_GUI_CXXFLAGS) $<
|
||||||
|
|
||||||
|
128
tests/sizers/wrapsizer.cpp
Normal file
128
tests/sizers/wrapsizer.cpp
Normal 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() );
|
||||||
|
}
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -829,6 +829,9 @@
|
|||||||
<File
|
<File
|
||||||
RelativePath=".\controls\windowtest.cpp">
|
RelativePath=".\controls\windowtest.cpp">
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath=".\sizers\wrapsizer.cpp">
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\xml\xrctest.cpp">
|
RelativePath=".\xml\xrctest.cpp">
|
||||||
</File>
|
</File>
|
||||||
|
@ -1179,6 +1179,10 @@
|
|||||||
RelativePath=".\controls\windowtest.cpp"
|
RelativePath=".\controls\windowtest.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath=".\sizers\wrapsizer.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\xml\xrctest.cpp"
|
RelativePath=".\xml\xrctest.cpp"
|
||||||
>
|
>
|
||||||
|
@ -1151,6 +1151,10 @@
|
|||||||
RelativePath=".\controls\windowtest.cpp"
|
RelativePath=".\controls\windowtest.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
|
<File
|
||||||
|
RelativePath=".\sizers\wrapsizer.cpp"
|
||||||
|
>
|
||||||
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\xml\xrctest.cpp"
|
RelativePath=".\xml\xrctest.cpp"
|
||||||
>
|
>
|
||||||
|
Loading…
Reference in New Issue
Block a user