2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wrapsizer.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxWrapSizer
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
2010-07-13 13:29:13 +00:00
|
|
|
// Licence: wxWindows licence
|
2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2011-12-30 06:14:17 +00:00
|
|
|
// flags for wxWrapSizer
|
|
|
|
enum
|
|
|
|
{
|
|
|
|
wxEXTEND_LAST_ON_EACH_LINE,
|
|
|
|
wxREMOVE_LEADING_SPACES,
|
|
|
|
wxWRAPSIZER_DEFAULT_FLAGS
|
|
|
|
};
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxWrapSizer
|
2008-03-08 14:43:31 +00:00
|
|
|
|
|
|
|
A wrap sizer lays out its items in a single line, like a box sizer -- as long
|
2008-09-27 10:27:44 +00:00
|
|
|
as there is space available in that direction.
|
|
|
|
Once all available space in the primary direction has been used, a new line
|
|
|
|
is added and items are added there.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
So a wrap sizer has a primary orientation for adding items, and adds lines
|
2008-03-08 14:43:31 +00:00
|
|
|
as needed in the secondary direction.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
|
|
|
@category{winlayout}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-09-27 10:27:44 +00:00
|
|
|
@see wxBoxSizer, wxSizer, @ref overview_sizer
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxWrapSizer : public wxBoxSizer
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-09-27 10:27:44 +00:00
|
|
|
Constructor for a wxWrapSizer.
|
|
|
|
|
|
|
|
@a orient determines the primary direction of the sizer (the most common
|
|
|
|
case being @c wxHORIZONTAL). The flags parameter can be a combination of
|
|
|
|
the values @c wxEXTEND_LAST_ON_EACH_LINE which will cause the last item
|
|
|
|
on each line to use any remaining space on that line and @c wxREMOVE_LEADING_SPACES
|
|
|
|
which removes any spacer elements from the beginning of a row.
|
|
|
|
|
|
|
|
Both of these flags are on by default.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-05-08 22:50:40 +00:00
|
|
|
wxWrapSizer(int orient = wxHORIZONTAL,
|
2008-09-27 20:26:28 +00:00
|
|
|
int flags = wxWRAPSIZER_DEFAULT_FLAGS);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-09-27 10:27:44 +00:00
|
|
|
Not used by an application.
|
|
|
|
|
|
|
|
This is the mechanism by which sizers can inform sub-items of the first
|
|
|
|
determined size component.
|
|
|
|
The sub-item can then better determine its size requirements.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
Returns @true if the information was used (and the sub-item min size was
|
|
|
|
updated).
|
|
|
|
*/
|
2008-09-27 20:26:28 +00:00
|
|
|
virtual bool InformFirstDirection(int direction, int size,
|
|
|
|
int availableOtherDir);
|
2011-11-02 20:22:29 +00:00
|
|
|
|
|
|
|
virtual void RecalcSizes();
|
|
|
|
virtual wxSize CalcMin();
|
2008-05-08 22:50:40 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
/**
|
|
|
|
Can be overridden in the derived classes to treat some normal items as
|
|
|
|
spacers.
|
|
|
|
|
|
|
|
This method is used to determine whether the given @a item should be
|
|
|
|
considered to be a spacer for the purposes of @c wxREMOVE_LEADING_SPACES
|
|
|
|
implementation. By default only returns @true for the real spacers.
|
|
|
|
*/
|
|
|
|
virtual bool IsSpaceItem(wxSizerItem *item) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|