OpenTTD Source 20250312-master-gcdcc6b491d
NWidgetPIPContainer Class Reference

Container with pre/inter/post child space. More...

#include <widget_type.h>

Inheritance diagram for NWidgetPIPContainer:
NWidgetContainer NWidgetBase NWidgetHorizontal NWidgetMatrix NWidgetVertical NWidgetHorizontalLTR NWidgetSocialPlugins

Public Member Functions

 NWidgetPIPContainer (WidgetType tp, NWidContainerFlags flags={})
 
void AdjustPaddingForZoom () override
 
void SetPIP (uint8_t pip_pre, uint8_t pip_inter, uint8_t pip_post)
 Set additional pre/inter/post space for the container.
 
void SetPIPRatio (uint8_t pip_ratio_pre, uint8_t pip_ratio_inter, uint8_t pip_rato_post)
 Set additional pre/inter/post space for the container.
 
- Public Member Functions inherited from NWidgetContainer
 NWidgetContainer (WidgetType tp)
 
void Add (std::unique_ptr< NWidgetBase > &&wid)
 Append widget wid to container.
 
void FillWidgetLookup (WidgetLookup &widget_lookup) override
 Fill the Window::widget_lookup with pointers to nested widgets in the tree.
 
void Draw (const Window *w) override
 Draw the widgets of the tree.
 
NWidgetCoreGetWidgetFromPos (int x, int y) override
 Retrieve a widget by its position.
 
bool IsEmpty ()
 Return whether the container is empty.
 
NWidgetBaseGetWidgetOfType (WidgetType tp) override
 Retrieve a widget by its type.
 
- Public Member Functions inherited from NWidgetBase
 NWidgetBase (WidgetType tp)
 
void ApplyAspectRatio ()
 
virtual void SetupSmallestSize (Window *w)=0
 Compute smallest size needed by the widget.
 
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.
 
template<class NWID >
NWID * GetParentWidget ()
 Get parent widget of type NWID.
 
template<class NWID >
const NWID * GetParentWidget () const
 Get parent widget of type NWID.
 
virtual bool IsHighlighted () const
 
virtual TextColour GetHighlightColour () const
 
virtual void SetHighlighted (TextColour highlight_colour)
 
void SetPadding (uint8_t top, uint8_t right, uint8_t bottom, uint8_t left)
 Set additional space (padding) around the widget.
 
void SetPadding (const RectPadding &padding)
 Set additional space (padding) around the widget.
 
uint GetHorizontalStepSize (SizingType sizing) const
 Get the horizontal sizing step.
 
uint GetVerticalStepSize (SizingType sizing) const
 Get the vertical sizing step.
 
virtual void SetDirty (const Window *w) const
 Mark the widget as 'dirty' (in need of repaint).
 
Rect GetCurrentRect () const
 

Protected Attributes

NWidContainerFlags flags {}
 Flags of the container.
 
uint8_t pip_pre = 0
 Amount of space before first widget.
 
uint8_t pip_inter = 0
 Amount of space between widgets.
 
uint8_t pip_post = 0
 Amount of space after last widget.
 
uint8_t pip_ratio_pre = 0
 Ratio of remaining space before first widget.
 
uint8_t pip_ratio_inter = 0
 Ratio of remaining space between widgets.
 
uint8_t pip_ratio_post = 0
 Ratio of remaining space after last widget.
 
uint8_t uz_pip_pre = 0
 Unscaled space before first widget.
 
uint8_t uz_pip_inter = 0
 Unscaled space between widgets.
 
uint8_t uz_pip_post = 0
 Unscaled space after last widget.
 
uint8_t gaps = 0
 Number of gaps between widgets.
 
- Protected Attributes inherited from NWidgetContainer
std::vector< std::unique_ptr< NWidgetBase > > children {}
 Child widgets in container.
 

Additional Inherited Members

- Data Fields inherited from NWidgetBase
WidgetType type {}
 Type of the widget / nested widget.
 
uint fill_x = 0
 Horizontal fill stepsize (from initial size, 0 means not resizable).
 
uint fill_y = 0
 Vertical fill stepsize (from initial size, 0 means not resizable).
 
uint resize_x = 0
 Horizontal resize step (0 means not resizable).
 
uint resize_y = 0
 Vertical resize step (0 means not resizable).
 
uint smallest_x = 0
 Smallest horizontal size of the widget in a filled window.
 
uint smallest_y = 0
 Smallest vertical size of the widget in a filled window.
 
uint current_x = 0
 Current horizontal size (after resizing).
 
uint current_y = 0
 Current vertical size (after resizing).
 
float aspect_ratio = 0
 Desired aspect ratio of widget.
 
AspectFlags aspect_flags = AspectFlag::ResizeX
 Which dimensions can be resized.
 
int pos_x = 0
 Horizontal position of top-left corner of the widget in the window.
 
int pos_y = 0
 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.
 
NWidgetBaseparent = nullptr
 Parent widget of this widget, automatically filled in when added to container.
 
- Protected Member Functions inherited from NWidgetBase
void StoreSizePosition (SizingType sizing, int x, int y, uint given_width, uint given_height)
 Store size and position.
 

Detailed Description

Container with pre/inter/post child space.

Definition at line 534 of file widget_type.h.

Constructor & Destructor Documentation

◆ NWidgetPIPContainer()

NWidgetPIPContainer::NWidgetPIPContainer ( WidgetType  tp,
NWidContainerFlags  flags = {} 
)

Definition at line 1481 of file widget.cpp.

Member Function Documentation

◆ AdjustPaddingForZoom()

void NWidgetPIPContainer::AdjustPaddingForZoom ( )
overridevirtual

Reimplemented from NWidgetContainer.

Definition at line 1486 of file widget.cpp.

◆ SetPIP()

void NWidgetPIPContainer::SetPIP ( uint8_t  pip_pre,
uint8_t  pip_inter,
uint8_t  pip_post 
)

Set additional pre/inter/post space for the container.

Parameters
pip_preAdditional space in front of the first child widget (above for the vertical container, at the left for the horizontal container).
pip_interAdditional space between two child widgets.
pip_postAdditional space after the last child widget (below for the vertical container, at the right for the horizontal container).

Definition at line 1503 of file widget.cpp.

References pip_inter, pip_post, pip_pre, ScaleGUITrad(), uz_pip_inter, uz_pip_post, and uz_pip_pre.

Referenced by ApplyNWidgetPartAttribute().

◆ SetPIPRatio()

void NWidgetPIPContainer::SetPIPRatio ( uint8_t  pip_ratio_pre,
uint8_t  pip_ratio_inter,
uint8_t  pip_ratio_post 
)

Set additional pre/inter/post space for the container.

Parameters
pip_ratio_preRatio of additional space in front of the first child widget (above for the vertical container, at the left for the horizontal container).
pip_ratio_interRatio of additional space between two child widgets.
pip_ratio_postRatio of additional space after the last child widget (below for the vertical container, at the right for the horizontal container).

Definition at line 1523 of file widget.cpp.

References pip_ratio_inter, pip_ratio_post, and pip_ratio_pre.

Referenced by ApplyNWidgetPartAttribute().

Field Documentation

◆ flags

◆ gaps

uint8_t NWidgetPIPContainer::gaps = 0
protected

◆ pip_inter

◆ pip_post

◆ pip_pre

◆ pip_ratio_inter

uint8_t NWidgetPIPContainer::pip_ratio_inter = 0
protected

◆ pip_ratio_post

uint8_t NWidgetPIPContainer::pip_ratio_post = 0
protected

◆ pip_ratio_pre

uint8_t NWidgetPIPContainer::pip_ratio_pre = 0
protected

◆ uz_pip_inter

uint8_t NWidgetPIPContainer::uz_pip_inter = 0
protected

Unscaled space between widgets.

Definition at line 552 of file widget_type.h.

Referenced by SetPIP().

◆ uz_pip_post

uint8_t NWidgetPIPContainer::uz_pip_post = 0
protected

Unscaled space after last widget.

Definition at line 553 of file widget_type.h.

Referenced by SetPIP().

◆ uz_pip_pre

uint8_t NWidgetPIPContainer::uz_pip_pre = 0
protected

Unscaled space before first widget.

Definition at line 551 of file widget_type.h.

Referenced by SetPIP().


The documentation for this class was generated from the following files: