Wt
3.3.8
|
A layout manager which arranges widgets horizontally or vertically. More...
#include <Wt/WBoxLayout>
Public Types | |
Public Types inherited from Wt::WObject | |
typedef void(WObject::* | Method) () |
Typedef for a WObject method without arguments. | |
Public Member Functions | |
WBoxLayout (Direction dir, WWidget *parent=0) | |
Creates a new box layout. More... | |
virtual void | addItem (WLayoutItem *item) |
Adds a layout item. More... | |
virtual void | removeItem (WLayoutItem *item) |
Removes a layout item (widget or nested layout). More... | |
virtual WLayoutItem * | itemAt (int index) const |
Returns the layout item at a specific index. More... | |
virtual int | count () const |
Returns the number of items in this layout. More... | |
virtual void | clear () |
Removes and deletes all child widgets and nested layouts. More... | |
void | setDirection (Direction direction) |
Sets the layout direction. More... | |
Direction | direction () const |
Returns the layout direction. More... | |
void | setSpacing (int size) |
Sets spacing between each item. More... | |
int | spacing () const |
Returns the spacing between each item. More... | |
void | addWidget (WWidget *widget, int stretch=0, WFlags< AlignmentFlag > alignment=0) |
Adds a widget to the layout. More... | |
void | addLayout (WLayout *layout, int stretch=0, WFlags< AlignmentFlag > alignment=0) |
Adds a nested layout to the layout. More... | |
void | addSpacing (const WLength &size) |
Adds extra spacing. More... | |
void | addStretch (int stretch=0) |
Adds a stretch element. More... | |
void | insertWidget (int index, WWidget *widget, int stretch=0, WFlags< AlignmentFlag > alignment=0) |
Inserts a widget in the layout. More... | |
void | insertLayout (int index, WLayout *layout, int stretch=0, WFlags< AlignmentFlag > alignment=0) |
Inserts a nested layout in the layout. More... | |
void | insertSpacing (int index, const WLength &size) |
Inserts extra spacing in the layout. More... | |
void | insertStretch (int index, int stretch=0) |
Inserts a stretch element in the layout. More... | |
bool | setStretchFactor (WLayout *layout, int stretch) |
Sets the stretch factor for a nested layout. More... | |
bool | setStretchFactor (WWidget *widget, int stretch) |
Sets the stretch factor for a widget. More... | |
void | setResizable (int index, bool enabled=true, const WLength &initialSize=WLength::Auto) |
Sets whether the use may drag a particular border. More... | |
bool | isResizable (int index) const |
Returns whether the user may drag a particular border. More... | |
Public Member Functions inherited from Wt::WLayout | |
virtual | ~WLayout () |
Destructor. More... | |
void | addWidget (WWidget *widget) |
Adds the given widget to the layout. More... | |
bool | removeWidget (WWidget *widget) |
Removes the given widget from the layout. More... | |
virtual int | indexOf (WLayoutItem *item) const |
Returns the index of a given item. More... | |
virtual WWidgetItem * | findWidgetItem (WWidget *widget) |
Finds the widget item associated with the given widget. | |
void | setLayoutHint (const std::string &name, const std::string &value) |
Provides a hint to the layout implementation. More... | |
virtual WWidget * | widget () |
Returns the widget that is held by this WLayoutItem. More... | |
virtual WLayout * | layout () |
Returns the layout that implements this WLayoutItem. More... | |
virtual WLayout * | parentLayout () const |
Returns the layout in which this item is contained. | |
WLayoutItemImpl * | impl () const |
Returns the implementation for this layout item. More... | |
void | setContentsMargins (int left, int top, int right, int bottom) |
Set contents margins (in pixels). More... | |
void | getContentsMargins (int *left, int *top, int *right, int *bottom) const |
Returns the contents margins. More... | |
Public Member Functions inherited from Wt::WLayoutItem | |
virtual | ~WLayoutItem () |
Destructor. | |
Public Member Functions inherited from Wt::WObject | |
WObject (WObject *parent=0) | |
Create a WObject with a given parent object. More... | |
virtual | ~WObject () |
Destructor. More... | |
virtual const std::string | id () const |
Returns the (unique) identifier for this object. More... | |
virtual void | setObjectName (const std::string &name) |
Sets an object name. More... | |
virtual std::string | objectName () const |
Returns the object name. More... | |
void | resetLearnedSlots () |
Resets learned stateless slot implementations. More... | |
template<class T > | |
void | resetLearnedSlot (void(T::*method)()) |
Resets a learned stateless slot implementation. More... | |
template<class T > | |
WStatelessSlot * | implementStateless (void(T::*method)()) |
Declares a slot to be stateless and learn client-side behaviour on first invocation. More... | |
template<class T > | |
WStatelessSlot * | implementStateless (void(T::*method)(), void(T::*undoMethod)()) |
Declares a slot to be stateless and learn client-side behaviour in advance. More... | |
void | isNotStateless () |
Marks the current function as not stateless. More... | |
template<class T > | |
WStatelessSlot * | implementJavaScript (void(T::*method)(), const std::string &jsCode) |
Provides a JavaScript implementation for a method. More... | |
void | addChild (WObject *child) |
Adds a child object. More... | |
virtual void | removeChild (WObject *child) |
Removes a child object. More... | |
const std::vector< WObject * > & | children () const |
Returns the children. | |
WObject * | parent () const |
Returns the parent object. | |
Additional Inherited Members | |
Protected Member Functions inherited from Wt::WLayout | |
WLayout () | |
Create a layout. | |
void | update (WLayoutItem *item=0) |
Update the layout. More... | |
void | updateAddItem (WLayoutItem *item) |
Update the layout, adding the given layout item. More... | |
void | updateRemoveItem (WLayoutItem *item) |
Update the layout, remove the given layout item. More... | |
void | setLayoutInParent (WWidget *parent) |
Set the layout in the parent. More... | |
void | clearLayoutItem (WLayoutItem *item) |
Clears and deletes an item. More... | |
Protected Member Functions inherited from Wt::WObject | |
virtual WStatelessSlot * | getStateless (Method method) |
On-demand stateless slot implementation. More... | |
Static Protected Member Functions inherited from Wt::WObject | |
static WObject * | sender () |
Returns the sender of the current slot call. More... | |
A layout manager which arranges widgets horizontally or vertically.
This layout manager arranges widgets horizontally or vertically inside the parent container.
The space is divided so that each widget is given its preferred size, and remaining space is divided according to stretch factors among widgets. If not all widgets can be given their preferred size (there is not enough room), then widgets are given a smaller size (down to their minimum size). If necessary, the container (or parent layout) of this layout is resized to meet minimum size requirements.
The preferred width or height of a widget is based on its natural size, where it presents its contents without overflowing. WWidget::resize() or (CSS width
, height
properties) can be used to adjust the preferred size of a widget.
The minimum width or height of a widget is based on the minimum dimensions of the widget or the nested layout. The default minimum height or width for a widget is 0. It can be specified using WWidget::setMinimumSize() or using CSS min-width
or min-height
properties.
You should use WContainerWidget::setOverflow(OverflowAuto) or use a WScrollArea to automatically show scrollbars for widgets inserted in the layout to cope with a size set by the layout manager that is smaller than the preferred size.
When the container of a layout manager does not have a defined size (by having an explicit size, or by being inside a layout manager), or has has only a maximum size set using WWidget::setMaximumSize(), then the size of the container will be based on the preferred size of the contents, up to this maximum size, instead of the default behaviour of constraining the size of the children based on the size of the container. Note that because of the CSS defaults, a WContainer has by default no height, but inherits the width of its parent widget. The width is thus by default defined.
A layout manager may provide resize handles between items which allow the user to change the automatic layout provided by the layout manager (see setResizable()).
Each item is separated using a constant spacing, which defaults to 6 pixels, and can be changed using setSpacing(). In addition, when this layout is a top-level layout (i.e. is not nested inside another layout), a margin is set around the contents. This margin defaults to 9 pixels, and can be changed using setContentsMargins(). You can add more space between two widgets using addSpacing().
For each item a stretch factor may be defined, which controls how remaining space is used. Each item is stretched using the stretch factor to fill the remaining space.
Usage example:
Enumeration of the direction in which widgets are layed out.
Creates a new box layout.
This constructor is rarely used. Instead, use the convenient constructors of the specialized WHBoxLayout or WVBoxLayout classes.
Use parent
= 0
to created a layout manager that can be nested inside other layout managers.
|
virtual |
Adds a layout item.
The item may be a widget or nested layout.
How the item is layed out with respect to siblings is implementation specific to the layout manager. In some cases, a layout manager will overload this method with extra arguments that specify layout options.
Implements Wt::WLayout.
void Wt::WBoxLayout::addLayout | ( | WLayout * | layout, |
int | stretch = 0 , |
||
WFlags< AlignmentFlag > | alignment = 0 |
||
) |
Adds a nested layout to the layout.
Adds a nested layout, with given stretch
factor.
void Wt::WBoxLayout::addSpacing | ( | const WLength & | size | ) |
void Wt::WBoxLayout::addStretch | ( | int | stretch = 0 | ) |
Adds a stretch element.
Adds a stretch element to the layout. This adds an empty space that stretches as needed.
void Wt::WBoxLayout::addWidget | ( | WWidget * | widget, |
int | stretch = 0 , |
||
WFlags< AlignmentFlag > | alignment = 0 |
||
) |
Adds a widget to the layout.
Adds a widget to the layout, with given stretch
factor. When the stretch factor is 0, the widget will not be resized by the layout manager (stretched to take excess space).
The alignment
parameter is a combination of a horizontal and/or a vertical AlignmentFlag OR'ed together.
The alignment
specifies the vertical and horizontal alignment of the item. The default value 0 indicates that the item is stretched to fill the entire column or row. The alignment can be specified as a logical combination of a horizontal alignment (Wt::AlignLeft, Wt::AlignCenter, or Wt::AlignRight) and a vertical alignment (Wt::AlignTop, Wt::AlignMiddle, or Wt::AlignBottom).
|
virtual |
Removes and deletes all child widgets and nested layouts.
This is similar to WContainerWidget::clear(), with the exception that the layout itself is not deleted.
Implements Wt::WLayout.
|
virtual |
Returns the number of items in this layout.
This may be a theoretical number, which is greater than the actual number of items. It can be used to iterate over the items in the layout, in conjunction with itemAt().
Implements Wt::WLayout.
Direction Wt::WBoxLayout::direction | ( | ) | const |
Returns the layout direction.
void Wt::WBoxLayout::insertLayout | ( | int | index, |
WLayout * | layout, | ||
int | stretch = 0 , |
||
WFlags< AlignmentFlag > | alignment = 0 |
||
) |
Inserts a nested layout in the layout.
Inserts a nested layout in the layout at positionindex
, with given stretch
factor.
void Wt::WBoxLayout::insertSpacing | ( | int | index, |
const WLength & | size | ||
) |
Inserts extra spacing in the layout.
Inserts extra spacing in the layout at position index
.
void Wt::WBoxLayout::insertStretch | ( | int | index, |
int | stretch = 0 |
||
) |
Inserts a stretch element in the layout.
Inserts a stretch element in the layout at position index
. This adds an empty space that stretches as needed.
void Wt::WBoxLayout::insertWidget | ( | int | index, |
WWidget * | widget, | ||
int | stretch = 0 , |
||
WFlags< AlignmentFlag > | alignment = 0 |
||
) |
Inserts a widget in the layout.
Inserts a widget in the layout at position index
, with given stretch
factor. When the stretch factor is 0, the widget will not be resized by the layout manager (stretched to take excess space).
The alignment
specifies the vertical and horizontal alignment of the item. The default value 0 indicates that the item is stretched to fill the entire column or row. The alignment can be specified as a logical combination of a horizontal alignment (Wt::AlignLeft, Wt::AlignCenter, or Wt::AlignRight) and a vertical alignment (Wt::AlignTop, Wt::AlignMiddle, or Wt::AlignBottom).
bool Wt::WBoxLayout::isResizable | ( | int | index | ) | const |
Returns whether the user may drag a particular border.
This method returns whether the border that separates item index from the next item may be resized by the user.
|
virtual |
Returns the layout item at a specific index.
If there is no item at the index
, 0
is returned.
Implements Wt::WLayout.
|
virtual |
Removes a layout item (widget or nested layout).
Implements Wt::WLayout.
void Wt::WBoxLayout::setDirection | ( | Direction | direction | ) |
Sets the layout direction.
void Wt::WBoxLayout::setResizable | ( | int | index, |
bool | enabled = true , |
||
const WLength & | initialSize = WLength::Auto |
||
) |
Sets whether the use may drag a particular border.
This method sets whether the border that separates item index from the next item may be resized by the user, depending on the value of enabled.
The default value is false.
If an initialSize
is given (that is not WLength::Auto), then this size is used for the size of the item, overriding the size it would be given by the layout manager.
void Wt::WBoxLayout::setSpacing | ( | int | size | ) |
Sets spacing between each item.
The default spacing is 6 pixels.
bool Wt::WBoxLayout::setStretchFactor | ( | WLayout * | layout, |
int | stretch | ||
) |
Sets the stretch factor for a nested layout.
The layout
must have previously been added to this layout using insertLayout() or addLayout().
Returns whether the stretch
could be set.
bool Wt::WBoxLayout::setStretchFactor | ( | WWidget * | widget, |
int | stretch | ||
) |
Sets the stretch factor for a widget.
The widget
must have previously been added to this layout using insertWidget() or addWidget().
Returns whether the stretch
could be set.
int Wt::WBoxLayout::spacing | ( | ) | const |
Returns the spacing between each item.