From b18e78e21d0c67258162b1c202800913c38f925e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Guilloux?= Date: Mon, 15 Jan 2024 21:41:44 +0100 Subject: [PATCH] Change: Redesign script debug window (#11782) --- src/script/script_gui.cpp | 18 ++++++++++-------- src/widget.cpp | 7 ++++--- src/widget_type.h | 2 +- 3 files changed, 15 insertions(+), 12 deletions(-) diff --git a/src/script/script_gui.cpp b/src/script/script_gui.cpp index 429298de1da60..1674327d77f9f 100644 --- a/src/script/script_gui.cpp +++ b/src/script/script_gui.cpp @@ -1233,7 +1233,7 @@ struct ScriptDebugWindow : public Window { /** Make a number of rows with buttons for each company for the Script debug window. */ std::unique_ptr MakeCompanyButtonRowsScriptDebug() { - return MakeCompanyButtonRows(WID_SCRD_COMPANY_BUTTON_START, WID_SCRD_COMPANY_BUTTON_END, COLOUR_GREY, 8, STR_AI_DEBUG_SELECT_AI_TOOLTIP); + return MakeCompanyButtonRows(WID_SCRD_COMPANY_BUTTON_START, WID_SCRD_COMPANY_BUTTON_END, COLOUR_GREY, 5, STR_AI_DEBUG_SELECT_AI_TOOLTIP, false); } /** Widgets for the Script debug window. */ @@ -1245,14 +1245,16 @@ static const NWidgetPart _nested_script_debug_widgets[] = { NWidget(WWT_DEFSIZEBOX, COLOUR_GREY), NWidget(WWT_STICKYBOX, COLOUR_GREY), EndContainer(), - NWidget(WWT_PANEL, COLOUR_GREY, WID_SCRD_VIEW), - NWidgetFunction(MakeCompanyButtonRowsScriptDebug), SetPadding(0, 2, 1, 2), - EndContainer(), NWidget(NWID_HORIZONTAL), - NWidget(WWT_TEXTBTN, COLOUR_GREY, WID_SCRD_SCRIPT_GAME), SetMinimalSize(100, 20), SetResize(1, 0), SetDataTip(STR_AI_GAME_SCRIPT, STR_AI_GAME_SCRIPT_TOOLTIP), - NWidget(WWT_TEXTBTN, COLOUR_GREY, WID_SCRD_NAME_TEXT), SetFill(1, 0), SetResize(1, 0), SetDataTip(STR_JUST_STRING2, STR_AI_DEBUG_NAME_TOOLTIP), - NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SCRD_SETTINGS), SetMinimalSize(100, 20), SetDataTip(STR_AI_DEBUG_SETTINGS, STR_AI_DEBUG_SETTINGS_TOOLTIP), - NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SCRD_RELOAD_TOGGLE), SetMinimalSize(100, 20), SetDataTip(STR_AI_DEBUG_RELOAD, STR_AI_DEBUG_RELOAD_TOOLTIP), + NWidget(WWT_PANEL, COLOUR_GREY, WID_SCRD_VIEW), + NWidgetFunction(MakeCompanyButtonRowsScriptDebug), SetPadding(0, 2, 1, 2), + EndContainer(), + NWidget(WWT_TEXTBTN, COLOUR_GREY, WID_SCRD_SCRIPT_GAME), SetMinimalSize(100, 20), SetDataTip(STR_AI_GAME_SCRIPT, STR_AI_GAME_SCRIPT_TOOLTIP), + NWidget(WWT_TEXTBTN, COLOUR_GREY, WID_SCRD_NAME_TEXT), SetResize(1, 0), SetDataTip(STR_JUST_STRING2, STR_AI_DEBUG_NAME_TOOLTIP), + NWidget(NWID_VERTICAL), + NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SCRD_SETTINGS), SetMinimalSize(100, 20), SetFill(0, 1), SetDataTip(STR_AI_DEBUG_SETTINGS, STR_AI_DEBUG_SETTINGS_TOOLTIP), + NWidget(WWT_PUSHTXTBTN, COLOUR_GREY, WID_SCRD_RELOAD_TOGGLE), SetMinimalSize(100, 20), SetFill(0, 1), SetDataTip(STR_AI_DEBUG_RELOAD, STR_AI_DEBUG_RELOAD_TOOLTIP), + EndContainer(), EndContainer(), NWidget(NWID_HORIZONTAL), NWidget(NWID_VERTICAL), diff --git a/src/widget.cpp b/src/widget.cpp index 18a04092bf5e1..d463bebc8ea1a 100644 --- a/src/widget.cpp +++ b/src/widget.cpp @@ -3329,9 +3329,10 @@ std::unique_ptr MakeWindowNWidgetTree(const NWidgetPart *nwid_begin * @param colour The colour in which to draw the button. * @param max_length Maximal number of company buttons in one row. * @param button_tooltip The tooltip-string of every button. + * @param resizable Whether the rows are resizable. * @return Panel with rows of company buttons. */ -std::unique_ptr MakeCompanyButtonRows(WidgetID widget_first, WidgetID widget_last, Colours button_colour, int max_length, StringID button_tooltip) +std::unique_ptr MakeCompanyButtonRows(WidgetID widget_first, WidgetID widget_last, Colours button_colour, int max_length, StringID button_tooltip, bool resizable) { assert(max_length >= 1); std::unique_ptr vert = nullptr; // Storage for all rows. @@ -3358,7 +3359,7 @@ std::unique_ptr MakeCompanyButtonRows(WidgetID widget_first, Widget auto panel = std::make_unique(WWT_PANEL, button_colour, widnum); panel->SetMinimalSize(sprite_size.width, sprite_size.height); panel->SetFill(1, 1); - panel->SetResize(1, 0); + if (resizable) panel->SetResize(1, 0); panel->SetDataTip(0x0, button_tooltip); hor->Add(std::move(panel)); hor_length++; @@ -3369,7 +3370,7 @@ std::unique_ptr MakeCompanyButtonRows(WidgetID widget_first, Widget /* Last row is partial, add a spacer at the end to force all buttons to the left. */ auto spc = std::make_unique(sprite_size.width, sprite_size.height); spc->SetFill(1, 1); - spc->SetResize(1, 0); + if (resizable) spc->SetResize(1, 0); hor->Add(std::move(spc)); } if (hor != nullptr) vert->Add(std::move(hor)); diff --git a/src/widget_type.h b/src/widget_type.h index ef7b38c65a3d8..0e058d33a0ffd 100644 --- a/src/widget_type.h +++ b/src/widget_type.h @@ -1356,7 +1356,7 @@ bool IsContainerWidgetType(WidgetType tp); std::unique_ptr MakeNWidgets(const NWidgetPart *nwid_begin, const NWidgetPart *nwid_end, std::unique_ptr &&container); std::unique_ptr MakeWindowNWidgetTree(const NWidgetPart *nwid_begin, const NWidgetPart *nwid_end, NWidgetStacked **shade_select); -std::unique_ptr MakeCompanyButtonRows(WidgetID widget_first, WidgetID widget_last, Colours button_colour, int max_length, StringID button_tooltip); +std::unique_ptr MakeCompanyButtonRows(WidgetID widget_first, WidgetID widget_last, Colours button_colour, int max_length, StringID button_tooltip, bool resizable = true); void SetupWidgetDimensions();