#include <widget_type.h>
Public Member Functions | |
NWidgetStacked () | |
Widgets stacked on top of each other. | |
void | SetIndex (int index) |
void | SetupSmallestSize (Window *w, bool init_array) |
Compute smallest size needed by the widget. | |
void | AssignSizePosition (SizingType sizing, uint x, uint y, uint given_width, uint given_height, bool rtl) |
Assign size and position to the widget. | |
void | FillNestedArray (NWidgetBase **array, uint length) |
void | Draw (const Window *w) |
Draw the widgets of the tree. | |
NWidgetCore * | GetWidgetFromPos (int x, int y) |
Retrieve a widget by its position. | |
void | SetDisplayedPlane (int plane) |
Select which plane to show (for NWID_SELECTION only). | |
Data Fields | |
int | shown_plane |
Plane being displayed (for NWID_SELECTION only). | |
int | index |
If non-negative, index in the Window::nested_array. |
NWID_SELECTION allows for selecting one of several panels (planes) to tbe displayed. All planes must have the same size. Since all planes are also initialized, switching between different planes can be done while the window is displayed.
There are also a number of special planes (defined in StackedZeroSizePlanes) that have zero size in one direction (and are stretchable in the other direction) or have zero size in both directions. They are used to make all child planes of the widget disappear. Unlike switching between the regular display planes (that all have the same size), switching from or to one of the zero-sized planes means that a Windows::ReInit() is needed to re-initialize the window since its size changes.
Definition at line 335 of file widget_type.h.
void NWidgetStacked::SetupSmallestSize | ( | Window * | w, | |
bool | init_array | |||
) | [virtual] |
Compute smallest size needed by the widget.
The smallest size of a widget is the smallest size that a widget needs to display itself properly. In addition, filling and resizing of the widget are computed. The function calls Window::UpdateWidgetSize for each leaf widget and background widget without child with a non-negative index.
w | Window owning the widget. | |
init_array | Initialize the w->nested_array . |
Implements NWidgetBase.
Definition at line 960 of file widget.cpp.
References NWidgetBase::fill_x, NWidgetBase::fill_y, NWidgetContainer::head, Dimension::height, index, LeastCommonMultiple(), max(), Window::nested_array, Window::nested_array_size, NWidgetBase::next, NWidgetBase::resize_x, NWidgetBase::resize_y, shown_plane, NWidgetBase::smallest_x, NWidgetBase::smallest_y, SZSP_BEGIN, SZSP_HORIZONTAL, SZSP_VERTICAL, Window::UpdateWidgetSize(), and Dimension::width.
void NWidgetStacked::AssignSizePosition | ( | SizingType | sizing, | |
uint | x, | |||
uint | y, | |||
uint | given_width, | |||
uint | given_height, | |||
bool | rtl | |||
) | [virtual] |
Assign size and position to the widget.
sizing | Type of resizing to perform. | |
x | Horizontal offset of the widget relative to the left edge of the window. | |
y | Vertical offset of the widget relative to the top edge of the window. | |
given_width | Width allocated to the widget. | |
given_height | Height allocated to the widget. | |
rtl | Adapt for right-to-left languages (position contents of horizontal containers backwards). |
Implements NWidgetBase.
Definition at line 1004 of file widget.cpp.
References ComputeMaxSize(), NWidgetContainer::head, NWidgetBase::next, shown_plane, NWidgetBase::smallest_x, NWidgetBase::smallest_y, ST_SMALLEST, NWidgetBase::StoreSizePosition(), and SZSP_BEGIN.
void NWidgetStacked::Draw | ( | const Window * | w | ) | [virtual] |
Draw the widgets of the tree.
The function calls Window::DrawWidget for each widget with a non-negative index, after the widget itself is painted.
w | Window that owns the tree. |
Implements NWidgetBase.
Definition at line 1030 of file widget.cpp.
References NWidgetContainer::head, NWidgetBase::next, shown_plane, and SZSP_BEGIN.
NWidgetCore * NWidgetStacked::GetWidgetFromPos | ( | int | x, | |
int | y | |||
) | [virtual] |
Retrieve a widget by its position.
x | Horizontal position relative to the left edge of the window. | |
y | Vertical position relative to the top edge of the window. |
NULL
if no widget can be found. Implements NWidgetBase.
Definition at line 1045 of file widget.cpp.
References NWidgetBase::current_x, NWidgetBase::current_y, NWidgetCore::GetWidgetFromPos(), NWidgetContainer::head, IsInsideBS(), NWidgetBase::next, NWidgetBase::pos_x, NWidgetBase::pos_y, shown_plane, and SZSP_BEGIN.
void NWidgetStacked::SetDisplayedPlane | ( | int | plane | ) |
Select which plane to show (for NWID_SELECTION only).
plane | Plane number to display. |
Definition at line 1062 of file widget.cpp.
References shown_plane.
Referenced by VehicleListWindow::OnPaint(), CompanyWindow::OnPaint(), and Window::SetShaded().