]> git.saurik.com Git - wxWidgets.git/blob - interface/wx/wrapsizer.h
Refactor wxGTK IM-related code to allow future modifications.
[wxWidgets.git] / interface / wx / wrapsizer.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wrapsizer.h
3 // Purpose: interface of wxWrapSizer
4 // Author: wxWidgets team
5 // RCS-ID: $Id$
6 // Licence: wxWindows licence
7 /////////////////////////////////////////////////////////////////////////////
8
9 // flags for wxWrapSizer
10 enum
11 {
12 wxEXTEND_LAST_ON_EACH_LINE,
13 wxREMOVE_LEADING_SPACES,
14 wxWRAPSIZER_DEFAULT_FLAGS
15 };
16
17 /**
18 @class wxWrapSizer
19
20 A wrap sizer lays out its items in a single line, like a box sizer -- as long
21 as there is space available in that direction.
22 Once all available space in the primary direction has been used, a new line
23 is added and items are added there.
24
25 So a wrap sizer has a primary orientation for adding items, and adds lines
26 as needed in the secondary direction.
27
28 @library{wxcore}
29 @category{winlayout}
30
31 @see wxBoxSizer, wxSizer, @ref overview_sizer
32 */
33 class wxWrapSizer : public wxBoxSizer
34 {
35 public:
36 /**
37 Constructor for a wxWrapSizer.
38
39 @a orient determines the primary direction of the sizer (the most common
40 case being @c wxHORIZONTAL). The flags parameter can be a combination of
41 the values @c wxEXTEND_LAST_ON_EACH_LINE which will cause the last item
42 on each line to use any remaining space on that line and @c wxREMOVE_LEADING_SPACES
43 which removes any spacer elements from the beginning of a row.
44
45 Both of these flags are on by default.
46 */
47 wxWrapSizer(int orient = wxHORIZONTAL,
48 int flags = wxWRAPSIZER_DEFAULT_FLAGS);
49
50 /**
51 Not used by an application.
52
53 This is the mechanism by which sizers can inform sub-items of the first
54 determined size component.
55 The sub-item can then better determine its size requirements.
56
57 Returns @true if the information was used (and the sub-item min size was
58 updated).
59 */
60 virtual bool InformFirstDirection(int direction, int size,
61 int availableOtherDir);
62
63 virtual void RecalcSizes();
64 virtual wxSize CalcMin();
65
66 protected:
67 /**
68 Can be overridden in the derived classes to treat some normal items as
69 spacers.
70
71 This method is used to determine whether the given @a item should be
72 considered to be a spacer for the purposes of @c wxREMOVE_LEADING_SPACES
73 implementation. By default only returns @true for the real spacers.
74 */
75 virtual bool IsSpaceItem(wxSizerItem *item) const;
76 };
77