491a5ece42
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@52584 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
1400 lines
44 KiB
Objective-C
1400 lines
44 KiB
Objective-C
/////////////////////////////////////////////////////////////////////////////
|
|
// Name: sizer.h
|
|
// Purpose: interface of wxStdDialogButtonSizer
|
|
// Author: wxWidgets team
|
|
// RCS-ID: $Id$
|
|
// Licence: wxWindows license
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
/**
|
|
@class wxStdDialogButtonSizer
|
|
@wxheader{sizer.h}
|
|
|
|
This class creates button layouts which conform to the standard button spacing
|
|
and ordering defined by the platform
|
|
or toolkit's user interface guidelines (if such things exist). By using this
|
|
class, you can ensure that all your
|
|
standard dialogs look correct on all major platforms. Currently it conforms to
|
|
the Windows, GTK+ and Mac OS X
|
|
human interface guidelines.
|
|
|
|
When there aren't interface guidelines defined for a particular platform or
|
|
toolkit, wxStdDialogButtonSizer reverts
|
|
to the Windows implementation.
|
|
|
|
To use this class, first add buttons to the sizer by calling AddButton (or
|
|
SetAffirmativeButton, SetNegativeButton,
|
|
or SetCancelButton) and then call Realize in order to create the actual button
|
|
layout used. Other than these special
|
|
operations, this sizer works like any other sizer.
|
|
|
|
If you add a button with wxID_SAVE, on Mac OS X the button will be renamed to
|
|
"Save" and
|
|
the wxID_NO button will be renamed to "Don't Save" in accordance with the Mac
|
|
OS X Human Interface Guidelines.
|
|
|
|
@library{wxcore}
|
|
@category{FIXME}
|
|
|
|
@see wxSizer, @ref overview_sizeroverview "Sizer overview",
|
|
wxDialog::CreateButtonSizer
|
|
*/
|
|
class wxStdDialogButtonSizer : public wxBoxSizer
|
|
{
|
|
public:
|
|
/**
|
|
Constructor for a wxStdDialogButtonSizer.
|
|
*/
|
|
wxStdDialogButtonSizer();
|
|
|
|
/**
|
|
Adds a button to the wxStdDialogButtonSizer. The button must have one of the
|
|
following identifiers:
|
|
wxID_OK
|
|
wxID_YES
|
|
wxID_SAVE
|
|
wxID_APPLY
|
|
wxID_CLOSE
|
|
wxID_NO
|
|
wxID_CANCEL
|
|
wxID_HELP
|
|
wxID_CONTEXT_HELP
|
|
*/
|
|
void AddButton(wxButton* button);
|
|
|
|
/**
|
|
Rearranges the buttons and applies proper spacing between buttons to make them
|
|
match the platform or toolkit's interface guidelines.
|
|
*/
|
|
void Realize();
|
|
|
|
/**
|
|
Sets the affirmative button for the sizer. This allows you to use identifiers
|
|
other than the standard identifiers outlined above.
|
|
*/
|
|
void SetAffirmativeButton(wxButton* button);
|
|
|
|
/**
|
|
Sets the cancel button for the sizer. This allows you to use identifiers other
|
|
than the standard identifiers outlined above.
|
|
*/
|
|
void SetCancelButton(wxButton* button);
|
|
|
|
/**
|
|
Sets the negative button for the sizer. This allows you to use identifiers
|
|
other than the standard identifiers outlined above.
|
|
*/
|
|
void SetNegativeButton(wxButton* button);
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxSizerItem
|
|
@wxheader{sizer.h}
|
|
|
|
The wxSizerItem class is used to track the position, size and other
|
|
attributes of each item managed by a wxSizer. It is not
|
|
usually necessary to use this class because the sizer elements can also be
|
|
identified by their positions or window or sizer pointers but sometimes it may
|
|
be more convenient to use it directly.
|
|
|
|
@library{wxcore}
|
|
@category{FIXME}
|
|
*/
|
|
class wxSizerItem : public wxObject
|
|
{
|
|
public:
|
|
//@{
|
|
/**
|
|
Construct a sizer item for tracking a subsizer.
|
|
*/
|
|
wxSizerItem(int width, int height, int proportion, int flag,
|
|
int border, wxObject* userData);
|
|
wxSizerItem(wxWindow* window, const wxSizerFlags& flags);
|
|
wxSizerItem(wxWindow* window, int proportion, int flag,
|
|
int border,
|
|
wxObject* userData);
|
|
wxSizerItem(wxSizer* window, const wxSizerFlags& flags);
|
|
wxSizerItem(wxSizer* sizer, int proportion, int flag,
|
|
int border,
|
|
wxObject* userData);
|
|
//@}
|
|
|
|
/**
|
|
Deletes the user data and subsizer, if any.
|
|
*/
|
|
~wxSizerItem();
|
|
|
|
/**
|
|
Calculates the minimum desired size for the item, including any space
|
|
needed by borders.
|
|
*/
|
|
wxSize CalcMin();
|
|
|
|
/**
|
|
Destroy the window or the windows in a subsizer, depending on the type
|
|
of item.
|
|
*/
|
|
void DeleteWindows();
|
|
|
|
/**
|
|
Enable deleting the SizerItem without destroying the contained sizer.
|
|
*/
|
|
void DetachSizer();
|
|
|
|
/**
|
|
Return the border attribute.
|
|
*/
|
|
int GetBorder() const;
|
|
|
|
/**
|
|
Return the flags attribute.
|
|
*/
|
|
int GetFlag() const;
|
|
|
|
/**
|
|
Return the numeric id of wxSizerItem, or @c wxID_NONE if the id has
|
|
not been set.
|
|
*/
|
|
int GetId() const;
|
|
|
|
/**
|
|
Get the minimum size needed for the item.
|
|
*/
|
|
wxSize GetMinSize() const;
|
|
|
|
/**
|
|
What is the current position of the item, as set in the last Layout.
|
|
*/
|
|
wxPoint GetPosition() const;
|
|
|
|
/**
|
|
Get the proportion item attribute.
|
|
*/
|
|
int GetProportion() const;
|
|
|
|
/**
|
|
Get the ration item attribute.
|
|
*/
|
|
float GetRatio() const;
|
|
|
|
/**
|
|
Get the rectangle of the item on the parent window, excluding borders.
|
|
*/
|
|
wxRect GetRect();
|
|
|
|
/**
|
|
Get the current size of the item, as set in the last Layout.
|
|
*/
|
|
wxSize GetSize() const;
|
|
|
|
/**
|
|
If this item is tracking a sizer, return it. @NULL otherwise.
|
|
*/
|
|
wxSizer* GetSizer() const;
|
|
|
|
/**
|
|
If this item is tracking a spacer, return its size.
|
|
*/
|
|
const wxSize GetSpacer() const;
|
|
|
|
/**
|
|
Get the userData item attribute.
|
|
*/
|
|
wxObject* GetUserData() const;
|
|
|
|
/**
|
|
If this item is tracking a window then return it. @NULL otherwise.
|
|
*/
|
|
wxWindow* GetWindow() const;
|
|
|
|
/**
|
|
Returns @true if this item is a window or a spacer and it is shown or if this
|
|
item is a sizer and not all its elements are hidden. In other words, for sizer
|
|
items, all of the child elements must be hidden for the sizer itself to be
|
|
considered hidden.
|
|
*/
|
|
bool IsShown() const;
|
|
|
|
/**
|
|
Is this item a sizer?
|
|
*/
|
|
bool IsSizer() const;
|
|
|
|
/**
|
|
Is this item a spacer?
|
|
*/
|
|
bool IsSpacer() const;
|
|
|
|
/**
|
|
Is this item a window?
|
|
*/
|
|
bool IsWindow() const;
|
|
|
|
/**
|
|
Set the border item attribute.
|
|
*/
|
|
void SetBorder(int border);
|
|
|
|
/**
|
|
Set the position and size of the space allocated to the sizer, and
|
|
adjust the position and size of the item to be within that space
|
|
taking alignment and borders into account.
|
|
*/
|
|
void SetDimension(const wxPoint& pos, const wxSize& size);
|
|
|
|
/**
|
|
Set the flag item attribute.
|
|
*/
|
|
void SetFlag(int flag);
|
|
|
|
/**
|
|
Sets the numeric id of the wxSizerItem to @e id.
|
|
*/
|
|
void SetId(int id);
|
|
|
|
/**
|
|
|
|
*/
|
|
void SetInitSize(int x, int y);
|
|
|
|
/**
|
|
Set the proportion item attribute.
|
|
*/
|
|
void SetProportion(int proportion);
|
|
|
|
//@{
|
|
/**
|
|
Set the ratio item attribute.
|
|
*/
|
|
void SetRatio(int width, int height);
|
|
void SetRatio(wxSize size);
|
|
void SetRatio(float ratio);
|
|
//@}
|
|
|
|
/**
|
|
Set the sizer tracked by this item.
|
|
*/
|
|
void SetSizer(wxSizer* sizer);
|
|
|
|
/**
|
|
Set the size of the spacer tracked by this item.
|
|
*/
|
|
void SetSpacer(const wxSize& size);
|
|
|
|
/**
|
|
Set the window to be tracked by thsi item.
|
|
*/
|
|
void SetWindow(wxWindow* window);
|
|
|
|
/**
|
|
Set the show item attribute, which sizers use to determine if the item
|
|
is to be made part of the layout or not. If the item is tracking a
|
|
window then it is shown or hidden as needed.
|
|
*/
|
|
void Show(bool show);
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxSizerFlags
|
|
@wxheader{sizer.h}
|
|
|
|
Normally, when you add an item to a sizer via
|
|
wxSizer::Add, you have to specify a lot of flags and
|
|
parameters which can be unwieldy. This is where wxSizerFlags comes in: it
|
|
allows you to specify all parameters using the named methods instead. For
|
|
example, instead of
|
|
|
|
@code
|
|
sizer-Add(ctrl, 0, wxEXPAND | wxALL, 10);
|
|
@endcode
|
|
|
|
you can now write
|
|
|
|
@code
|
|
sizer-Add(ctrl, wxSizerFlags().Expand().Border(10));
|
|
@endcode
|
|
|
|
This is more readable and also allows you to create wxSizerFlags objects which
|
|
can be reused for several sizer items.
|
|
|
|
@code
|
|
wxSizerFlags flagsExpand(1);
|
|
flagsExpand.Expand().Border(10);
|
|
|
|
sizer-Add(ctrl1, flagsExpand);
|
|
sizer-Add(ctrl2, flagsExpand);
|
|
@endcode
|
|
|
|
Note that by specification, all methods of wxSizerFlags return the wxSizerFlags
|
|
object itself to allowing chaining multiple methods calls like in the examples
|
|
above.
|
|
|
|
@library{wxcore}
|
|
@category{FIXME}
|
|
|
|
@see wxSizer
|
|
*/
|
|
class wxSizerFlags
|
|
{
|
|
public:
|
|
/**
|
|
Creates the wxSizer with the proportion specified by @e proportion.
|
|
*/
|
|
wxSizerFlags(int proportion = 0);
|
|
|
|
/**
|
|
Sets the alignment of this wxSizerFlags to @e align.
|
|
Note that if this method is not called, the wxSizerFlags has no specified
|
|
alignment.
|
|
|
|
@see Top(), Left(), Right(),
|
|
Bottom(), Centre()
|
|
*/
|
|
wxSizerFlags Align(int align = 0);
|
|
|
|
//@{
|
|
/**
|
|
Sets the wxSizerFlags to have a border of a number of pixels specified by
|
|
@a borderinpixels with the directions specified by @e direction.
|
|
In the overloaded version without @a borderinpixels parameter, the border of
|
|
default size, as returned by GetDefaultBorder(),
|
|
is used.
|
|
*/
|
|
wxSizerFlags Border(int direction, int borderinpixels);
|
|
wxSizerFlags Border(int direction = wxALL);
|
|
//@}
|
|
|
|
/**
|
|
Aligns the object to the bottom, shortcut for @c Align(wxALIGN_BOTTOM)
|
|
|
|
@see Align()
|
|
*/
|
|
wxSizerFlags Bottom();
|
|
|
|
/**
|
|
Sets the object of the wxSizerFlags to center itself in the area it is given.
|
|
*/
|
|
wxSizerFlags Center();
|
|
|
|
/**
|
|
Center() for people with the other dialect of english.
|
|
*/
|
|
wxSizerFlags Centre();
|
|
|
|
/**
|
|
Sets the border in the given @a direction having twice the default border
|
|
size.
|
|
*/
|
|
wxSizerFlags DoubleBorder(int direction = wxALL);
|
|
|
|
/**
|
|
Sets the border in left and right directions having twice the default border
|
|
size.
|
|
*/
|
|
wxSizerFlags DoubleHorzBorder();
|
|
|
|
/**
|
|
Sets the object of the wxSizerFlags to expand to fill as much area as it can.
|
|
*/
|
|
wxSizerFlags Expand();
|
|
|
|
/**
|
|
Set the @c wxFIXED_MINSIZE flag which indicates that the initial size of
|
|
the window should be also set as its minimal size.
|
|
*/
|
|
wxSizerFlags FixedMinSize();
|
|
|
|
/**
|
|
Returns the border used by default in Border() method.
|
|
*/
|
|
static int GetDefaultBorder();
|
|
|
|
/**
|
|
Aligns the object to the left, shortcut for @c Align(wxALIGN_LEFT)
|
|
|
|
@see Align()
|
|
*/
|
|
wxSizerFlags Left();
|
|
|
|
/**
|
|
Sets the proportion of this wxSizerFlags to @e proportion
|
|
*/
|
|
wxSizerFlags Proportion(int proportion = 0);
|
|
|
|
/**
|
|
Aligns the object to the right, shortcut for @c Align(wxALIGN_RIGHT)
|
|
|
|
@see Align()
|
|
*/
|
|
wxSizerFlags Right();
|
|
|
|
/**
|
|
Set the @c wx_SHAPED flag which indicates that the elements should
|
|
always keep the fixed width to height ratio equal to its original value.
|
|
*/
|
|
wxSizerFlags Shaped();
|
|
|
|
/**
|
|
Aligns the object to the top, shortcut for @c Align(wxALIGN_TOP)
|
|
|
|
@see Align()
|
|
*/
|
|
wxSizerFlags Top();
|
|
|
|
/**
|
|
Sets the border in the given @a direction having thrice the default border
|
|
size.
|
|
*/
|
|
wxSizerFlags TripleBorder(int direction = wxALL);
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxNotebookSizer
|
|
@wxheader{sizer.h}
|
|
|
|
@b This class is deprecated and should not be used in new code! It is no
|
|
longer needed, wxNotebook control can be inserted
|
|
into any sizer class and its minimal size will be determined correctly.
|
|
See @ref overview_sizeroverview "wxSizer overview" for more information.
|
|
|
|
wxNotebookSizer is a specialized sizer to make sizers work in connection
|
|
with using notebooks. This sizer is different from any other sizer as
|
|
you must not add any children to it - instead, it queries the notebook class
|
|
itself.
|
|
The only thing this sizer does is to determine the size of the biggest
|
|
page of the notebook and report an adjusted minimal size to a more toplevel
|
|
sizer.
|
|
|
|
@library{wxbase}
|
|
@category{FIXME}
|
|
|
|
@see wxSizer, wxNotebook, @ref overview_sizeroverview "Sizer overview"
|
|
*/
|
|
class wxNotebookSizer : public wxSizer
|
|
{
|
|
public:
|
|
/**
|
|
Constructor. It takes an associated notebook as its only parameter.
|
|
*/
|
|
wxNotebookSizer(wxNotebook* notebook);
|
|
|
|
/**
|
|
Returns the notebook associated with the sizer.
|
|
*/
|
|
wxNotebook* GetNotebook();
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxFlexGridSizer
|
|
@wxheader{sizer.h}
|
|
|
|
A flex grid sizer is a sizer which lays out its children in a two-dimensional
|
|
table with all table fields in one row having the same
|
|
height and all fields in one column having the same width, but all
|
|
rows or all columns are not necessarily the same height or width as in
|
|
the wxGridSizer.
|
|
|
|
Since wxWidgets 2.5.0, wxFlexGridSizer can also size items equally in one
|
|
direction but unequally ("flexibly") in the other. If the sizer is only
|
|
flexible in one direction (this can be changed using
|
|
wxFlexGridSizer::SetFlexibleDirection),
|
|
it needs to be decided how the sizer should grow in the other ("non-flexible")
|
|
direction in order to fill the available space. The
|
|
wxFlexGridSizer::SetNonFlexibleGrowMode method
|
|
serves this purpose.
|
|
|
|
@library{wxcore}
|
|
@category{winlayout}
|
|
|
|
@see wxSizer, @ref overview_sizeroverview "Sizer overview"
|
|
*/
|
|
class wxFlexGridSizer : public wxGridSizer
|
|
{
|
|
public:
|
|
//@{
|
|
/**
|
|
Constructor for a wxGridSizer. @a rows and @a cols determine the number of
|
|
columns and rows in the sizer - if either of the parameters is zero, it will be
|
|
calculated to form the total number of children in the sizer, thus making the
|
|
sizer grow dynamically. @a vgap and @a hgap define extra space between
|
|
all children.
|
|
*/
|
|
wxFlexGridSizer(int rows, int cols, int vgap, int hgap);
|
|
wxFlexGridSizer(int cols, int vgap = 0, int hgap = 0);
|
|
//@}
|
|
|
|
/**
|
|
Specifies that column @a idx (starting from zero) should be grown if
|
|
there is extra space available to the sizer.
|
|
The @a proportion parameter has the same meaning as the stretch factor for
|
|
the sizers() except that if all proportions are 0,
|
|
then all columns are resized equally (instead of not being resized at all).
|
|
*/
|
|
void AddGrowableCol(size_t idx, int proportion = 0);
|
|
|
|
/**
|
|
Specifies that row idx (starting from zero) should be grown if there
|
|
is extra space available to the sizer.
|
|
See AddGrowableCol() for the description
|
|
of @a proportion parameter.
|
|
*/
|
|
void AddGrowableRow(size_t idx, int proportion = 0);
|
|
|
|
/**
|
|
Returns a wxOrientation value that specifies whether the sizer flexibly
|
|
resizes its columns, rows, or both (default).
|
|
|
|
@returns One of the following values:
|
|
|
|
@see SetFlexibleDirection()
|
|
*/
|
|
int GetFlexibleDirection() const;
|
|
|
|
/**
|
|
Returns the value that specifies how the sizer grows in the "non-flexible"
|
|
direction if there is one.
|
|
|
|
@returns One of the following values:
|
|
|
|
@see SetFlexibleDirection(),
|
|
SetNonFlexibleGrowMode()
|
|
*/
|
|
int GetNonFlexibleGrowMode() const;
|
|
|
|
/**
|
|
Specifies that column idx is no longer growable.
|
|
*/
|
|
void RemoveGrowableCol(size_t idx);
|
|
|
|
/**
|
|
Specifies that row idx is no longer growable.
|
|
*/
|
|
void RemoveGrowableRow(size_t idx);
|
|
|
|
/**
|
|
Specifies whether the sizer should flexibly resize its columns, rows, or
|
|
both. Argument @c direction can be @c wxVERTICAL, @c wxHORIZONTAL
|
|
or @c wxBOTH (which is the default value). Any other value is ignored. See
|
|
@ref getflexibledrection() GetFlexibleDirection for the
|
|
explanation of these values.
|
|
Note that this method does not trigger relayout.
|
|
*/
|
|
void SetFlexibleDirection(int direction);
|
|
|
|
/**
|
|
Specifies how the sizer should grow in the non-flexible direction if
|
|
there is one (so
|
|
SetFlexibleDirection() must have
|
|
been called previously). Argument @a mode can be one of those documented in
|
|
GetNonFlexibleGrowMode(), please
|
|
see there for their explanation.
|
|
Note that this method does not trigger relayout.
|
|
*/
|
|
void SetNonFlexibleGrowMode(wxFlexSizerGrowMode mode);
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxSizer
|
|
@wxheader{sizer.h}
|
|
|
|
wxSizer is the abstract base class used for laying out subwindows in a window.
|
|
You
|
|
cannot use wxSizer directly; instead, you will have to use one of the sizer
|
|
classes derived from it. Currently there are wxBoxSizer,
|
|
wxStaticBoxSizer,
|
|
wxGridSizer,
|
|
wxFlexGridSizer,
|
|
wxWrapSizer
|
|
and wxGridBagSizer.
|
|
|
|
The layout algorithm used by sizers in wxWidgets is closely related to layout
|
|
in other GUI toolkits, such as Java's AWT, the GTK toolkit or the Qt toolkit.
|
|
It is
|
|
based upon the idea of the individual subwindows reporting their minimal
|
|
required
|
|
size and their ability to get stretched if the size of the parent window has
|
|
changed.
|
|
This will most often mean that the programmer does not set the original size of
|
|
a dialog in the beginning, rather the dialog will be assigned a sizer and this
|
|
sizer
|
|
will be queried about the recommended size. The sizer in turn will query its
|
|
children, which can be normal windows, empty space or other sizers, so that
|
|
a hierarchy of sizers can be constructed. Note that wxSizer does not derive
|
|
from wxWindow
|
|
and thus does not interfere with tab ordering and requires very little
|
|
resources compared
|
|
to a real window on screen.
|
|
|
|
What makes sizers so well fitted for use in wxWidgets is the fact that every
|
|
control
|
|
reports its own minimal size and the algorithm can handle differences in font
|
|
sizes
|
|
or different window (dialog item) sizes on different platforms without
|
|
problems. If e.g.
|
|
the standard font as well as the overall design of Motif widgets requires more
|
|
space than
|
|
on Windows, the initial dialog size will automatically be bigger on Motif than
|
|
on Windows.
|
|
|
|
Sizers may also be used to control the layout of custom drawn items on the
|
|
window. The
|
|
Add, Insert, and Prepend functions return a pointer to the newly added
|
|
wxSizerItem. Just
|
|
add empty space of the desired size and attributes, and then use the
|
|
wxSizerItem::GetRect
|
|
method to determine where the drawing operations should take place.
|
|
|
|
Please notice that sizers, like child windows, are owned by the library and
|
|
will be deleted by it which implies that they must be allocated on the heap.
|
|
However if you create a sizer and do not add it to another sizer or window, the
|
|
library wouldn't be able to delete such an orphan sizer and in this, and only
|
|
this, case it should be deleted explicitly.
|
|
|
|
@b wxPython note: If you wish to create a sizer class in wxPython you should
|
|
derive the class from @c wxPySizer in order to get Python-aware
|
|
capabilities for the various virtual methods.
|
|
|
|
@library{wxcore}
|
|
@category{winlayout}
|
|
|
|
@see @ref overview_sizeroverview "Sizer overview"
|
|
*/
|
|
class wxSizer : public wxObject
|
|
{
|
|
public:
|
|
/**
|
|
The constructor. Note that wxSizer is an abstract base class and may not
|
|
be instantiated.
|
|
*/
|
|
wxSizer();
|
|
|
|
/**
|
|
The destructor.
|
|
*/
|
|
~wxSizer();
|
|
|
|
//@{
|
|
/**
|
|
Appends a child to the sizer. wxSizer itself is an abstract class, but the
|
|
parameters are
|
|
equivalent in the derived classes that you will instantiate to use it so they
|
|
are described
|
|
here:
|
|
|
|
@param window
|
|
The window to be added to the sizer. Its initial size (either set
|
|
explicitly by the
|
|
user or calculated internally when using wxDefaultSize) is interpreted as
|
|
the minimal and in many
|
|
cases also the initial size.
|
|
@param sizer
|
|
The (child-)sizer to be added to the sizer. This allows placing a child
|
|
sizer in a
|
|
sizer and thus to create hierarchies of sizers (typically a vertical box as
|
|
the top sizer and several
|
|
horizontal boxes on the level beneath).
|
|
@param width and height
|
|
The dimension of a spacer to be added to the sizer. Adding spacers to sizers
|
|
gives more flexibility in the design of dialogs; imagine for example a
|
|
horizontal box with two buttons at the
|
|
bottom of a dialog: you might want to insert a space between the two
|
|
buttons and make that space stretchable
|
|
using the proportion flag and the result will be that the left button will
|
|
be aligned with the left
|
|
side of the dialog and the right button with the right side - the space in
|
|
between will shrink and grow with
|
|
the dialog.
|
|
@param proportion
|
|
Although the meaning of this parameter is undefined in wxSizer, it is used
|
|
in wxBoxSizer
|
|
to indicate if a child of a sizer can change its size in the main
|
|
orientation of the wxBoxSizer - where
|
|
0 stands for not changeable and a value of more than zero is interpreted
|
|
relative to the value of other
|
|
children of the same wxBoxSizer. For example, you might have a horizontal
|
|
wxBoxSizer with three children, two
|
|
of which are supposed to change their size with the sizer. Then the two
|
|
stretchable windows would get a
|
|
value of 1 each to make them grow and shrink equally with the sizer's
|
|
horizontal dimension.
|
|
@param flag
|
|
This parameter can be used to set a number of flags
|
|
which can be combined using the binary OR operator |. Two main
|
|
behaviours are defined using these flags. One is the border around a
|
|
window: the border parameter determines the border width whereas
|
|
the flags given here determine which side(s) of the item that the
|
|
border will be added. The other flags determine how the sizer item
|
|
behaves when the space allotted to the sizer changes, and is somewhat
|
|
dependent on the specific kind of sizer used.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
wxTOP
|
|
|
|
wxBOTTOM
|
|
|
|
wxLEFT
|
|
|
|
wxRIGHT
|
|
|
|
wxALL
|
|
|
|
|
|
|
|
|
|
These flags are used to specify which side(s) of
|
|
the sizer item the border width will apply to.
|
|
|
|
|
|
|
|
|
|
|
|
wxEXPAND
|
|
|
|
|
|
|
|
|
|
The item will be expanded to fill
|
|
the space assigned to the item.
|
|
|
|
|
|
|
|
|
|
|
|
wxSHAPED
|
|
|
|
|
|
|
|
|
|
The item will be expanded as much
|
|
as possible while also maintaining its aspect ratio
|
|
|
|
|
|
|
|
|
|
|
|
wxFIXED_MINSIZE
|
|
|
|
|
|
|
|
|
|
Normally wxSizers will use
|
|
GetAdjustedBestSize to
|
|
determine what the minimal size of window items should be, and will
|
|
use that size to calculate the layout. This allows layouts to
|
|
adjust when an item changes and its best size becomes
|
|
different. If you would rather have a window item stay the size it
|
|
started with then use wxFIXED_MINSIZE.
|
|
|
|
|
|
|
|
|
|
|
|
wxALIGN_CENTER wxALIGN_CENTRE
|
|
|
|
wxALIGN_LEFT
|
|
|
|
wxALIGN_RIGHT
|
|
|
|
wxALIGN_TOP
|
|
|
|
wxALIGN_BOTTOM
|
|
|
|
wxALIGN_CENTER_VERTICAL wxALIGN_CENTRE_VERTICAL
|
|
|
|
wxALIGN_CENTER_HORIZONTAL wxALIGN_CENTRE_HORIZONTAL
|
|
|
|
|
|
|
|
|
|
The wxALIGN flags allow you to
|
|
specify the alignment of the item within the space allotted to it by
|
|
the sizer, adjusted for the border if any.
|
|
@param border
|
|
Determines the border width, if the flag
|
|
parameter is set to include any border flag.
|
|
@param userData
|
|
Allows an extra object to be attached to the sizer
|
|
item, for use in derived classes when sizing information is more
|
|
complex than the proportion and flag will allow for.
|
|
@param flags
|
|
A wxSizerFlags object that
|
|
enables you to specify most of the above parameters more conveniently.
|
|
*/
|
|
wxSizerItem* Add(wxWindow* window, const wxSizerFlags& flags);
|
|
wxSizerItem* Add(wxWindow* window, int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
wxSizerItem* Add(wxSizer* sizer, const wxSizerFlags& flags);
|
|
wxSizerItem* Add(wxSizer* sizer, int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
wxSizerItem* Add(int width, int height, int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
//@}
|
|
|
|
/**
|
|
Adds non-stretchable space to the sizer. More readable way of calling
|
|
wxSizer::Add(size, size, 0).
|
|
*/
|
|
wxSizerItem* AddSpacer(int size);
|
|
|
|
/**
|
|
Adds stretchable space to the sizer. More readable way of calling
|
|
wxSizer::Add(0, 0, prop).
|
|
*/
|
|
wxSizerItem* AddStretchSpacer(int prop = 1);
|
|
|
|
/**
|
|
This method is abstract and has to be overwritten by any derived class.
|
|
Here, the sizer will do the actual calculation of its children's minimal sizes.
|
|
*/
|
|
wxSize CalcMin();
|
|
|
|
/**
|
|
Detaches all children from the sizer. If @a delete_windows is @true then
|
|
child windows will also be deleted.
|
|
*/
|
|
void Clear(bool delete_windows = false);
|
|
|
|
/**
|
|
Computes client area size for @a window so that it matches the sizer's
|
|
minimal size. Unlike GetMinSize(), this method accounts for other
|
|
constraints imposed on @e window, namely display's size (returned size
|
|
will never be too large for the display) and maximum window size if
|
|
previously set by wxWindow::SetMaxSize(). The returned value is
|
|
suitable for passing to wxWindow::SetClientSize() or
|
|
wxWindow::SetMinClientSize().
|
|
|
|
@since 2.8.8
|
|
|
|
@see ComputeFittingWindowSize(), Fit()
|
|
*/
|
|
wxSize ComputeFittingClientSize(wxWindow* window);
|
|
|
|
/**
|
|
Like ComputeFittingClientSize(), but converts the result into window
|
|
size. The returned value is suitable for passing to wxWindow::SetSize()
|
|
or wxWindow::SetMinSize().
|
|
|
|
@since 2.8.8
|
|
|
|
@see ComputeFittingClientSize(), Fit()
|
|
*/
|
|
wxSize ComputeFittingWindowSize(wxWindow* window);
|
|
|
|
//@{
|
|
/**
|
|
Detach a child from the sizer without destroying it. @a window is the window to
|
|
be
|
|
detached, @a sizer is the equivalent sizer and @a index is the position of
|
|
the child in the sizer, typically 0 for the first item. This method does not
|
|
cause any layout or resizing to take place, call Layout()
|
|
to update the layout "on screen" after detaching a child from the sizer.
|
|
Returns @true if the child item was found and detached, @false otherwise.
|
|
|
|
@see Remove()
|
|
*/
|
|
bool Detach(wxWindow* window);
|
|
bool Detach(wxSizer* sizer);
|
|
bool Detach(size_t index);
|
|
//@}
|
|
|
|
/**
|
|
Tell the sizer to resize the @a window so that its client area matches the
|
|
sizer's minimal size
|
|
(ComputeFittingClientSize() is called
|
|
to determine it).
|
|
This is commonly done in the constructor of the window
|
|
itself, see sample in the description
|
|
of wxBoxSizer. Returns the new window size.
|
|
|
|
@see ComputeFittingClientSize(), ComputeFittingWindowSize()
|
|
*/
|
|
wxSize Fit(wxWindow* window);
|
|
|
|
/**
|
|
Tell the sizer to resize the virtual size of the @a window to match the sizer's
|
|
minimal size. This will not alter the on screen size of the window, but may
|
|
cause
|
|
the addition/removal/alteration of scrollbars required to view the virtual area
|
|
in
|
|
windows which manage it.
|
|
|
|
@see wxScrolledWindow::SetScrollbars, SetVirtualSizeHints()
|
|
*/
|
|
void FitInside(wxWindow* window);
|
|
|
|
//@{
|
|
/**
|
|
Returns the list of the items in this sizer. The elements of type-safe
|
|
wxList @c wxSizerItemList are objects of type
|
|
@ref overview_wxsizeritem "wxSizerItem *".
|
|
*/
|
|
const wxSizerItemList GetChildren();
|
|
const wxSizerItemList GetChildren();
|
|
//@}
|
|
|
|
/**
|
|
Returns the window this sizer is used in or @NULL if none.
|
|
*/
|
|
wxWindow* GetContainingWindow() const;
|
|
|
|
//@{
|
|
/**
|
|
Finds item of the sizer which holds given @e window, @a sizer or is located
|
|
in sizer at position @e index.
|
|
Use parameter @a recursive to search in subsizers too.
|
|
Returns pointer to item or @NULL.
|
|
*/
|
|
wxSizerItem* GetItem(wxWindow* window, bool recursive = false);
|
|
wxSizerItem* GetItem(wxSizer* sizer, bool recursive = false);
|
|
wxSizerItem* GetItem(size_t index);
|
|
//@}
|
|
|
|
/**
|
|
Finds item of the sizer which has the given @e id. This @a id is not the
|
|
window id but the id of the wxSizerItem itself. This is mainly useful for
|
|
retrieving the sizers created from XRC resources.
|
|
Use parameter @a recursive to search in subsizers too.
|
|
Returns pointer to item or @NULL.
|
|
*/
|
|
wxSizerItem* GetItemById(int id, bool recursive = false);
|
|
|
|
/**
|
|
Returns the minimal size of the sizer. This is either the combined minimal
|
|
size of all the children and their borders or the minimal size set by
|
|
SetMinSize(), depending on which is bigger.
|
|
Note that the returned value is client size, not window size.
|
|
In particular, if you use the value to set toplevel window's minimal or
|
|
actual size, use wxWindow::SetMinClientSize
|
|
or wxWindow::SetClientSize, not
|
|
wxWindow::SetMinSize
|
|
or wxWindow::SetSize.
|
|
*/
|
|
wxSize GetMinSize();
|
|
|
|
/**
|
|
Returns the current position of the sizer.
|
|
*/
|
|
wxPoint GetPosition();
|
|
|
|
/**
|
|
Returns the current size of the sizer.
|
|
*/
|
|
wxSize GetSize();
|
|
|
|
//@{
|
|
/**
|
|
Hides the @e window, @e sizer, or item at @e index.
|
|
To make a sizer item disappear, use Hide() followed by Layout().
|
|
Use parameter @a recursive to hide elements found in subsizers.
|
|
Returns @true if the child item was found, @false otherwise.
|
|
|
|
@see IsShown(), Show()
|
|
*/
|
|
bool Hide(wxWindow* window, bool recursive = false);
|
|
bool Hide(wxSizer* sizer, bool recursive = false);
|
|
bool Hide(size_t index);
|
|
//@}
|
|
|
|
//@{
|
|
/**
|
|
Insert a child into the sizer before any existing item at
|
|
|
|
See Add() for the meaning of the other parameters.
|
|
|
|
@param index.
|
|
|
|
index
|
|
The position this child should assume in the sizer.
|
|
*/
|
|
wxSizerItem* Insert(size_t index, wxWindow* window,
|
|
const wxSizerFlags& flags);
|
|
wxSizerItem* Insert(size_t index, wxWindow* window,
|
|
int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
wxSizerItem* Insert(size_t index, wxSizer* sizer,
|
|
const wxSizerFlags& flags);
|
|
wxSizerItem* Insert(size_t index, wxSizer* sizer,
|
|
int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
wxSizerItem* Insert(size_t index, int width, int height,
|
|
int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
//@}
|
|
|
|
/**
|
|
Inserts non-stretchable space to the sizer. More readable way of calling
|
|
wxSizer::Insert(size, size, 0).
|
|
*/
|
|
wxSizerItem* InsertSpacer(size_t index, int size);
|
|
|
|
/**
|
|
Inserts stretchable space to the sizer. More readable way of calling
|
|
wxSizer::Insert(0, 0, prop).
|
|
*/
|
|
wxSizerItem* InsertStretchSpacer(size_t index, int prop = 1);
|
|
|
|
//@{
|
|
/**
|
|
Returns @true if the @e window, @e sizer, or item at @a index is shown.
|
|
|
|
@see Hide(), Show()
|
|
*/
|
|
bool IsShown(wxWindow* window) const;
|
|
const bool IsShown(wxSizer* sizer) const;
|
|
const bool IsShown(size_t index) const;
|
|
//@}
|
|
|
|
/**
|
|
Call this to force layout of the children anew, e.g. after having added a child
|
|
to or removed a child (window, other sizer or space) from the sizer while
|
|
keeping
|
|
the current dimension.
|
|
*/
|
|
void Layout();
|
|
|
|
//@{
|
|
/**
|
|
Same as Add(), but prepends the items to the beginning of the
|
|
list of items (windows, subsizers or spaces) owned by this sizer.
|
|
*/
|
|
wxSizerItem* Prepend(wxWindow* window, const wxSizerFlags& flags);
|
|
wxSizerItem* Prepend(wxWindow* window, int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
wxSizerItem* Prepend(wxSizer* sizer,
|
|
const wxSizerFlags& flags);
|
|
wxSizerItem* Prepend(wxSizer* sizer, int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
wxSizerItem* Prepend(int width, int height,
|
|
int proportion = 0,
|
|
int flag = 0,
|
|
int border = 0,
|
|
wxObject* userData = NULL);
|
|
//@}
|
|
|
|
/**
|
|
Prepends non-stretchable space to the sizer. More readable way of calling
|
|
wxSizer::Prepend(size, size, 0).
|
|
*/
|
|
wxSizerItem* PrependSpacer(int size);
|
|
|
|
/**
|
|
Prepends stretchable space to the sizer. More readable way of calling
|
|
wxSizer::Prepend(0, 0, prop).
|
|
*/
|
|
wxSizerItem* PrependStretchSpacer(int prop = 1);
|
|
|
|
/**
|
|
This method is abstract and has to be overwritten by any derived class.
|
|
Here, the sizer will do the actual calculation of its children's positions
|
|
and sizes.
|
|
*/
|
|
void RecalcSizes();
|
|
|
|
//@{
|
|
/**
|
|
Removes a child from the sizer and destroys it if it is a sizer or a spacer,
|
|
but not if it is a window (because windows are owned by their parent window,
|
|
not the sizer). @a sizer is the wxSizer to be removed,
|
|
@a index is the position of the child in the sizer, e.g. 0 for the first item.
|
|
This method does not cause any layout or resizing to take place, call
|
|
Layout() to update the layout "on screen" after removing a
|
|
child from the sizer.
|
|
@b NB: The method taking a wxWindow* parameter is deprecated as it does not
|
|
destroy the window as would usually be expected from Remove. You should use
|
|
Detach() in new code instead. There is
|
|
currently no wxSizer method that will both detach and destroy a wxWindow item.
|
|
Returns @true if the child item was found and removed, @false otherwise.
|
|
*/
|
|
bool Remove(wxWindow* window);
|
|
bool Remove(wxSizer* sizer);
|
|
bool Remove(size_t index);
|
|
//@}
|
|
|
|
//@{
|
|
/**
|
|
Detaches the given @e oldwin, @a oldsz child from the sizer and
|
|
replaces it with the given window, sizer, or wxSizerItem.
|
|
The detached child is removed @b only if it is a sizer or a spacer
|
|
(because windows are owned by their parent window, not the sizer).
|
|
Use parameter @a recursive to search the given element recursively in subsizers.
|
|
|
|
This method does not cause any layout or resizing to take place, call
|
|
Layout() to update the layout "on screen" after replacing a
|
|
child from the sizer.
|
|
Returns @true if the child item was found and removed, @false otherwise.
|
|
*/
|
|
bool Replace(wxWindow* oldwin, wxWindow* newwin,
|
|
bool recursive = false);
|
|
bool Replace(wxSizer* oldsz, wxSizer* newsz,
|
|
bool recursive = false);
|
|
bool Remove(size_t oldindex, wxSizerItem* newitem);
|
|
//@}
|
|
|
|
/**
|
|
Call this to force the sizer to take the given dimension and thus force the
|
|
items owned
|
|
by the sizer to resize themselves according to the rules defined by the
|
|
parameter in the
|
|
Add() and Prepend() methods.
|
|
*/
|
|
void SetDimension(int x, int y, int width, int height);
|
|
|
|
//@{
|
|
/**
|
|
Set an item's minimum size by window, sizer, or position. The item will be
|
|
found recursively
|
|
in the sizer's descendants. This function enables an application to set the
|
|
size of an item
|
|
after initial creation.
|
|
*/
|
|
void SetItemMinSize(wxWindow* window, int width, int height);
|
|
void SetItemMinSize(wxSizer* sizer, int width, int height);
|
|
void SetItemMinSize(size_t index, int width, int height);
|
|
//@}
|
|
|
|
//@{
|
|
/**
|
|
Call this to give the sizer a minimal size. Normally, the sizer will calculate
|
|
its
|
|
minimal size based purely on how much space its children need. After calling
|
|
this
|
|
method GetMinSize() will return either the minimal size
|
|
as requested by its children or the minimal size set here, depending on which is
|
|
bigger.
|
|
*/
|
|
void SetMinSize(int width, int height);
|
|
void SetMinSize(const wxSize& size);
|
|
//@}
|
|
|
|
/**
|
|
This method first calls Fit() and then
|
|
wxTopLevelWindow::SetSizeHints on the @e window
|
|
passed to it. This only makes sense when @a window is actually a
|
|
wxTopLevelWindow such as a wxFrame or a
|
|
wxDialog, since SetSizeHints only has any effect in these classes.
|
|
It does nothing in normal windows or controls.
|
|
This method is implicitly used by wxWindow::SetSizerAndFit
|
|
which is commonly invoked in the constructor of a toplevel window itself (see
|
|
the sample in the description of wxBoxSizer) if the
|
|
toplevel window is resizable.
|
|
*/
|
|
void SetSizeHints(wxWindow* window);
|
|
|
|
/**
|
|
Tell the sizer to set the minimal size of the @a window virtual area to match
|
|
the sizer's
|
|
minimal size. For windows with managed scrollbars this will set them
|
|
appropriately.
|
|
|
|
@see wxScrolledWindow::SetScrollbars
|
|
*/
|
|
void SetVirtualSizeHints(wxWindow* window);
|
|
|
|
//@{
|
|
/**
|
|
Shows or hides the @e window, @e sizer, or item at @e index.
|
|
To make a sizer item disappear or reappear, use Show() followed by Layout().
|
|
Use parameter @a recursive to show or hide elements found in subsizers.
|
|
Returns @true if the child item was found, @false otherwise.
|
|
|
|
@see Hide(), IsShown()
|
|
*/
|
|
bool Show(wxWindow* window, bool show = true,
|
|
bool recursive = false);
|
|
bool Show(wxSizer* sizer, bool show = true,
|
|
bool recursive = false);
|
|
bool Show(size_t index, bool show = true);
|
|
//@}
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxGridSizer
|
|
@wxheader{sizer.h}
|
|
|
|
A grid sizer is a sizer which lays out its children in a two-dimensional
|
|
table with all table fields having the same size,
|
|
i.e. the width of each field is the width of the widest child,
|
|
the height of each field is the height of the tallest child.
|
|
|
|
@library{wxcore}
|
|
@category{winlayout}
|
|
|
|
@see wxSizer, @ref overview_sizeroverview "Sizer overview"
|
|
*/
|
|
class wxGridSizer : public wxSizer
|
|
{
|
|
public:
|
|
//@{
|
|
/**
|
|
Constructor for a wxGridSizer. @a rows and @a cols determine the number of
|
|
columns and rows in the sizer - if either of the parameters is zero, it will be
|
|
calculated to form the total number of children in the sizer, thus making the
|
|
sizer grow dynamically. @a vgap and @a hgap define extra space between
|
|
all children.
|
|
*/
|
|
wxGridSizer(int rows, int cols, int vgap, int hgap);
|
|
wxGridSizer(int cols, int vgap = 0, int hgap = 0);
|
|
//@}
|
|
|
|
/**
|
|
Returns the number of columns in the sizer.
|
|
*/
|
|
int GetCols();
|
|
|
|
/**
|
|
Returns the horizontal gap (in pixels) between cells in the sizer.
|
|
*/
|
|
int GetHGap();
|
|
|
|
/**
|
|
Returns the number of rows in the sizer.
|
|
*/
|
|
int GetRows();
|
|
|
|
/**
|
|
Returns the vertical gap (in pixels) between the cells in the sizer.
|
|
*/
|
|
int GetVGap();
|
|
|
|
/**
|
|
Sets the number of columns in the sizer.
|
|
*/
|
|
void SetCols(int cols);
|
|
|
|
/**
|
|
Sets the horizontal gap (in pixels) between cells in the sizer.
|
|
*/
|
|
void SetHGap(int gap);
|
|
|
|
/**
|
|
Sets the number of rows in the sizer.
|
|
*/
|
|
void SetRows(int rows);
|
|
|
|
/**
|
|
Sets the vertical gap (in pixels) between the cells in the sizer.
|
|
*/
|
|
void SetVGap(int gap);
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxStaticBoxSizer
|
|
@wxheader{sizer.h}
|
|
|
|
wxStaticBoxSizer is a sizer derived from wxBoxSizer but adds a static
|
|
box around the sizer. This static box may be either created independently or
|
|
the sizer may create it itself as a convenience. In any case, the sizer owns
|
|
the wxStaticBox control and will delete it if it is
|
|
deleted.
|
|
|
|
@library{wxcore}
|
|
@category{winlayout}
|
|
|
|
@see wxSizer, wxStaticBox, wxBoxSizer, @ref overview_sizeroverview "Sizer
|
|
overview"
|
|
*/
|
|
class wxStaticBoxSizer : public wxBoxSizer
|
|
{
|
|
public:
|
|
//@{
|
|
/**
|
|
The first constructor uses an already existing static box. It takes the
|
|
associated static box and the orientation @e orient, which can be either
|
|
@c wxVERTICAL or @c wxHORIZONTAL as parameters.
|
|
The second one creates a new static box with the given label and parent window.
|
|
*/
|
|
wxStaticBoxSizer(wxStaticBox* box, int orient);
|
|
wxStaticBoxSizer(int orient, wxWindow parent,
|
|
const wxString& label = wxEmptyString);
|
|
//@}
|
|
|
|
/**
|
|
Returns the static box associated with the sizer.
|
|
*/
|
|
wxStaticBox* GetStaticBox();
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
@class wxBoxSizer
|
|
@wxheader{sizer.h}
|
|
|
|
The basic idea behind a box sizer is that windows will most often be laid out
|
|
in rather
|
|
simple basic geometry, typically in a row or a column or several hierarchies of
|
|
either.
|
|
|
|
For more information, please see @ref overview_boxsizerprogramming "Programming
|
|
with wxBoxSizer".
|
|
|
|
@library{wxcore}
|
|
@category{winlayout}
|
|
|
|
@see wxSizer, @ref overview_sizeroverview "Sizer overview"
|
|
*/
|
|
class wxBoxSizer : public wxSizer
|
|
{
|
|
public:
|
|
/**
|
|
Constructor for a wxBoxSizer. @a orient may be either of wxVERTICAL
|
|
or wxHORIZONTAL for creating either a column sizer or a row sizer.
|
|
*/
|
|
wxBoxSizer(int orient);
|
|
|
|
/**
|
|
Implements the calculation of a box sizer's minimal. It is used internally
|
|
only and must not be called by the user. Documented for information.
|
|
*/
|
|
wxSize CalcMin();
|
|
|
|
/**
|
|
Returns the orientation of the box sizer, either wxVERTICAL
|
|
or wxHORIZONTAL.
|
|
*/
|
|
int GetOrientation();
|
|
|
|
/**
|
|
Implements the calculation of a box sizer's dimensions and then sets
|
|
the size of its children (calling wxWindow::SetSize
|
|
if the child is a window). It is used internally only and must not be called
|
|
by the user (call Layout() if you want to resize). Documented for information.
|
|
*/
|
|
void RecalcSizes();
|
|
};
|
|
|