OpenTTD Source
20241109-master-g5e4f8db7d6
|
Baseclass for nested widgets. More...
#include <widget_type.h>
Public Member Functions | |
NWidgetBase (WidgetType tp) | |
Base class constructor. More... | |
void | ApplyAspectRatio () |
virtual void | AdjustPaddingForZoom () |
virtual void | SetupSmallestSize (Window *w)=0 |
Compute smallest size needed by the widget. More... | |
virtual void | AssignSizePosition (SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl)=0 |
Assign size and position to the widget. More... | |
virtual void | FillWidgetLookup (WidgetLookup &widget_lookup)=0 |
Fill the Window::widget_lookup with pointers to nested widgets in the tree. More... | |
virtual NWidgetCore * | GetWidgetFromPos (int x, int y)=0 |
Retrieve a widget by its position. More... | |
virtual NWidgetBase * | GetWidgetOfType (WidgetType tp) |
Retrieve a widget by its type. More... | |
template<class NWID > | |
NWID * | GetParentWidget () |
Get parent widget of type NWID. More... | |
template<class NWID > | |
const NWID * | GetParentWidget () const |
Get parent widget of type NWID. More... | |
virtual bool | IsHighlighted () const |
virtual TextColour | GetHighlightColour () const |
virtual void | SetHighlighted ([[maybe_unused]] TextColour highlight_colour) |
void | SetPadding (uint8_t top, uint8_t right, uint8_t bottom, uint8_t left) |
Set additional space (padding) around the widget. More... | |
void | SetPadding (const RectPadding &padding) |
Set additional space (padding) around the widget. More... | |
uint | GetHorizontalStepSize (SizingType sizing) const |
Get the horizontal sizing step. More... | |
uint | GetVerticalStepSize (SizingType sizing) const |
Get the vertical sizing step. More... | |
virtual void | Draw (const Window *w)=0 |
Draw the widgets of the tree. More... | |
virtual void | SetDirty (const Window *w) const |
Mark the widget as 'dirty' (in need of repaint). More... | |
Rect | GetCurrentRect () const |
Public Member Functions inherited from ZeroedMemoryAllocator | |
void * | operator new (size_t size) |
Memory allocator for a single class instance. More... | |
void * | operator new[] (size_t size) |
Memory allocator for an array of class instances. More... | |
void | operator delete (void *ptr) |
Memory release for a single class instance. More... | |
void | operator delete[] (void *ptr) |
Memory release for an array of class instances. More... | |
Data Fields | |
WidgetType | type |
Type of the widget / nested widget. | |
uint | fill_x |
Horizontal fill stepsize (from initial size, 0 means not resizable). | |
uint | fill_y |
Vertical fill stepsize (from initial size, 0 means not resizable). | |
uint | resize_x |
Horizontal resize step (0 means not resizable). | |
uint | resize_y |
Vertical resize step (0 means not resizable). | |
uint | smallest_x |
Smallest horizontal size of the widget in a filled window. | |
uint | smallest_y |
Smallest vertical size of the widget in a filled window. | |
uint | current_x |
Current horizontal size (after resizing). | |
uint | current_y |
Current vertical size (after resizing). | |
float | aspect_ratio = 0 |
Desired aspect ratio of widget. | |
AspectFlags | aspect_flags = AspectFlags::ResizeX |
Which dimensions can be resized. | |
int | pos_x |
Horizontal position of top-left corner of the widget in the window. | |
int | pos_y |
Vertical position of top-left corner of the widget in the window. | |
RectPadding | padding |
Padding added to the widget. Managed by parent container widget. (parent container may swap left and right for RTL) | |
RectPadding | uz_padding |
Unscaled padding, for resize calculation. | |
NWidgetBase * | parent |
Parent widget of this widget, automatically filled in when added to container. | |
Protected Member Functions | |
void | StoreSizePosition (SizingType sizing, int x, int y, uint given_width, uint given_height) |
Store size and position. More... | |
Baseclass for nested widgets.
Definition at line 144 of file widget_type.h.
NWidgetBase::NWidgetBase | ( | WidgetType | tp | ) |
Base class constructor.
tp | Nested widget type. |
Definition at line 851 of file widget.cpp.
References type.
|
pure 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). |
Afterwards, pos_x and pos_y contain the top-left position of the widget, smallest_x and smallest_y contain the smallest size such that all widgets of the window are consistent, and current_x and current_y contain the current size.
Implemented in NWidgetBackground, NWidgetMatrix, NWidgetVertical, NWidgetHorizontalLTR, NWidgetHorizontal, NWidgetStacked, NWidgetResizeBase, NWidgetToolbarContainer, NWidgetSmallmapDisplay, NWidgetNewGRFDisplay, and NWidgetServerListHeader.
|
pure 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. |
Implemented in NWidgetLeaf, NWidgetScrollbar, NWidgetViewport, NWidgetBackground, NWidgetSpacer, NWidgetMatrix, NWidgetStacked, NWidgetContainer, NWidgetToolbarContainer, NWidgetSocialPlugins, and NWidgetNewGRFDisplay.
|
pure virtual |
Fill the Window::widget_lookup with pointers to nested widgets in the tree.
widget_lookup | The WidgetLookup. |
Implemented in NWidgetBackground, NWidgetSpacer, NWidgetMatrix, NWidgetStacked, NWidgetContainer, NWidgetCore, NWidgetSocialPlugins, and NWidgetNewGRFDisplay.
|
inline |
Get the horizontal sizing step.
sizing | Type of resize being performed. |
Definition at line 264 of file widget_type.h.
|
inline |
Get parent widget of type NWID.
NWID | Type of the nested widget. |
Definition at line 164 of file widget_type.h.
References parent.
|
inline |
Get parent widget of type NWID.
NWID | Type of the nested widget. |
Definition at line 178 of file widget_type.h.
References parent.
|
inline |
Get the vertical sizing step.
sizing | Type of resize being performed. |
Definition at line 273 of file widget_type.h.
|
pure 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. |
nullptr
if no widget can be found. Implemented in NWidgetBackground, NWidgetSpacer, NWidgetMatrix, NWidgetStacked, NWidgetContainer, NWidgetCore, and NWidgetNewGRFDisplay.
|
virtual |
Retrieve a widget by its type.
tp | Widget type to search for. |
nullptr
if no widget can be found. Reimplemented in NWidgetBackground, and NWidgetContainer.
Definition at line 923 of file widget.cpp.
References type.
Referenced by NWidgetContainer::GetWidgetOfType().
|
virtual |
Mark the widget as 'dirty' (in need of repaint).
w | Window owning the widget. |
Reimplemented in NWidgetSpacer.
Definition at line 903 of file widget.cpp.
References AddDirtyBlock(), current_x, current_y, Window::left, pos_x, pos_y, and Window::top.
Referenced by VehicleListWindow::OnPaint(), Window::SetFocusedWidget(), Window::SetWidgetHighlight(), SmallMapWindow::SmallMapCenterOnCurrentPos(), and Window::UnfocusFocusedWidget().
|
inline |
Set additional space (padding) around the widget.
padding | Amount of padding around the widget. |
Definition at line 210 of file widget_type.h.
References padding, and uz_padding.
|
inline |
Set additional space (padding) around the widget.
top | Amount of additional space above the widget. |
right | Amount of additional space right of the widget. |
bottom | Amount of additional space below the widget. |
left | Amount of additional space left of the widget. |
Definition at line 197 of file widget_type.h.
References uz_padding.
|
pure 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. |
Implemented in NWidgetLeaf, NWidgetScrollbar, NWidgetViewport, NWidgetBackground, NWidgetSpacer, NWidgetMatrix, NWidgetVertical, NWidgetHorizontal, NWidgetStacked, NWidgetScenarioToolbarContainer, NWidgetToolbarContainer, NWidgetSmallmapDisplay, NWidgetSocialPlugins, NWidgetNewGRFDisplay, and NWidgetServerListHeader.
Referenced by NWidgetSmallmapDisplay::SetupSmallestSize().
|
inlineprotected |
Store size and position.
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. |
Definition at line 286 of file widget_type.h.