OpenTTD Source 20250312-master-gcdcc6b491d
NWidgetNewGRFDisplay Class Reference

Custom nested widget container for the NewGRF gui. More...

Inheritance diagram for NWidgetNewGRFDisplay:
NWidgetBase

Public Member Functions

 NWidgetNewGRFDisplay (std::unique_ptr< NWidgetBase > &&avs, std::unique_ptr< NWidgetBase > &&acs, std::unique_ptr< NWidgetBase > &&inf)
 
void SetupSmallestSize (Window *w) override
 Compute smallest size needed by the widget.
 
void AssignSizePosition (SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
 Assign size and position to the widget.
 
void FillWidgetLookup (WidgetLookup &widget_lookup) override
 Fill the Window::widget_lookup with pointers to nested widgets in the tree.
 
NWidgetCoreGetWidgetFromPos (int x, int y) override
 Retrieve a widget by its position.
 
void Draw (const Window *w) override
 Draw the widgets of the tree.
 
- Public Member Functions inherited from NWidgetBase
 NWidgetBase (WidgetType tp)
 
void ApplyAspectRatio ()
 
virtual void AdjustPaddingForZoom ()
 
virtual NWidgetBaseGetWidgetOfType (WidgetType tp)
 Retrieve a widget by its type.
 
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
 

Data Fields

std::unique_ptr< NWidgetBaseavs {}
 Widget with the available grfs list and buttons.
 
std::unique_ptr< NWidgetBaseacs {}
 Widget with the active grfs list and buttons.
 
std::unique_ptr< NWidgetBaseinf {}
 Info panel.
 
bool editable = true
 Editable status of the parent NewGRF window (if false, drop all widgets that make the window editable).
 
- 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.
 

Static Public Attributes

static const uint MAX_EXTRA_INFO_WIDTH = 150
 Maximal additional width given to the panel.
 
static const uint MIN_EXTRA_FOR_3_COLUMNS = 50
 Minimal additional width needed before switching to 3 columns.
 

Additional Inherited Members

- 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

Custom nested widget container for the NewGRF gui.

Depending on the space in the gui, it uses either

  • two column mode, put the acs and the avs underneath each other and the inf next to it, or
  • three column mode, put the avs, acs, and inf each in its own column.

Definition at line 1545 of file newgrf_gui.cpp.

Constructor & Destructor Documentation

◆ NWidgetNewGRFDisplay()

NWidgetNewGRFDisplay::NWidgetNewGRFDisplay ( std::unique_ptr< NWidgetBase > &&  avs,
std::unique_ptr< NWidgetBase > &&  acs,
std::unique_ptr< NWidgetBase > &&  inf 
)
inline

Definition at line 1555 of file newgrf_gui.cpp.

Member Function Documentation

◆ AssignSizePosition()

void NWidgetNewGRFDisplay::AssignSizePosition ( SizingType  sizing,
int  x,
int  y,
uint  given_width,
uint  given_height,
bool  rtl 
)
inlineoverridevirtual

Assign size and position to the widget.

Parameters
sizingType of resizing to perform.
xHorizontal offset of the widget relative to the left edge of the window.
yVertical offset of the widget relative to the top edge of the window.
given_widthWidth allocated to the widget.
given_heightHeight allocated to the widget.
rtlAdapt 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.

Implements NWidgetBase.

Definition at line 1605 of file newgrf_gui.cpp.

References acs, avs, ComputeMaxSize(), editable, WidgetDimensions::hsep_wide, inf, MAX_EXTRA_INFO_WIDTH, MIN_EXTRA_FOR_3_COLUMNS, WidgetDimensions::scaled, ScaleGUITrad(), NWidgetBase::StoreSizePosition(), and WidgetDimensions::vsep_wide.

◆ Draw()

void NWidgetNewGRFDisplay::Draw ( const Window w)
inlineoverridevirtual

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.

Parameters
wWindow that owns the tree.

Implements NWidgetBase.

Definition at line 1741 of file newgrf_gui.cpp.

References acs, avs, and inf.

◆ FillWidgetLookup()

void NWidgetNewGRFDisplay::FillWidgetLookup ( WidgetLookup widget_lookup)
inlineoverridevirtual

Fill the Window::widget_lookup with pointers to nested widgets in the tree.

Parameters
widget_lookupThe WidgetLookup.

Implements NWidgetBase.

Definition at line 1724 of file newgrf_gui.cpp.

References acs, avs, and inf.

◆ GetWidgetFromPos()

NWidgetCore * NWidgetNewGRFDisplay::GetWidgetFromPos ( int  x,
int  y 
)
inlineoverridevirtual

Retrieve a widget by its position.

Parameters
xHorizontal position relative to the left edge of the window.
yVertical position relative to the top edge of the window.
Returns
Returns the deepest nested widget that covers the given position, or nullptr if no widget can be found.

Implements NWidgetBase.

Definition at line 1731 of file newgrf_gui.cpp.

References acs, avs, NWidgetBase::current_x, NWidgetBase::current_y, editable, NWidgetCore::GetWidgetFromPos(), inf, IsInsideBS(), NWidgetBase::pos_x, and NWidgetBase::pos_y.

◆ SetupSmallestSize()

void NWidgetNewGRFDisplay::SetupSmallestSize ( Window w)
inlineoverridevirtual

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.

Parameters
wWindow owning the widget.
Note
After the computation, the results can be queried by accessing the smallest_x and smallest_y data members of the widget.

Implements NWidgetBase.

Definition at line 1562 of file newgrf_gui.cpp.

References acs, avs, ComputeMaxSize(), NewGRFWindow::editable, NWidgetBase::fill_x, NWidgetBase::fill_y, WidgetDimensions::hsep_wide, inf, NWidgetBase::resize_x, NWidgetBase::resize_y, WidgetDimensions::scaled, NWidgetBase::smallest_x, and NWidgetBase::smallest_y.

Field Documentation

◆ acs

std::unique_ptr<NWidgetBase> NWidgetNewGRFDisplay::acs {}

Widget with the active grfs list and buttons.

Definition at line 1551 of file newgrf_gui.cpp.

Referenced by AssignSizePosition(), Draw(), FillWidgetLookup(), GetWidgetFromPos(), and SetupSmallestSize().

◆ avs

std::unique_ptr<NWidgetBase> NWidgetNewGRFDisplay::avs {}

Widget with the available grfs list and buttons.

Definition at line 1550 of file newgrf_gui.cpp.

Referenced by AssignSizePosition(), Draw(), FillWidgetLookup(), GetWidgetFromPos(), and SetupSmallestSize().

◆ editable

bool NWidgetNewGRFDisplay::editable = true

Editable status of the parent NewGRF window (if false, drop all widgets that make the window editable).

Definition at line 1553 of file newgrf_gui.cpp.

Referenced by AssignSizePosition(), and GetWidgetFromPos().

◆ inf

std::unique_ptr<NWidgetBase> NWidgetNewGRFDisplay::inf {}

Info panel.

Definition at line 1552 of file newgrf_gui.cpp.

Referenced by AssignSizePosition(), Draw(), FillWidgetLookup(), GetWidgetFromPos(), and SetupSmallestSize().

◆ MAX_EXTRA_INFO_WIDTH

const uint NWidgetNewGRFDisplay::MAX_EXTRA_INFO_WIDTH = 150
static

Maximal additional width given to the panel.

Definition at line 1547 of file newgrf_gui.cpp.

Referenced by AssignSizePosition().

◆ MIN_EXTRA_FOR_3_COLUMNS

const uint NWidgetNewGRFDisplay::MIN_EXTRA_FOR_3_COLUMNS = 50
static

Minimal additional width needed before switching to 3 columns.

Definition at line 1548 of file newgrf_gui.cpp.

Referenced by AssignSizePosition().


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