OpenTTD Source 20260206-master-g4d4e37dbf1
dropdown.cpp File Reference

Implementation of the dropdown widget. More...

#include "stdafx.h"
#include "core/backup_type.hpp"
#include "dropdown_type.h"
#include "dropdown_func.h"
#include "strings_func.h"
#include "sound_func.h"
#include "timer/timer.h"
#include "timer/timer_window.h"
#include "window_gui.h"
#include "window_func.h"
#include "zoom_func.h"
#include "widgets/dropdown_widget.h"
#include "table/strings.h"
#include "dropdown_common_type.h"
#include "safeguards.h"

Go to the source code of this file.

Data Structures

struct  DropdownWindow
 Drop-down menu window. More...

Functions

std::unique_ptr< DropDownListItemMakeDropDownListDividerItem ()
std::unique_ptr< DropDownListItemMakeDropDownListStringItem (StringID str, int value, bool masked, bool shaded)
std::unique_ptr< DropDownListItemMakeDropDownListStringItem (std::string &&str, int value, bool masked, bool shaded)
std::unique_ptr< DropDownListItemMakeDropDownListIconItem (SpriteID sprite, PaletteID palette, StringID str, int value, bool masked, bool shaded)
std::unique_ptr< DropDownListItemMakeDropDownListIconItem (const Dimension &dim, SpriteID sprite, PaletteID palette, StringID str, int value, bool masked, bool shaded)
std::unique_ptr< DropDownListItemMakeDropDownListCheckedItem (bool checked, StringID str, int value, bool masked, bool shaded, uint indent)
void ReplaceDropDownList (Window *parent, DropDownList &&list, std::optional< int > selected_result)
Dimension GetDropDownListDimension (const DropDownList &list)
 Determine width and height required to fully display a DropDownList.
void ShowDropDownListAt (Window *w, DropDownList &&list, int selected, WidgetID button, Rect wi_rect, Colours wi_colour, DropDownOptions options)
 Show a drop down list.
void ShowDropDownList (Window *w, DropDownList &&list, int selected, WidgetID button, uint width, DropDownOptions options)
 Show a drop down list.
void ShowDropDownMenu (Window *w, std::span< const StringID > strings, int selected, WidgetID button, uint32_t disabled_mask, uint32_t hidden_mask, uint width)
 Show a dropdown menu window near a widget of the parent window.

Variables

static constexpr std::initializer_list< NWidgetPart_nested_dropdown_menu_widgets
static WindowDesc _dropdown_desc (WDP_MANUAL, {}, 0, 0, WC_DROPDOWN_MENU, WC_NONE, WindowDefaultFlag::NoFocus, _nested_dropdown_menu_widgets)

Detailed Description

Implementation of the dropdown widget.

Definition in file dropdown.cpp.

Function Documentation

◆ GetDropDownListDimension()

Dimension GetDropDownListDimension ( const DropDownList & list)

Determine width and height required to fully display a DropDownList.

Parameters
listThe list.
Returns
Dimension required to display the list.

Definition at line 381 of file dropdown.cpp.

References WidgetDimensions::scaled.

Referenced by DropdownWindow::UpdateSizeAndPosition(), BuildVehicleWindow::UpdateWidgetSize(), GameOptionsWindow::UpdateWidgetSize(), VehicleGroupWindow::UpdateWidgetSize(), and VehicleListWindow::UpdateWidgetSize().

◆ MakeDropDownListCheckedItem()

std::unique_ptr< DropDownListItem > MakeDropDownListCheckedItem ( bool checked,
StringID str,
int value,
bool masked,
bool shaded,
uint indent )

Definition at line 55 of file dropdown.cpp.

◆ MakeDropDownListDividerItem()

std::unique_ptr< DropDownListItem > MakeDropDownListDividerItem ( )

Definition at line 30 of file dropdown.cpp.

◆ MakeDropDownListIconItem() [1/2]

std::unique_ptr< DropDownListItem > MakeDropDownListIconItem ( const Dimension & dim,
SpriteID sprite,
PaletteID palette,
StringID str,
int value,
bool masked,
bool shaded )

Definition at line 50 of file dropdown.cpp.

◆ MakeDropDownListIconItem() [2/2]

std::unique_ptr< DropDownListItem > MakeDropDownListIconItem ( SpriteID sprite,
PaletteID palette,
StringID str,
int value,
bool masked,
bool shaded )

Definition at line 45 of file dropdown.cpp.

◆ MakeDropDownListStringItem() [1/2]

std::unique_ptr< DropDownListItem > MakeDropDownListStringItem ( std::string && str,
int value,
bool masked,
bool shaded )

Definition at line 40 of file dropdown.cpp.

◆ MakeDropDownListStringItem() [2/2]

std::unique_ptr< DropDownListItem > MakeDropDownListStringItem ( StringID str,
int value,
bool masked,
bool shaded )

Definition at line 35 of file dropdown.cpp.

◆ ReplaceDropDownList()

void ReplaceDropDownList ( Window * parent,
DropDownList && list,
std::optional< int > selected_result )

Definition at line 370 of file dropdown.cpp.

◆ ShowDropDownList()

void ShowDropDownList ( Window * w,
DropDownList && list,
int selected,
WidgetID button,
uint width,
DropDownOptions options )

◆ ShowDropDownListAt()

void ShowDropDownListAt ( Window * w,
DropDownList && list,
int selected,
WidgetID button,
Rect wi_rect,
Colours wi_colour,
DropDownOptions options )

Show a drop down list.

Parameters
wParent window for the list.
listPrepopulated DropDownList.
selectedThe initially selected list item.
buttonThe widget which is passed to Window::OnDropdownSelect and OnDropdownClose. Unless you override those functions, this should be then widget index of the dropdown button.
wi_rectCoord of the parent drop down button, used to position the dropdown menu.
wi_colourColour of the parent widget.
optionsDrop Down options for this menu.

Definition at line 403 of file dropdown.cpp.

References CloseWindowByClass(), Rect, and WC_DROPDOWN_MENU.

Referenced by GSConfigWindow::OnClick(), NewGRFParametersWindow::OnClick(), ScriptSettingsWindow::OnClick(), NetworkClientListWindow::OnClickClientAdmin(), NetworkClientListWindow::OnClickCompanyAdmin(), and ShowDropDownList().

◆ ShowDropDownMenu()

void ShowDropDownMenu ( Window * w,
std::span< const StringID > strings,
int selected,
WidgetID button,
uint32_t disabled_mask,
uint32_t hidden_mask,
uint width )

Show a dropdown menu window near a widget of the parent window.

The result code of the items is their index in the strings list.

Parameters
wParent window that wants the dropdown menu.
stringsMenu list.
selectedIndex of initial selected item.
buttonButton widget number of the parent window w that wants the dropdown menu.
disabled_maskBitmask for disabled items (items with their bit set are displayed, but not selectable in the dropdown list).
hidden_maskBitmask for hidden items (items with their bit set are not copied to the dropdown list).
widthMinimum width of the dropdown menu.

Definition at line 459 of file dropdown.cpp.

References HasBit(), and ShowDropDownList().

Referenced by DisplayVehicleSortDropDown(), BuildBridgeWindow::OnClick(), CompanyStationsWindow::OnClick(), GenerateLandscapeWindow::OnClick(), IndustryDirectoryWindow::OnClick(), OrdersWindow::OnClick(), ReplaceVehicleWindow::OnClick(), StationViewWindow::OnClick(), TownDirectoryWindow::OnClick(), VehicleDetailsWindow::OnClick(), VehicleGroupWindow::OnClick(), and VehicleListWindow::OnClick().

Variable Documentation

◆ _nested_dropdown_menu_widgets

std::initializer_list<NWidgetPart> _nested_dropdown_menu_widgets
staticconstexpr
Initial value:
= {
}
@ WID_DM_ITEMS
Panel showing the dropdown items.
@ WID_DM_SCROLL
Scrollbar.
@ WID_DM_SHOW_SCROLL
Hide scrollbar if too few items.
constexpr NWidgetPart SetScrollbar(WidgetID index)
Attach a scrollbar to a widget.
constexpr NWidgetPart EndContainer()
Widget part function for denoting the end of a container (horizontal, vertical, WWT_FRAME,...
constexpr NWidgetPart NWidget(WidgetType tp, Colours col, WidgetID idx=INVALID_WIDGET)
Widget part function for starting a new 'real' widget.
@ NWID_HORIZONTAL
Horizontal container.
Definition widget_type.h:66
@ WWT_PANEL
Simple depressed panel.
Definition widget_type.h:39
@ NWID_VSCROLLBAR
Vertical scrollbar.
Definition widget_type.h:76
@ NWID_SELECTION
Stacked widgets, only one visible at a time (eg in a panel with tabs).
Definition widget_type.h:71

Definition at line 60 of file dropdown.cpp.