OpenTTD Source 20260401-master-g3efaeb0eea
widget_type.h
Go to the documentation of this file.
1/*
2 * This file is part of OpenTTD.
3 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
4 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
5 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <https://www.gnu.org/licenses/old-licenses/gpl-2.0>.
6 */
7
9
10#ifndef WIDGET_TYPE_H
11#define WIDGET_TYPE_H
12
13#include "core/math_func.hpp"
14#include "strings_type.h"
15#include "gfx_type.h"
16#include "window_type.h"
17
19enum class ArrowWidgetType : uint8_t {
24};
25
27enum class ResizeWidgetType : uint8_t {
30};
31
111
113enum class SizingType : uint8_t {
116};
117
119enum class AspectFlag : uint8_t {
122};
123using AspectFlags = EnumBitSet<AspectFlag, uint8_t>;
124
125/* Forward declarations. */
126class NWidgetCore;
127class Scrollbar;
128
130using WidgetLookup = std::map<WidgetID, class NWidgetBase *>;
131
138class NWidgetBase {
139public:
140 NWidgetBase(WidgetType tp, WidgetID index = INVALID_WIDGET) : type(tp), index(index) {}
142 virtual ~NWidgetBase() = default;
143
144 void ApplyAspectRatio();
145
149 virtual void AdjustPaddingForZoom();
150 virtual void SetupSmallestSize(Window *w) = 0;
151 virtual void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) = 0;
152
153 virtual void FillWidgetLookup(WidgetLookup &widget_lookup);
154
155 virtual NWidgetCore *GetWidgetFromPos(int x, int y) = 0;
156 virtual NWidgetBase *GetWidgetOfType(WidgetType tp);
157
163 template <class NWID>
165 {
166 for (NWidgetBase *nwid_parent = this->parent; nwid_parent != nullptr; nwid_parent = nwid_parent->parent) {
167 if (NWID *nwid = dynamic_cast<NWID *>(nwid_parent); nwid != nullptr) return nwid;
168 }
169 return nullptr;
170 }
171
177 template <class NWID>
178 const NWID *GetParentWidget() const
179 {
180 for (const NWidgetBase *nwid_parent = this->parent; nwid_parent != nullptr; nwid_parent = nwid_parent->parent) {
181 if (const NWID *nwid = dynamic_cast<const NWID *>(nwid_parent); nwid != nullptr) return nwid;
182 }
183 return nullptr;
184 }
185
186 inline WidgetID GetIndex() const { return this->index; }
187
192 virtual bool IsHighlighted() const { return false; }
193
198 virtual TextColour GetHighlightColour() const { return TC_INVALID; }
199
204 virtual void SetHighlighted([[maybe_unused]] TextColour highlight_colour) {}
205
213 inline void SetPadding(uint8_t top, uint8_t right, uint8_t bottom, uint8_t left)
214 {
215 this->uz_padding.top = top;
216 this->uz_padding.right = right;
217 this->uz_padding.bottom = bottom;
218 this->uz_padding.left = left;
219 this->AdjustPaddingForZoom();
220 }
221
226 inline void SetPadding(const RectPadding &padding)
227 {
228 this->uz_padding = padding;
229 this->AdjustPaddingForZoom();
230 }
231
232 inline uint GetHorizontalStepSize(SizingType sizing) const;
233 inline uint GetVerticalStepSize(SizingType sizing) const;
234
235 virtual void Draw(const Window *w) = 0;
236 virtual void SetDirty(const Window *w) const;
237
238 Rect GetCurrentRect() const
239 {
240 Rect r;
241 r.left = this->pos_x;
242 r.top = this->pos_y;
243 r.right = this->pos_x + this->current_x - 1;
244 r.bottom = this->pos_y + this->current_y - 1;
245 return r;
246 }
247
249 uint fill_x = 0;
250 uint fill_y = 0;
251 uint resize_x = 0;
252 uint resize_y = 0;
253 /* Size of the widget in the smallest window possible.
254 * Computed by #SetupSmallestSize() followed by #AssignSizePosition().
255 */
256 uint smallest_x = 0;
257 uint smallest_y = 0;
258 /* Current widget size (that is, after resizing). */
259 uint current_x = 0;
260 uint current_y = 0;
261 float aspect_ratio = 0;
263
264 int pos_x = 0;
265 int pos_y = 0;
266
269
270 NWidgetBase *parent = nullptr;
271
272protected:
274
275 inline void StoreSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height);
276};
277
284{
285 return (sizing == SizingType::Resize) ? this->resize_x : this->fill_x;
286}
287
294{
295 return (sizing == SizingType::Resize) ? this->resize_y : this->fill_y;
296}
297
306inline void NWidgetBase::StoreSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height)
307{
308 this->pos_x = x;
309 this->pos_y = y;
310 if (sizing == SizingType::Smallest) {
311 this->smallest_x = given_width;
312 this->smallest_y = given_height;
313 }
314 this->current_x = given_width;
315 this->current_y = given_height;
316}
317
318
323class NWidgetResizeBase : public NWidgetBase {
324public:
326
327 void AdjustPaddingForZoom() override;
328 void SetMinimalSize(uint min_x, uint min_y);
329 void SetMinimalSizeAbsolute(uint min_x, uint min_y);
330 void SetMinimalTextLines(uint8_t min_lines, uint8_t spacing, FontSize size);
332 void SetFill(uint fill_x, uint fill_y);
333 void SetResize(uint resize_x, uint resize_y);
334 void SetAspect(float ratio, AspectFlags flags = AspectFlag::ResizeX);
335 void SetAspect(int x_ratio, int y_ratio, AspectFlags flags = AspectFlag::ResizeX);
336
337 bool UpdateMultilineWidgetSize(const std::string &str, int max_lines);
338 bool UpdateSize(uint min_x, uint min_y);
339 bool UpdateVerticalSize(uint min_y);
340
341 void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override;
342
343 uint min_x = 0;
344 uint min_y = 0;
345
346 bool absolute = false;
347 uint uz_min_x = 0;
348 uint uz_min_y = 0;
349
350 uint8_t uz_text_lines = 0;
351 uint8_t uz_text_spacing = 0;
353 uint8_t toolbar_size = 0;
354};
355
357enum class NWidgetDisplayFlag : uint8_t {
358 /* Generic. */
361
362 /* Viewport widget. */
366
367 /* Button dropdown widget. */
369
370 /* Scrollbar widget. */
373
374 /* Generic. */
377};
378using NWidgetDisplayFlags = EnumBitSet<NWidgetDisplayFlag, uint16_t>;
379
382 StringID string{};
383 SpriteID sprite{};
384 ArrowWidgetType arrow_widget_type{};
385 ResizeWidgetType resize_widget_type{};
386 Colours alternate_colour = INVALID_COLOUR;
387 Dimension matrix{};
388};
389
395public:
397
398 void SetString(StringID string);
400 void SetSprite(SpriteID sprite);
402 void SetMatrixDimension(uint32_t columns, uint32_t rows);
405 StringID GetToolTip() const;
408
409 StringID GetString() const;
411
412 inline void SetLowered(bool lowered);
413 inline bool IsLowered() const;
414 inline void SetDisabled(bool disabled);
415 inline bool IsDisabled() const;
416
417 inline TextColour GetTextColour() const { return this->text_colour; }
418 inline FontSize GetFontSize() const { return this->text_size; }
419
420 NWidgetCore *GetWidgetFromPos(int x, int y) override;
421 bool IsHighlighted() const override;
422 TextColour GetHighlightColour() const override;
424
425 NWidgetDisplayFlags disp_flags;
426 Colours colour;
427protected:
435
436 /* This function constructs the widgets, so it should be able to write the variables. */
437 friend void ApplyNWidgetPartAttribute(const struct NWidgetPart &nwid, NWidgetBase *dest);
438};
439
445
446inline bool NWidgetCore::IsHighlighted() const
447{
448 return this->disp_flags.Test(NWidgetDisplayFlag::Highlight);
449}
450
452{
453 return this->highlight_colour;
454}
455
460inline void NWidgetCore::SetLowered(bool lowered)
461{
463}
464
469inline bool NWidgetCore::IsLowered() const
470{
471 return this->disp_flags.Test(NWidgetDisplayFlag::Lowered);
472}
473
478inline void NWidgetCore::SetDisabled(bool disabled)
479{
481}
482
487inline bool NWidgetCore::IsDisabled() const
488{
489 return this->disp_flags.Test(NWidgetDisplayFlag::Disabled);
490}
491
492
497class NWidgetContainer : public NWidgetBase {
498public:
499 NWidgetContainer(WidgetType tp, WidgetID index = INVALID_WIDGET) : NWidgetBase(tp, index) {}
500
501 void AdjustPaddingForZoom() override;
502 void Add(std::unique_ptr<NWidgetBase> &&wid);
503 void FillWidgetLookup(WidgetLookup &widget_lookup) override;
504
505 void Draw(const Window *w) override;
506 NWidgetCore *GetWidgetFromPos(int x, int y) override;
507
512 inline bool IsEmpty() { return this->children.empty(); }
513
515 void UnfocusWidgets(Window *parent_window);
516
521 inline void Clear(Window *parent_window)
522 {
523 this->UnfocusWidgets(parent_window);
524 this->children.clear();
525 }
526
527protected:
528 std::vector<std::unique_ptr<NWidgetBase>> children{};
529};
530
539
550class NWidgetStacked : public NWidgetContainer {
551public:
552 NWidgetStacked(WidgetID index) : NWidgetContainer(NWID_SELECTION, index) {}
553
554 void SetupSmallestSize(Window *w) override;
555 void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override;
557
558 void Draw(const Window *w) override;
559 NWidgetCore *GetWidgetFromPos(int x, int y) override;
560
561 bool SetDisplayedPlane(int plane);
562
563 int shown_plane = 0;
564private:
566};
567
569enum class NWidContainerFlag : uint8_t {
572};
573using NWidContainerFlags = EnumBitSet<NWidContainerFlag, uint8_t>;
574
576class NWidgetPIPContainer : public NWidgetContainer {
577public:
578 NWidgetPIPContainer(WidgetType tp, NWidContainerFlags flags = {}, WidgetID index = INVALID_WIDGET) : NWidgetContainer(tp, index), flags(flags) {}
579
580 void AdjustPaddingForZoom() override;
581 void SetPIP(uint8_t pip_pre, uint8_t pip_inter, uint8_t pip_post);
582 void SetPIPRatio(uint8_t pip_ratio_pre, uint8_t pip_ratio_inter, uint8_t pip_ratio_post);
583
584protected:
585 NWidContainerFlags flags{};
586 uint8_t pip_pre = 0;
587 uint8_t pip_inter = 0;
588 uint8_t pip_post = 0;
589 uint8_t pip_ratio_pre = 0;
590 uint8_t pip_ratio_inter = 0;
591 uint8_t pip_ratio_post = 0;
592
593 uint8_t uz_pip_pre = 0;
594 uint8_t uz_pip_inter = 0;
595 uint8_t uz_pip_post = 0;
596
597 uint8_t gaps = 0;
598};
599
604class NWidgetHorizontal : public NWidgetPIPContainer {
605public:
606 NWidgetHorizontal(NWidContainerFlags flags = {}, WidgetID index = INVALID_WIDGET, WidgetType type = NWID_HORIZONTAL) : NWidgetPIPContainer(type, flags, index) {}
607
608 void SetupSmallestSize(Window *w) override;
609 void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override;
610};
611
616class NWidgetHorizontalLTR : public NWidgetHorizontal {
617public:
618 NWidgetHorizontalLTR(NWidContainerFlags flags = {}, WidgetID index = INVALID_WIDGET) : NWidgetHorizontal(flags, index, NWID_HORIZONTAL_LTR) {}
619
620 void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override;
621};
622
627class NWidgetVertical : public NWidgetPIPContainer {
628public:
629 NWidgetVertical(NWidContainerFlags flags = {}, WidgetID index = INVALID_WIDGET) : NWidgetPIPContainer(NWID_VERTICAL, flags, index) {}
630
631 void SetupSmallestSize(Window *w) override;
632 void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override;
633
634 bool bottom_up = false;
635};
636
645class NWidgetMatrix : public NWidgetPIPContainer {
646public:
647 NWidgetMatrix(Colours colour, WidgetID index) : NWidgetPIPContainer(NWID_MATRIX, NWidContainerFlag::EqualSize, index), colour(colour) {}
648
649 void SetClicked(int clicked);
650 void SetCount(int count);
652 int GetCurrentElement() const;
653
654 void SetupSmallestSize(Window *w) override;
655 void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override;
656
657 NWidgetCore *GetWidgetFromPos(int x, int y) override;
658 void Draw(const Window *w) override;
659protected:
660 Colours colour{};
661 int clicked = -1;
662 int count = 0;
664 Scrollbar *sb = nullptr;
665private:
666 int widget_w = 0;
667 int widget_h = 0;
668 int widgets_x = 0;
669 int widgets_y = 0;
670
671 void GetScrollOffsets(int &start_x, int &start_y, int &base_offs_x, int &base_offs_y);
672};
673
674
680public:
681 NWidgetSpacer(int width, int height);
682
683 void SetupSmallestSize(Window *w) override;
684
685 void Draw(const Window *w) override;
686 void SetDirty(const Window *w) const override;
687 NWidgetCore *GetWidgetFromPos(int x, int y) override;
688};
689
695public:
696 NWidgetBackground(WidgetType tp, Colours colour, WidgetID index, std::unique_ptr<NWidgetPIPContainer> &&child = nullptr);
697
698 void Add(std::unique_ptr<NWidgetBase> &&nwid);
699 void SetPIP(uint8_t pip_pre, uint8_t pip_inter, uint8_t pip_post);
700 void SetPIPRatio(uint8_t pip_ratio_pre, uint8_t pip_ratio_inter, uint8_t pip_ratio_post);
701
702 void AdjustPaddingForZoom() override;
703 void SetupSmallestSize(Window *w) override;
704 void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override;
705
706 void FillWidgetLookup(WidgetLookup &widget_lookup) override;
707
708 void Draw(const Window *w) override;
709 NWidgetCore *GetWidgetFromPos(int x, int y) override;
711
712private:
713 std::unique_ptr<NWidgetPIPContainer> child{};
714};
715
725class NWidgetViewport : public NWidgetCore {
726public:
727 NWidgetViewport(WidgetID index);
728
729 void SetupSmallestSize(Window *w) override;
730 void Draw(const Window *w) override;
731
732 void InitializeViewport(Window *w, std::variant<TileIndex, VehicleID> focus, ZoomLevel zoom);
734};
735
739class Scrollbar {
740public:
741 using size_type = int32_t;
742 static constexpr size_type max_size_type = std::numeric_limits<size_type>::max();
743 static constexpr size_type npos = max_size_type;
744private:
745 const bool is_vertical = false;
746 size_type count = 0;
747 size_type cap = 0;
748 size_type pos = 0;
749 size_type stepsize = 1;
750
751public:
753 enum class Stepping : uint8_t {
757 };
758
760
765 inline size_type GetCount() const
766 {
767 return this->count;
768 }
769
774 inline size_type GetCapacity() const
775 {
776 return this->cap;
777 }
778
783 inline size_type GetPosition() const
784 {
785 return this->pos;
786 }
787
793 inline bool IsVisible(size_type item) const
794 {
795 return IsInsideBS(item, this->GetPosition(), this->GetCapacity());
796 }
797
802 inline bool IsVertical() const
803 {
804 return this->is_vertical;
805 }
806
812 {
813 assert(stepsize > 0);
814
815 this->stepsize = ClampTo<size_type>(stepsize);
816 }
817
823 void SetCount(size_t num)
824 {
825 assert(num < Scrollbar::max_size_type);
826
827 this->count = ClampTo<size_type>(num);
828 /* Ensure position is within bounds */
829 this->SetPosition(this->pos);
830 }
831
837 void SetCapacity(size_t capacity)
838 {
839 assert(capacity < Scrollbar::max_size_type);
840
841 this->cap = ClampTo<size_type>(capacity);
842 /* Ensure position is within bounds */
843 this->SetPosition(this->pos);
844 }
845
846 void SetCapacityFromWidget(Window *w, WidgetID widget, int padding = 0);
847
853 bool SetPosition(size_type position)
854 {
855 size_type old_pos = this->pos;
856 this->pos = Clamp(position, 0, std::max(this->count - this->cap, 0));
857 return this->pos != old_pos;
858 }
859
868 {
869 if (difference == 0) return false;
870 switch (unit) {
871 case Stepping::Small: difference *= this->stepsize; break;
872 case Stepping::Big: difference *= this->cap; break;
873 default: break;
874 }
875 return this->SetPosition(this->pos + difference);
876 }
877
884 void ScrollTowards(size_type position)
885 {
886 if (position < this->GetPosition()) {
887 /* scroll up to the item */
888 this->SetPosition(position);
889 } else if (position >= this->GetPosition() + this->GetCapacity()) {
890 /* scroll down so that the item is at the bottom */
891 this->SetPosition(position - this->GetCapacity() + 1);
892 }
893 }
894
895 size_type GetScrolledRowFromWidget(int clickpos, const Window * const w, WidgetID widget, int padding = 0, int line_height = -1) const;
896
902 template <typename Tcontainer>
903 auto GetVisibleRangeIterators(Tcontainer &container) const
904 {
905 assert(static_cast<size_t>(this->GetCount()) == container.size()); // Scrollbar and container size must match.
906 auto first = std::next(std::begin(container), this->GetPosition());
907 auto last = std::next(first, std::min<size_t>(this->GetCapacity(), this->GetCount() - this->GetPosition()));
908 return std::make_pair(first, last);
909 }
910
921 template <typename Tcontainer>
922 auto GetScrolledItemFromWidget(Tcontainer &container, int clickpos, const Window * const w, WidgetID widget, int padding = 0, int line_height = -1) const
923 {
924 assert(static_cast<size_t>(this->GetCount()) == container.size()); // Scrollbar and container size must match.
925 size_type row = this->GetScrolledRowFromWidget(clickpos, w, widget, padding, line_height);
926 if (row == Scrollbar::npos) return std::end(container);
927
928 return std::next(std::begin(container), row);
929 }
930
931 EventState UpdateListPositionOnKeyPress(int &list_position, uint16_t keycode) const;
932};
933
939class NWidgetScrollbar : public NWidgetCore, public Scrollbar {
940public:
942
943 void SetupSmallestSize(Window *w) override;
944 void Draw(const Window *w) override;
945
946 static void InvalidateDimensionCache();
947 static Dimension GetVerticalDimension();
948 static Dimension GetHorizontalDimension();
949
950private:
953};
954
959class NWidgetLeaf : public NWidgetCore {
960public:
961 NWidgetLeaf(WidgetType tp, Colours colour, WidgetID index, const WidgetData &data, StringID tip);
962
963 void SetupSmallestSize(Window *w) override;
964 void Draw(const Window *w) override;
965
966 bool ButtonHit(const Point &pt);
967
968 static void InvalidateDimensionCache();
969
973private:
978};
979
987inline uint ComputeMaxSize(uint base, uint max_space, uint step)
988{
989 if (base >= max_space || step == 0) return base;
990 if (step == 1) return max_space;
991 uint increment = max_space - base;
992 increment -= increment % step;
993 return base + increment;
994}
995
1044
1053
1062
1064 NWidContainerFlags flags;
1065 WidgetID index;
1066};
1067
1074
1080 uint8_t pre, inter, post;
1081};
1082
1092
1101
1109
1111 float ratio;
1112 AspectFlags flags;
1113};
1114
1119using NWidgetFunctionType = std::unique_ptr<NWidgetBase>();
1120
1125struct NWidgetPart {
1127 union NWidgetPartUnion {
1139
1140 /* Constructors for each NWidgetPartUnion data type. */
1141 constexpr NWidgetPartUnion() : xy() {}
1142 constexpr NWidgetPartUnion(Point xy) : xy(xy) {}
1143 constexpr NWidgetPartUnion(NWidgetPartDataTip data_tip) : data_tip(data_tip) {}
1144 constexpr NWidgetPartUnion(NWidgetPartWidget widget) : widget(widget) {}
1145 constexpr NWidgetPartUnion(NWidgetPartPaddings padding) : padding(padding) {}
1146 constexpr NWidgetPartUnion(NWidgetPartPIP pip) : pip(pip) {}
1147 constexpr NWidgetPartUnion(NWidgetPartTextLines text_lines) : text_lines(text_lines) {}
1148 constexpr NWidgetPartUnion(NWidgetPartTextStyle text_style) : text_style(text_style) {}
1149 constexpr NWidgetPartUnion(NWidgetPartAlignment align) : align(align) {}
1150 constexpr NWidgetPartUnion(NWidgetFunctionType *func_ptr) : func_ptr(func_ptr) {}
1151 constexpr NWidgetPartUnion(NWidgetPartContainer container) : container(container) {}
1152 constexpr NWidgetPartUnion(NWidgetPartAspect aspect) : aspect(aspect) {}
1153 } u;
1154
1155 /* Constructors for each NWidgetPart data type. */
1156 explicit constexpr NWidgetPart(WidgetType type) : type(type), u() {}
1157 constexpr NWidgetPart(WidgetType type, Point xy) : type(type), u(xy) {}
1158 constexpr NWidgetPart(WidgetType type, NWidgetPartDataTip data_tip) : type(type), u(data_tip) {}
1159 constexpr NWidgetPart(WidgetType type, NWidgetPartWidget widget) : type(type), u(widget) {}
1160 constexpr NWidgetPart(WidgetType type, NWidgetPartPaddings padding) : type(type), u(padding) {}
1161 constexpr NWidgetPart(WidgetType type, NWidgetPartPIP pip) : type(type), u(pip) {}
1162 constexpr NWidgetPart(WidgetType type, NWidgetPartTextLines text_lines) : type(type), u(text_lines) {}
1163 constexpr NWidgetPart(WidgetType type, NWidgetPartTextStyle text_style) : type(type), u(text_style) {}
1164 constexpr NWidgetPart(WidgetType type, NWidgetPartAlignment align) : type(type), u(align) {}
1165 constexpr NWidgetPart(WidgetType type, NWidgetFunctionType *func_ptr) : type(type), u(func_ptr) {}
1166 constexpr NWidgetPart(WidgetType type, NWidgetPartContainer container) : type(type), u(container) {}
1167 constexpr NWidgetPart(WidgetType type, NWidgetPartAspect aspect) : type(type), u(aspect) {}
1168};
1169
1177constexpr NWidgetPart SetResize(int16_t dx, int16_t dy)
1178{
1179 return NWidgetPart{WPT_RESIZE, Point{dx, dy}};
1180}
1181
1189constexpr NWidgetPart SetMinimalSize(int16_t x, int16_t y)
1190{
1191 return NWidgetPart{WPT_MINSIZE, Point{x, y}};
1192}
1193
1200{
1201 return NWidgetPart{WPT_MINSIZE, Point{4, 0}};
1202}
1203
1211{
1212 return NWidgetPart{WPT_TOOLBARSIZE, Point{width, 1}};
1213}
1214
1223constexpr NWidgetPart SetMinimalTextLines(uint8_t lines, uint8_t spacing, FontSize size = FS_NORMAL)
1224{
1225 return NWidgetPart{WPT_MINTEXTLINES, NWidgetPartTextLines{lines, spacing, size}};
1226}
1227
1236{
1237 return NWidgetPart{WPT_TEXTSTYLE, NWidgetPartTextStyle{colour, size}};
1238}
1239
1250
1258constexpr NWidgetPart SetFill(uint16_t fill_x, uint16_t fill_y)
1259{
1260 return NWidgetPart{WPT_FILL, Point{fill_x, fill_y}};
1261}
1262
1270{
1272}
1273
1281constexpr NWidgetPart SetStringTip(StringID string, StringID tip = {})
1282{
1283 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{.string = string}, tip}};
1284}
1285
1293constexpr NWidgetPart SetSpriteTip(SpriteID sprite, StringID tip = {})
1294{
1295 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{.sprite = sprite}, tip}};
1296}
1297
1306constexpr NWidgetPart SetSpriteStringTip(SpriteID sprite, StringID string, StringID tip = {})
1307{
1308 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{.string = string, .sprite = sprite}, tip}};
1309}
1310
1319{
1320 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{.arrow_widget_type = widget_type}, tip}};
1321}
1322
1331{
1332 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{.resize_widget_type = widget_type}, tip}};
1333}
1334
1342constexpr NWidgetPart SetAlternateColourTip(Colours colour, StringID tip)
1343{
1344 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{.alternate_colour = colour}, tip}};
1345}
1346
1355constexpr NWidgetPart SetMatrixDataTip(uint32_t cols, uint32_t rows, StringID tip = {})
1356{
1357 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{.matrix{ cols, rows }}, tip}};
1358}
1359
1367{
1368 return NWidgetPart{WPT_DATATIP, NWidgetPartDataTip{{}, tip}};
1369}
1370
1381constexpr NWidgetPart SetPadding(uint8_t top, uint8_t right, uint8_t bottom, uint8_t left)
1382{
1383 return NWidgetPart{WPT_PADDING, NWidgetPartPaddings{left, top, right, bottom}};
1384}
1385
1393constexpr NWidgetPart SetPadding(uint8_t horizontal, uint8_t vertical)
1394{
1395 return NWidgetPart{WPT_PADDING, NWidgetPartPaddings{horizontal, vertical, horizontal, vertical}};
1396}
1397
1404constexpr NWidgetPart SetPadding(const RectPadding &padding)
1405{
1407}
1408
1415constexpr NWidgetPart SetPadding(uint8_t padding)
1416{
1417 return SetPadding(padding, padding, padding, padding);
1418}
1419
1428constexpr NWidgetPart SetPIP(uint8_t pre, uint8_t inter, uint8_t post)
1429{
1430 return NWidgetPart{WPT_PIPSPACE, NWidgetPartPIP{pre, inter, post}};
1431}
1432
1441constexpr NWidgetPart SetPIPRatio(uint8_t ratio_pre, uint8_t ratio_inter, uint8_t ratio_post)
1442{
1443 return NWidgetPart{WPT_PIPRATIO, NWidgetPartPIP{ratio_pre, ratio_inter, ratio_post}};
1444}
1445
1455{
1456 return NWidgetPart{WPT_SCROLLBAR, NWidgetPartWidget{INVALID_COLOUR, index}};
1457}
1458
1466constexpr NWidgetPart SetAspect(float ratio, AspectFlags flags = AspectFlag::ResizeX)
1467{
1468 return NWidgetPart{WPT_ASPECT, NWidgetPartAspect{ratio, flags}};
1469}
1470
1481constexpr NWidgetPart NWidget(WidgetType tp, Colours col, WidgetID idx = INVALID_WIDGET)
1482{
1483 return NWidgetPart{tp, NWidgetPartWidget{col, idx}};
1484}
1485
1494constexpr NWidgetPart NWidget(WidgetType tp, NWidContainerFlags cont_flags = {}, WidgetID idx = INVALID_WIDGET)
1495{
1496 return NWidgetPart{tp, NWidgetPartContainer{cont_flags, idx}};
1497}
1498
1506{
1507 return NWidgetPart{WPT_FUNCTION, func_ptr};
1508}
1509
1511std::unique_ptr<NWidgetBase> MakeNWidgets(std::span<const NWidgetPart> nwid_parts, std::unique_ptr<NWidgetBase> &&container);
1512std::unique_ptr<NWidgetBase> MakeWindowNWidgetTree(std::span<const NWidgetPart> nwid_parts, NWidgetStacked **shade_select);
1513
1514std::unique_ptr<NWidgetBase> MakeCompanyButtonRows(WidgetID widget_first, WidgetID widget_last, Colours button_colour, int max_length, StringID button_tooltip, bool resizable = true);
1515
1517
1518#endif /* WIDGET_TYPE_H */
Enum-as-bit-set wrapper.
NWidgetCore * GetWidgetFromPos(int x, int y) override
Retrieve a widget by its position.
Definition widget.cpp:2370
NWidgetBase * GetWidgetOfType(WidgetType tp) override
Retrieve a widget by its type.
Definition widget.cpp:2380
void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
Assign size and position to the widget.
Definition widget.cpp:2316
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:2247
void AdjustPaddingForZoom() override
Adjust the padding based on the user interface zoom.
Definition widget.cpp:2241
NWidgetBackground(WidgetType tp, Colours colour, WidgetID index, std::unique_ptr< NWidgetPIPContainer > &&child=nullptr)
Constructor parent nested widgets.
Definition widget.cpp:2179
void SetPIP(uint8_t pip_pre, uint8_t pip_inter, uint8_t pip_post)
Set additional pre/inter/post space for the background widget.
Definition widget.cpp:2213
std::unique_ptr< NWidgetPIPContainer > child
Child widget.
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:2334
void Add(std::unique_ptr< NWidgetBase > &&nwid)
Add a child to the parent.
Definition widget.cpp:2194
void FillWidgetLookup(WidgetLookup &widget_lookup) override
Fill the Window::widget_lookup with pointers to nested widgets in the tree.
Definition widget.cpp:2328
void SetPIPRatio(uint8_t pip_ratio_pre, uint8_t pip_ratio_inter, uint8_t pip_ratio_post)
Set additional pre/inter/post space ratios for the background widget.
Definition widget.cpp:2232
Baseclass for nested widgets.
void StoreSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height)
Store size and position.
virtual TextColour GetHighlightColour() const
Get the colour of the highlighted text.
virtual ~NWidgetBase()=default
Ensure the destructor of the sub classes are called as well.
float aspect_ratio
Desired aspect ratio of widget.
uint GetHorizontalStepSize(SizingType sizing) const
Get the horizontal sizing step.
virtual bool IsHighlighted() const
Whether the widget is currently highlighted or not.
virtual void AdjustPaddingForZoom()
Adjust the padding based on the user interface zoom.
Definition widget.cpp:990
virtual void SetDirty(const Window *w) const
Mark the widget as 'dirty' (in need of repaint).
Definition widget.cpp:951
WidgetType type
Type of the widget / nested widget.
uint resize_x
Horizontal resize step (0 means not resizable).
uint fill_x
Horizontal fill stepsize (from initial size, 0 means not resizable).
NWID * GetParentWidget()
Get parent widget of type NWID.
NWidgetBase * parent
Parent widget of this widget, automatically filled in when added to container.
RectPadding uz_padding
Unscaled padding, for resize calculation.
virtual void SetupSmallestSize(Window *w)=0
Compute smallest size needed by the widget.
uint smallest_x
Smallest horizontal size of the widget in a filled window.
AspectFlags aspect_flags
Which dimensions can be resized.
uint current_x
Current horizontal size (after resizing).
int pos_y
Vertical position of top-left corner of the widget in the window.
int pos_x
Horizontal position of top-left corner of the widget in the window.
virtual void Draw(const Window *w)=0
Draw the widgets of the tree.
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.
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.
uint smallest_y
Smallest vertical size of the widget in a filled window.
const WidgetID index
Index of the nested widget (INVALID_WIDGET means 'not used').
virtual NWidgetBase * GetWidgetOfType(WidgetType tp)
Retrieve a widget by its type.
Definition widget.cpp:971
uint fill_y
Vertical fill stepsize (from initial size, 0 means not resizable).
uint resize_y
Vertical resize step (0 means not resizable).
virtual void SetHighlighted(TextColour highlight_colour)
Highlight the widget or not.
RectPadding padding
Padding added to the widget. Managed by parent container widget. (parent container may swap left and ...
virtual NWidgetCore * GetWidgetFromPos(int x, int y)=0
Retrieve a widget by its position.
uint current_y
Current vertical size (after resizing).
virtual void FillWidgetLookup(WidgetLookup &widget_lookup)
Fill the Window::widget_lookup with pointers to nested widgets in the tree.
Definition widget.cpp:935
uint GetVerticalStepSize(SizingType sizing) const
Get the vertical sizing step.
const NWID * GetParentWidget() const
Get parent widget of type NWID.
void Add(std::unique_ptr< NWidgetBase > &&wid)
Append widget wid to container.
Definition widget.cpp:1323
void FillWidgetLookup(WidgetLookup &widget_lookup) override
Fill the Window::widget_lookup with pointers to nested widgets in the tree.
Definition widget.cpp:1330
void UnfocusWidgets(Window *parent_window)
Unfocuses the focused widget of the window, if the focused widget is contained inside the container.
Definition widget.cpp:3526
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:1338
bool IsEmpty()
Return whether the container is empty.
std::vector< std::unique_ptr< NWidgetBase > > children
Child widgets in container.
void Clear(Window *parent_window)
Clears the container, deleting all widgets that were contained.
NWidgetCore * GetWidgetFromPos(int x, int y) override
Retrieve a widget by its position.
Definition widget.cpp:1347
void AdjustPaddingForZoom() override
Adjust the padding based on the user interface zoom.
Definition widget.cpp:1311
NWidgetBase * GetWidgetOfType(WidgetType tp) override
Retrieve a widget by its type.
Definition widget.cpp:1301
Base class for a 'real' widget.
WidgetData widget_data
Data of the widget.
void SetToolTip(StringID tool_tip)
Set the tool tip of the nested widget.
Definition widget.cpp:1255
bool IsHighlighted() const override
Whether the widget is currently highlighted or not.
bool IsDisabled() const
Return whether the widget is disabled.
void SetSprite(SpriteID sprite)
Set sprite of the nested widget.
Definition widget.cpp:1205
NWidgetDisplayFlags disp_flags
Flags that affect display and interaction with the widget.
void SetTextStyle(TextColour colour, FontSize size)
Set the text style of the nested widget.
Definition widget.cpp:1245
WidgetID GetScrollbarIndex() const
Get the WidgetID of this nested widget's scrollbar.
Definition widget.cpp:1291
TextColour highlight_colour
Colour of highlight.
void SetAlignment(StringAlignment align)
Set the text/image alignment of the nested widget.
Definition widget.cpp:1273
void SetResizeWidgetType(ResizeWidgetType type)
Set the resize widget type of the nested widget.
Definition widget.cpp:1235
NWidgetCore(WidgetType tp, Colours colour, WidgetID index, uint fill_x, uint fill_y, const WidgetData &widget_data, StringID tool_tip)
Initialization of a 'real' widget.
Definition widget.cpp:1173
void SetSpriteTip(SpriteID sprite, StringID tool_tip)
Set sprite and tool tip of the nested widget.
Definition widget.cpp:1215
StringAlignment align
Alignment of text/image within widget.
FontSize text_size
Size of text within widget.
void SetHighlighted(TextColour highlight_colour) override
Highlight the widget or not.
StringID GetString() const
Get the string that has been set for this nested widget.
Definition widget.cpp:1282
WidgetID scrollbar_index
Index of an attached scrollbar.
StringID GetToolTip() const
Get the tool tip of the nested widget.
Definition widget.cpp:1264
NWidgetCore * GetWidgetFromPos(int x, int y) override
Retrieve a widget by its position.
Definition widget.cpp:1296
void SetString(StringID string)
Set string of the nested widget.
Definition widget.cpp:1185
TextColour text_colour
Colour of text within widget.
Colours colour
Colour of this widget.
void SetMatrixDimension(uint32_t columns, uint32_t rows)
Set the matrix dimension.
Definition widget.cpp:1226
void SetLowered(bool lowered)
Lower or raise the widget.
TextColour GetHighlightColour() const override
Get the colour of the highlighted text.
void SetStringTip(StringID string, StringID tool_tip)
Set string and tool tip of the nested widget.
Definition widget.cpp:1195
StringID tool_tip
Tooltip of the widget.
void SetDisabled(bool disabled)
Disable (grey-out) or enable the widget.
bool IsLowered() const
Return whether the widget is lowered.
void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
Assign size and position to the widget.
Definition widget.cpp:1744
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:1566
void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
Assign size and position to the widget.
Definition widget.cpp:1635
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:2998
static void InvalidateDimensionCache()
Reset the cached dimensions.
Definition widget.cpp:2675
static Dimension resizebox_dimension
Cached size of a resizebox widget.
static Dimension shadebox_dimension
Cached size of a shadebox widget.
static Dimension closebox_dimension
Cached size of a closebox widget.
static Dimension stickybox_dimension
Cached size of a stickybox widget.
NWidgetLeaf(WidgetType tp, Colours colour, WidgetID index, const WidgetData &data, StringID tip)
Nested leaf widget.
Definition widget.cpp:2702
static Dimension defsizebox_dimension
Cached size of a defsizebox widget.
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:2811
static Dimension dropdown_dimension
Cached size of a dropdown widget.
static Dimension debugbox_dimension
Cached size of a debugbox widget.
bool ButtonHit(const Point &pt)
For a NWID_BUTTON_DROPDOWN, test whether pt refers to the button or to the drop-down.
Definition widget.cpp:3142
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:2093
int count
Amount of valid elements.
void SetClicked(int clicked)
Sets the clicked element in the matrix.
Definition widget.cpp:1962
int GetCurrentElement() const
Get current element.
Definition widget.cpp:2012
Scrollbar * sb
The scrollbar we're associated with.
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:2017
int widget_w
The width of the child widget including inter spacing.
void SetScrollbar(Scrollbar *sb)
Assign a scrollbar to this matrix.
Definition widget.cpp:2003
void GetScrollOffsets(int &start_x, int &start_y, int &base_offs_x, int &base_offs_y)
Get the different offsets that are influenced by scrolling.
Definition widget.cpp:2148
int current_element
The element currently being processed.
int widgets_x
The number of visible widgets in horizontal direction.
int widget_h
The height of the child widget including inter spacing.
void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
Assign size and position to the widget.
Definition widget.cpp:2039
NWidgetCore * GetWidgetFromPos(int x, int y) override
Retrieve a widget by its position.
Definition widget.cpp:2063
int clicked
The currently clicked element.
void SetCount(int count)
Set the number of elements in this matrix.
Definition widget.cpp:1979
int widgets_y
The number of visible widgets in vertical direction.
Colours colour
Colour of this widget.
uint8_t gaps
Number of gaps between widgets.
NWidContainerFlags flags
Flags of the container.
uint8_t pip_pre
Amount of space before first widget.
uint8_t uz_pip_pre
Unscaled space before first widget.
void 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.
Definition widget.cpp:1559
uint8_t uz_pip_inter
Unscaled space between widgets.
uint8_t pip_ratio_pre
Ratio of remaining space before first widget.
void AdjustPaddingForZoom() override
Adjust the padding based on the user interface zoom.
Definition widget.cpp:1522
void SetPIP(uint8_t pip_pre, uint8_t pip_inter, uint8_t pip_post)
Set additional pre/inter/post space for the container.
Definition widget.cpp:1539
uint8_t pip_post
Amount of space after last widget.
uint8_t pip_ratio_inter
Ratio of remaining space between widgets.
uint8_t pip_ratio_post
Ratio of remaining space after last widget.
uint8_t uz_pip_post
Unscaled space after last widget.
uint8_t pip_inter
Amount of space between widgets.
uint8_t uz_text_spacing
'Unscaled' text padding, stored for resize calculation.
bool absolute
Set if minimum size is fixed and should not be resized.
void SetMinimalSize(uint min_x, uint min_y)
Set minimal size of the widget.
Definition widget.cpp:1048
bool UpdateSize(uint min_x, uint min_y)
Set absolute (post-scaling) minimal size of the widget.
Definition widget.cpp:1137
void AdjustPaddingForZoom() override
Adjust the padding based on the user interface zoom.
Definition widget.cpp:1030
uint min_x
Minimal horizontal size of only this widget.
FontSize uz_text_size
'Unscaled' font size, stored for resize calculation.
NWidgetResizeBase(WidgetType tp, WidgetID index, uint fill_x, uint fill_y)
Constructor for resizable nested widgets.
Definition widget.cpp:1002
uint uz_min_x
Unscaled Minimal horizontal size of only this widget.
uint8_t uz_text_lines
'Unscaled' text lines, stored for resize calculation.
void SetFill(uint fill_x, uint fill_y)
Set the filling of the widget from initial size.
Definition widget.cpp:1093
void SetToolbarMinimalSize(uint8_t toolbar_size)
Set minimal size of the widget in toolbar-icon-relative width.
Definition widget.cpp:1058
void SetMinimalTextLines(uint8_t min_lines, uint8_t spacing, FontSize size)
Set minimal text lines for the widget.
Definition widget.cpp:1081
uint min_y
Minimal vertical size of only this widget.
uint uz_min_y
Unscaled Minimal vertical size of only this widget.
bool UpdateMultilineWidgetSize(const std::string &str, int max_lines)
Try to set optimum widget size for a multiline text widget.
Definition widget.cpp:1117
void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
Assign size and position to the widget.
Definition widget.cpp:1158
bool UpdateVerticalSize(uint min_y)
Set absolute (post-scaling) minimal size of the widget.
Definition widget.cpp:1151
void SetResize(uint resize_x, uint resize_y)
Set resize step of the widget.
Definition widget.cpp:1104
uint8_t toolbar_size
Minimal size in terms of toolbar images.
void SetAspect(float ratio, AspectFlags flags=AspectFlag::ResizeX)
Set desired aspect ratio of this widget.
Definition widget.cpp:1013
void SetMinimalSizeAbsolute(uint min_x, uint min_y)
Set absolute (post-scaling) minimal size of the widget.
Definition widget.cpp:1068
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:2619
NWidgetScrollbar(WidgetType tp, Colours colour, WidgetID index)
Scrollbar widget.
Definition widget.cpp:2577
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:2598
static Dimension horizontal_dimension
Cached size of horizontal scrollbar button.
static Dimension vertical_dimension
Cached size of vertical scrollbar button.
NWidgetSpacer(int width, int height)
Generic spacer widget.
Definition widget.cpp:1923
NWidgetCore * GetWidgetFromPos(int x, int y) override
Retrieve a widget by its position.
Definition widget.cpp:1953
void SetDirty(const Window *w) const override
Mark the widget as 'dirty' (in need of repaint).
Definition widget.cpp:1948
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:1936
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:1929
Stacked widgets, widgets all occupying the same space in the window.
int shown_plane
Plane being displayed (for NWID_SELECTION only).
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:1358
WidgetLookup * widget_lookup
Window's widget lookup, updated in SetDisplayedPlane().
void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
Assign size and position to the widget.
Definition widget.cpp:1399
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:1429
bool SetDisplayedPlane(int plane)
Select which plane to show (for NWID_SELECTION only).
Definition widget.cpp:1453
void FillWidgetLookup(WidgetLookup &widget_lookup) override
Fill the Window::widget_lookup with pointers to nested widgets in the tree.
Definition widget.cpp:1419
NWidgetCore * GetWidgetFromPos(int x, int y) override
Retrieve a widget by its position.
Definition widget.cpp:1438
void AssignSizePosition(SizingType sizing, int x, int y, uint given_width, uint given_height, bool rtl) override
Assign size and position to the widget.
Definition widget.cpp:1818
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:1749
bool bottom_up
Set to flow the widget from bottom-to-top instead of top-to-bottom.
void UpdateViewportCoordinates(Window *w)
Update the position and size of the viewport (after eg a resize).
Definition widget.cpp:2435
void Draw(const Window *w) override
Draw the widgets of the tree.
Definition widget.cpp:2399
void SetupSmallestSize(Window *w) override
Compute smallest size needed by the widget.
Definition widget.cpp:2392
void InitializeViewport(Window *w, std::variant< TileIndex, VehicleID > focus, ZoomLevel zoom)
Initialize the viewport of the window.
Definition widget.cpp:2426
Scrollbar data structure.
bool IsVisible(size_type item) const
Checks whether given current item is visible in the list.
const bool is_vertical
Scrollbar has vertical orientation.
size_type GetCapacity() const
Gets the number of visible elements of the scrollbar.
size_type stepsize
Distance to scroll, when pressing the buttons or using the wheel.
void SetCount(size_t num)
Sets the number of elements in the list.
bool IsVertical() const
Is the scrollbar vertical or not?
auto GetScrolledItemFromWidget(Tcontainer &container, int clickpos, const Window *const w, WidgetID widget, int padding=0, int line_height=-1) const
Return an iterator pointing to the element of a scrolled widget that a user clicked in.
bool UpdatePosition(int difference, Scrollbar::Stepping unit=Stepping::Small)
Updates the position of the first visible element by the given amount.
Stepping
Stepping sizes when scrolling.
@ Small
Step in stepsize units.
@ Single
Step in single units.
@ Big
Step in cap units.
void SetCapacity(size_t capacity)
Set the capacity of visible elements.
size_type cap
Number of visible elements of the scroll bar.
size_type GetScrolledRowFromWidget(int clickpos, const Window *const w, WidgetID widget, int padding=0, int line_height=-1) const
Compute the row of a scrolled widget that a user clicked in.
Definition widget.cpp:2458
size_type count
Number of elements in the list.
bool SetPosition(size_type position)
Sets the position of the first visible element.
void SetCapacityFromWidget(Window *w, WidgetID widget, int padding=0)
Set capacity of visible elements from the size and resize properties of a widget.
Definition widget.cpp:2532
size_type GetCount() const
Gets the number of elements in the list.
EventState UpdateListPositionOnKeyPress(int &list_position, uint16_t keycode) const
Update the given list position as if it were on this scroll bar when the given keycode was pressed.
Definition widget.cpp:2479
void ScrollTowards(size_type position)
Scroll towards the given position; if the item is visible nothing happens, otherwise it will be shown...
auto GetVisibleRangeIterators(Tcontainer &container) const
Get a pair of iterators for the range of visible elements in a container.
void SetStepSize(size_t stepsize)
Set the distance to scroll when using the buttons or the wheel.
size_type pos
Index of first visible item of the list.
size_type GetPosition() const
Gets the position of the first visible element in the list.
Types related to the graphics and/or input devices.
uint32_t SpriteID
The number of a sprite, without mapping bits and colourtables.
Definition gfx_type.h:17
FontSize
Available font sizes.
Definition gfx_type.h:248
@ FS_NORMAL
Index of the normal font in the font tables.
Definition gfx_type.h:249
StringAlignment
How to align the to-be drawn text.
Definition gfx_type.h:387
@ SA_CENTER
Center both horizontally and vertically.
Definition gfx_type.h:398
TextColour
Colour of the strings, see _string_colourmap in table/string_colours.h or docs/ottd-colourtext-palett...
Definition gfx_type.h:307
constexpr NWidgetPart SetMatrixDataTip(uint32_t cols, uint32_t rows, StringID tip={})
Widget part function for setting the data and tooltip of WWT_MATRIX widgets.
constexpr NWidgetPart NWidgetFunction(NWidgetFunctionType *func_ptr)
Obtain a nested widget (sub)tree from an external source.
constexpr NWidgetPart SetFill(uint16_t fill_x, uint16_t fill_y)
Widget part function for setting filling.
constexpr NWidgetPart SetSpriteTip(SpriteID sprite, StringID tip={})
Widget part function for setting the sprite and tooltip.
constexpr NWidgetPart SetResizeWidgetTypeTip(ResizeWidgetType widget_type, StringID tip)
Widget part function for setting the resize widget type and tooltip.
constexpr NWidgetPart SetToolbarMinimalSize(int width)
Widget part function to setting the minimal size for a toolbar button.
constexpr NWidgetPart SetPIP(uint8_t pre, uint8_t inter, uint8_t post)
Widget part function for setting a pre/inter/post spaces.
constexpr NWidgetPart SetScrollbar(WidgetID index)
Attach a scrollbar to a widget.
constexpr NWidgetPart SetPadding(uint8_t top, uint8_t right, uint8_t bottom, uint8_t left)
Widget part function for setting additional space around a widget.
constexpr NWidgetPart SetAlternateColourTip(Colours colour, StringID tip)
Widget part function for setting the alternate colour and tooltip.
constexpr NWidgetPart SetStringTip(StringID string, StringID tip={})
Widget part function for setting the string and tooltip.
constexpr NWidgetPart SetAspect(float ratio, AspectFlags flags=AspectFlag::ResizeX)
Widget part function for setting the aspect ratio.
constexpr NWidgetPart SetTextStyle(TextColour colour, FontSize size=FS_NORMAL)
Widget part function for setting the text style.
std::unique_ptr< NWidgetBase > MakeWindowNWidgetTree(std::span< const NWidgetPart > nwid_parts, NWidgetStacked **shade_select)
Make a nested widget tree for a window from a parts array.
Definition widget.cpp:3434
constexpr NWidgetPart SetToolbarSpacerMinimalSize()
Widget part function to setting the minimal size for a toolbar spacer.
constexpr NWidgetPart SetMinimalSize(int16_t x, int16_t y)
Widget part function for setting the minimal size.
std::unique_ptr< NWidgetBase > MakeNWidgets(std::span< const NWidgetPart > nwid_parts, std::unique_ptr< NWidgetBase > &&container)
Construct a nested widget tree from an array of parts.
Definition widget.cpp:3415
constexpr NWidgetPart SetSpriteStringTip(SpriteID sprite, StringID string, StringID tip={})
Widget part function for setting the sprite, string and tooltip.
constexpr NWidgetPart SetToolTip(StringID tip)
Widget part function for setting tooltip and clearing the widget data.
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.
constexpr NWidgetPart SetMinimalTextLines(uint8_t lines, uint8_t spacing, FontSize size=FS_NORMAL)
Widget part function for setting the minimal text lines.
constexpr NWidgetPart SetAlignment(StringAlignment align)
Widget part function for setting the alignment of text/images.
constexpr NWidgetPart SetArrowWidgetTypeTip(ArrowWidgetType widget_type, StringID tip={})
Widget part function for setting the arrow widget type and tooltip.
constexpr NWidgetPart SetResize(int16_t dx, int16_t dy)
Widget part function for setting the resize step.
constexpr NWidgetPart SetPIPRatio(uint8_t ratio_pre, uint8_t ratio_inter, uint8_t ratio_post)
Widget part function for setting a pre/inter/post ratio.
#define Rect
Macro that prevents name conflicts between included headers.
#define Point
Macro that prevents name conflicts between included headers.
Integer math functions.
constexpr bool IsInsideBS(const T x, const size_t base, const size_t size)
Checks if a value is between a window started at some base point.
constexpr T Clamp(const T a, const T min, const T max)
Clamp a value between an interval.
Definition math_func.hpp:79
constexpr To ClampTo(From value)
Clamp the given value down to lie within the requested type.
Types related to strings.
uint32_t StringID
Numeric value that represents a string, independent of the selected language.
Dimensions (a width and height) of a rectangle in 2D.
Widget part for setting text/image alignment within a widget.
StringAlignment align
Alignment of text/image.
Widget part for storing data and tooltip information.
WidgetData data
Data value of the widget.
StringID tooltip
Tooltip of the widget.
Widget part for storing pre/inter/post spaces.
uint8_t post
Amount of space before/between/after child widgets.
Widget part for storing padding.
Widget part for storing minimal text line data.
uint8_t lines
Number of text lines.
uint8_t spacing
Extra spacing around lines.
FontSize size
Font size of text lines.
Widget part for storing text colour.
TextColour colour
TextColour for DrawString.
FontSize size
Font size of text.
Widget part for storing basic widget information.
Colours colour
Widget colour.
WidgetID index
Index of the widget.
Partial widget specification to allow NWidgets to be written nested.
WidgetType type
Type of the part.
Padding dimensions to apply to each side of a Rect.
Container with the data associated to a single widget.
Data structure for an opened window.
Definition window_gui.h:274
NWidgetPartContainer container
Part with container flags.
NWidgetPartTextLines text_lines
Part with text line data.
NWidgetPartPIP pip
Part with pre/inter/post spaces.
NWidgetPartPaddings padding
Part with paddings.
NWidgetFunctionType * func_ptr
Part with a function call.
NWidgetPartDataTip data_tip
Part with a data/tooltip.
NWidgetPartAlignment align
Part with internal alignment.
NWidgetPartAspect aspect
Part to set aspect ratio.
NWidgetPartTextStyle text_style
Part with text style data.
Point xy
Part with an x/y size.
NWidgetPartWidget widget
Part with a start of a widget.
WidgetType
Window widget types, nested widget types, and nested widget part types.
Definition widget_type.h:35
@ WWT_PUSHTXTBTN
Normal push-button (no toggle button) with text caption.
@ WWT_INSET
Pressed (inset) panel, most commonly used as combo box text area.
Definition widget_type.h:40
@ WPT_FILL
Widget part for specifying fill.
Definition widget_type.h:84
@ WWT_PUSHIMGTEXTBTN
Normal push-button (no toggle button) with image and text caption.
@ WPT_ALIGNMENT
Widget part for specifying text/image alignment.
Definition widget_type.h:90
@ WWT_IMGBTN
(Toggle) Button with image
Definition widget_type.h:41
@ WWT_PUSHBTN
Normal push-button (no toggle button) with custom drawing.
@ WWT_IMGBTN_2
(Toggle) Button with diff image when clicked
Definition widget_type.h:42
@ NWID_CUSTOM
General Custom widget.
Definition widget_type.h:77
@ WWT_PUSHIMGBTN
Normal push-button (no toggle button) with image caption.
@ WPT_MINSIZE
Widget part for specifying minimal size.
Definition widget_type.h:82
@ WWT_PUSHARROWBTN
Normal push-button (no toggle button) with arrow caption.
@ WWT_LABEL
Centered label.
Definition widget_type.h:48
@ NWID_BUTTON_DROPDOWN
Button with a drop-down.
Definition widget_type.h:74
@ NWID_SPACER
Invisible widget that takes some space.
Definition widget_type.h:70
@ WWT_EDITBOX
a textbox for typing
Definition widget_type.h:62
@ WWT_ARROWBTN
(Toggle) Button with an arrow
Definition widget_type.h:43
@ NWID_HORIZONTAL
Horizontal container.
Definition widget_type.h:66
@ WWT_TEXTBTN
(Toggle) Button with text
Definition widget_type.h:44
@ WPT_SCROLLBAR
Widget part for attaching a scrollbar.
Definition widget_type.h:91
@ WWT_PANEL
Simple depressed panel.
Definition widget_type.h:39
@ WPT_ASPECT
Widget part for specifying aspect ratio.
Definition widget_type.h:92
@ WWT_STICKYBOX
Sticky box (at top-right of a window, after WWT_DEFSIZEBOX).
Definition widget_type.h:57
@ WPT_RESIZE
Widget part for specifying resizing.
Definition widget_type.h:81
@ WWT_IMGTEXTBTN
(Toggle) Button with image and text
Definition widget_type.h:47
@ WWT_MATRIX
Grid of rows and columns.
Definition widget_type.h:50
@ WWT_SHADEBOX
Shade box (at top-right of a window, between WWT_DEBUGBOX and WWT_DEFSIZEBOX).
Definition widget_type.h:55
@ WPT_TOOLBARSIZE
Widget part for specifying minimal size in terms of toolbar images.
Definition widget_type.h:93
@ WWT_CAPTION
Window caption (window title between closebox and stickybox).
Definition widget_type.h:52
@ NWID_VSCROLLBAR
Vertical scrollbar.
Definition widget_type.h:76
@ WPT_TEXTSTYLE
Widget part for specifying text colour.
Definition widget_type.h:89
@ WPT_PADDING
Widget part for specifying a padding.
Definition widget_type.h:86
@ WWT_BOOLBTN
Standard boolean toggle button.
Definition widget_type.h:46
@ NWID_VERTICAL
Vertical container.
Definition widget_type.h:68
@ WWT_CLOSEBOX
Close box (at top-left of a window).
Definition widget_type.h:60
@ WWT_TEXTBTN_2
(Toggle) Button with diff text when clicked
Definition widget_type.h:45
@ WWT_FRAME
Frame.
Definition widget_type.h:51
@ WPT_MINTEXTLINES
Widget part for specifying minimal number of lines of text.
Definition widget_type.h:83
@ WWT_EMPTY
Empty widget, place holder to reserve space in widget tree.
Definition widget_type.h:37
@ WWT_LAST
Last Item. use WIDGETS_END to fill up padding!!
Definition widget_type.h:63
@ WPT_ATTRIBUTE_END
End marker for attribute NWidgetPart types.
Definition widget_type.h:94
@ NWID_HSCROLLBAR
Horizontal scrollbar.
Definition widget_type.h:75
@ WPT_ENDCONTAINER
Widget part to denote end of a container.
Definition widget_type.h:97
@ WWT_RESIZEBOX
Resize box (normally at bottom-right of a window).
Definition widget_type.h:59
@ WPT_PIPRATIO
Widget part for specifying pre/inter/post ratio for containers.
Definition widget_type.h:88
@ WPT_DATATIP
Widget part for specifying data and tooltip.
Definition widget_type.h:85
@ WWT_DEFSIZEBOX
Default window size box (at top-right of a window, between WWT_SHADEBOX and WWT_STICKYBOX).
Definition widget_type.h:56
@ WPT_ATTRIBUTE_BEGIN
Begin marker for attribute NWidgetPart types.
Definition widget_type.h:80
@ WPT_PIPSPACE
Widget part for specifying pre/inter/post space for containers.
Definition widget_type.h:87
@ NWID_MATRIX
Matrix container.
Definition widget_type.h:69
@ NWID_VIEWPORT
Nested widget containing a viewport.
Definition widget_type.h:73
@ WWT_DROPDOWN
Drop down list.
Definition widget_type.h:61
@ WWT_TEXT
Pure simple text.
Definition widget_type.h:49
@ NWID_HORIZONTAL_LTR
Horizontal container that doesn't change the order of the widgets for RTL languages.
Definition widget_type.h:67
@ WPT_FUNCTION
Widget part for calling a user function.
Definition widget_type.h:96
@ WWT_DEBUGBOX
NewGRF debug box (at top-right of a window, between WWT_CAPTION and WWT_SHADEBOX).
Definition widget_type.h:54
@ NWID_LAYER
Layered widgets, all visible together.
Definition widget_type.h:72
@ NWID_SELECTION
Stacked widgets, only one visible at a time (eg in a panel with tabs).
Definition widget_type.h:71
NWidgetDisplayFlag
Nested widget flags that affect display and interaction with 'real' widgets.
@ Highlight
Highlight of widget is on.
@ ScrollbarDown
Down-button is lowered bit.
@ ShadeGrey
Shade viewport to grey-scale.
@ NoTransparency
Viewport is never transparent.
@ ShadeDimmed
Display dimmed colours in the viewport.
@ Disabled
Widget is disabled (greyed out) bit.
@ DropdownClosed
Dropdown menu of the dropdown widget has closed.
@ Lowered
Widget is lowered (pressed down) bit.
@ DropdownActive
Dropdown menu of the button dropdown widget is active.
@ ScrollbarUp
Up-button is lowered bit.
uint ComputeMaxSize(uint base, uint max_space, uint step)
Return the biggest possible size of a nested widget.
bool IsContainerWidgetType(WidgetType tp)
Test if WidgetType is a container widget.
Definition widget.cpp:3358
StackedZeroSizePlanes
Display planes with zero size for NWidgetStacked.
@ SZSP_HORIZONTAL
Display plane with zero size vertically, and filling and resizing horizontally.
@ SZSP_BEGIN
First zero-size plane.
@ SZSP_VERTICAL
Display plane with zero size horizontally, and filling and resizing vertically.
@ SZSP_NONE
Display plane with zero size in both directions (none filling and resizing).
NWidContainerFlag
Nested widget container flags,.
@ EqualSize
Containers should keep all their (resizing) children equally large.
@ BigFirst
Allocate space to biggest resize first.
std::unique_ptr< NWidgetBase >() NWidgetFunctionType
Pointer to function returning a nested widget.
std::unique_ptr< NWidgetBase > MakeCompanyButtonRows(WidgetID widget_first, WidgetID widget_last, Colours button_colour, int max_length, StringID button_tooltip, bool resizable=true)
Make a number of rows with button-like graphics, for enabling/disabling each company.
Definition widget.cpp:3476
void SetupWidgetDimensions()
Set up pre-scaled versions of Widget Dimensions.
Definition widget.cpp:98
SizingType
Different forms of sizing nested widgets, using NWidgetBase::AssignSizePosition().
@ Resize
Resize the nested widget tree.
@ Smallest
Initialize nested widget tree to smallest size. Also updates current_x and current_y.
ArrowWidgetType
Values for an arrow widget.
Definition widget_type.h:19
@ Right
Force the arrow to the right.
Definition widget_type.h:23
@ Left
Force the arrow to the left.
Definition widget_type.h:22
@ Decrease
Arrow to the left or in case of RTL to the right.
Definition widget_type.h:20
@ Increase
Arrow to the right or in case of RTL to the left.
Definition widget_type.h:21
std::map< WidgetID, class NWidgetBase * > WidgetLookup
Lookup between widget IDs and NWidget objects.
ResizeWidgetType
WidgetData values for a resize box widget.
Definition widget_type.h:27
@ HideBevel
Bevel of resize box is hidden.
Definition widget_type.h:29
@ ShowBevel
Bevel of resize box is shown.
Definition widget_type.h:28
AspectFlag
Flags to control how a widgeet is resized to reach its aspect ratio.
@ ResizeY
Resize vertically to reach desired aspect ratio.
@ ResizeX
Resize horizontally to reach desired aspect ratio.
Types related to windows.
int WidgetID
Widget ID.
Definition window_type.h:20
EventState
State of handling an event.
static constexpr WidgetID INVALID_WIDGET
An invalid widget index.
Definition window_type.h:23
ZoomLevel
All zoom levels we know.
Definition zoom_type.h:20