OpenTTD Source 20251116-master-g21329071df
terraform_gui.cpp
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 <http://www.gnu.org/licenses/>.
6 */
7
10#include "stdafx.h"
11#include "core/backup_type.hpp"
12#include "clear_map.h"
13#include "company_func.h"
14#include "company_base.h"
15#include "house.h"
16#include "gui.h"
17#include "window_gui.h"
18#include "window_func.h"
19#include "viewport_func.h"
20#include "command_func.h"
21#include "signs_func.h"
22#include "sound_func.h"
23#include "base_station_base.h"
24#include "textbuf_gui.h"
25#include "genworld.h"
26#include "tree_map.h"
27#include "landscape_type.h"
28#include "tilehighlight_func.h"
29#include "strings_func.h"
30#include "newgrf_object.h"
31#include "object.h"
32#include "hotkeys.h"
33#include "engine_base.h"
34#include "terraform_gui.h"
35#include "terraform_cmd.h"
36#include "zoom_func.h"
37#include "rail_cmd.h"
38#include "landscape_cmd.h"
39#include "terraform_cmd.h"
40#include "object_cmd.h"
41
43
44#include "table/strings.h"
45
46#include "safeguards.h"
47
48void CcTerraform(Commands, const CommandCost &result, Money, TileIndex tile)
49{
50 if (result.Succeeded()) {
52 } else {
54 }
55}
56
57
59static void GenerateDesertArea(TileIndex end, TileIndex start)
60{
61 if (_game_mode != GM_EDITOR) return;
62
63 Backup<bool> old_generating_world(_generating_world, true);
64
65 TileArea ta(start, end);
66 for (TileIndex tile : ta) {
70 }
71 old_generating_world.Restore();
73}
74
76static void GenerateRockyArea(TileIndex end, TileIndex start)
77{
78 if (_game_mode != GM_EDITOR) return;
79
80 bool success = false;
81 TileArea ta(start, end);
82
83 for (TileIndex tile : ta) {
84 switch (GetTileType(tile)) {
85 case MP_TREES:
86 if (GetTreeGround(tile) == TREE_GROUND_SHORE) continue;
87 [[fallthrough]];
88
89 case MP_CLEAR:
90 MakeClear(tile, CLEAR_ROCKS, 3);
91 break;
92
93 default:
94 continue;
95 }
97 success = true;
98 }
99
100 if (success && _settings_client.sound.confirm) SndPlayTileFx(SND_1F_CONSTRUCTION_OTHER, end);
101}
102
113{
115 /* When end_tile is MP_VOID, the error tile will not be visible to the
116 * user. This happens when terraforming at the southern border. */
117 if (TileX(end_tile) == Map::MaxX()) end_tile += TileDiffXY(-1, 0);
118 if (TileY(end_tile) == Map::MaxY()) end_tile += TileDiffXY(0, -1);
119 }
120
121 switch (proc) {
123 Command<CMD_CLEAR_AREA>::Post(STR_ERROR_CAN_T_CLEAR_THIS_AREA, CcPlaySound_EXPLOSION, end_tile, start_tile, _ctrl_pressed);
124 break;
126 Command<CMD_LEVEL_LAND>::Post(STR_ERROR_CAN_T_RAISE_LAND_HERE, CcTerraform, end_tile, start_tile, _ctrl_pressed, LM_RAISE);
127 break;
129 Command<CMD_LEVEL_LAND>::Post(STR_ERROR_CAN_T_LOWER_LAND_HERE, CcTerraform, end_tile, start_tile, _ctrl_pressed, LM_LOWER);
130 break;
131 case DDSP_LEVEL_AREA:
132 Command<CMD_LEVEL_LAND>::Post(STR_ERROR_CAN_T_LEVEL_LAND_HERE, CcTerraform, end_tile, start_tile, _ctrl_pressed, LM_LEVEL);
133 break;
135 GenerateRockyArea(end_tile, start_tile);
136 break;
138 GenerateDesertArea(end_tile, start_tile);
139 break;
140 default:
141 return false;
142 }
143
144 return true;
145}
146
155
159
161 {
162 /* This is needed as we like to have the tree available on OnInit. */
163 this->CreateNestedTree();
164 this->FinishInitNested(window_number);
165 }
166
167 void OnInit() override
168 {
169 /* Don't show the place object button when there are no objects to place. */
170 NWidgetStacked *show_object = this->GetWidget<NWidgetStacked>(WID_TT_SHOW_PLACE_OBJECT);
172 }
173
174 void OnClick([[maybe_unused]] Point pt, WidgetID widget, [[maybe_unused]] int click_count) override
175 {
176 if (widget < WID_TT_BUTTONS_START) return;
177
178 switch (widget) {
179 case WID_TT_LOWER_LAND: // Lower land button
181 this->last_user_action = widget;
182 break;
183
184 case WID_TT_RAISE_LAND: // Raise land button
186 this->last_user_action = widget;
187 break;
188
189 case WID_TT_LEVEL_LAND: // Level land button
190 HandlePlacePushButton(this, WID_TT_LEVEL_LAND, SPR_CURSOR_LEVEL_LAND, HT_POINT | HT_DIAGONAL);
191 this->last_user_action = widget;
192 break;
193
194 case WID_TT_DEMOLISH: // Demolish aka dynamite button
196 this->last_user_action = widget;
197 break;
198
199 case WID_TT_BUY_LAND: // Buy land button
200 HandlePlacePushButton(this, WID_TT_BUY_LAND, SPR_CURSOR_BUY_LAND, HT_RECT | HT_DIAGONAL);
201 this->last_user_action = widget;
202 break;
203
204 case WID_TT_PLANT_TREES: // Plant trees button
205 ShowBuildTreesToolbar();
206 break;
207
208 case WID_TT_PLACE_SIGN: // Place sign button
209 HandlePlacePushButton(this, WID_TT_PLACE_SIGN, SPR_CURSOR_SIGN, HT_RECT);
210 this->last_user_action = widget;
211 break;
212
213 case WID_TT_PLACE_OBJECT: // Place object button
215 break;
216
217 default: NOT_REACHED();
218 }
219 }
220
221 void OnPlaceObject([[maybe_unused]] Point pt, TileIndex tile) override
222 {
223 switch (this->last_user_action) {
224 case WID_TT_LOWER_LAND: // Lower land button
226 break;
227
228 case WID_TT_RAISE_LAND: // Raise land button
230 break;
231
232 case WID_TT_LEVEL_LAND: // Level land button
234 break;
235
236 case WID_TT_DEMOLISH: // Demolish aka dynamite button
238 break;
239
240 case WID_TT_BUY_LAND: // Buy land button
242 break;
243
244 case WID_TT_PLACE_SIGN: // Place sign button
245 PlaceProc_Sign(tile);
246 break;
247
248 default: NOT_REACHED();
249 }
250 }
251
252 void OnPlaceDrag(ViewportPlaceMethod select_method, [[maybe_unused]] ViewportDragDropSelectionProcess select_proc, [[maybe_unused]] Point pt) override
253 {
254 VpSelectTilesWithMethod(pt.x, pt.y, select_method);
255 }
256
257 Point OnInitialPosition([[maybe_unused]] int16_t sm_width, [[maybe_unused]] int16_t sm_height, [[maybe_unused]] int window_number) override
258 {
261
262 return pt;
263 }
264
265 void OnPlaceMouseUp([[maybe_unused]] ViewportPlaceMethod select_method, ViewportDragDropSelectionProcess select_proc, [[maybe_unused]] Point pt, TileIndex start_tile, TileIndex end_tile) override
266 {
267 if (pt.x != -1) {
268 switch (select_proc) {
269 default: NOT_REACHED();
273 case DDSP_LEVEL_AREA:
274 GUIPlaceProcDragXY(select_proc, start_tile, end_tile);
275 break;
278 /* When end_tile is MP_VOID, the error tile will not be visible to the
279 * user. This happens when terraforming at the southern border. */
280 if (TileX(end_tile) == Map::MaxX()) end_tile += TileDiffXY(-1, 0);
281 if (TileY(end_tile) == Map::MaxY()) end_tile += TileDiffXY(0, -1);
282 }
283 Command<CMD_BUILD_OBJECT_AREA>::Post(STR_ERROR_CAN_T_PURCHASE_THIS_LAND, CcPlaySound_CONSTRUCTION_RAIL,
284 end_tile, start_tile, OBJECT_OWNED_LAND, 0, (_ctrl_pressed ? true : false));
285 break;
286 }
287 }
288 }
289
290 void OnPlaceObjectAbort() override
291 {
292 this->RaiseButtons();
293 }
294
301 {
302 if (_game_mode != GM_NORMAL) return ES_NOT_HANDLED;
303 Window *w = ShowTerraformToolbar(nullptr);
304 if (w == nullptr) return ES_NOT_HANDLED;
305 return w->OnHotkey(hotkey);
306 }
307
308 static inline HotkeyList hotkeys{"terraform", {
312 Hotkey('D' | WKC_GLOBAL_HOTKEY, "dynamite", WID_TT_DEMOLISH),
313 Hotkey('U', "buyland", WID_TT_BUY_LAND),
314 Hotkey('I', "trees", WID_TT_PLANT_TREES),
315 Hotkey('O', "placesign", WID_TT_PLACE_SIGN),
316 Hotkey('P', "placeobject", WID_TT_PLACE_OBJECT),
318};
319
320static constexpr std::initializer_list<NWidgetPart> _nested_terraform_widgets = {
322 NWidget(WWT_CLOSEBOX, COLOUR_DARK_GREEN),
323 NWidget(WWT_CAPTION, COLOUR_DARK_GREEN), SetStringTip(STR_LANDSCAPING_TOOLBAR, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS),
324 NWidget(WWT_STICKYBOX, COLOUR_DARK_GREEN),
325 EndContainer(),
328 SetFill(0, 1), SetSpriteTip(SPR_IMG_TERRAFORM_DOWN, STR_LANDSCAPING_TOOLTIP_LOWER_A_CORNER_OF_LAND),
330 SetFill(0, 1), SetSpriteTip(SPR_IMG_TERRAFORM_UP, STR_LANDSCAPING_TOOLTIP_RAISE_A_CORNER_OF_LAND),
332 SetFill(0, 1), SetSpriteTip(SPR_IMG_LEVEL_LAND, STR_LANDSCAPING_LEVEL_LAND_TOOLTIP),
333
335
337 SetFill(0, 1), SetSpriteTip(SPR_IMG_DYNAMITE, STR_TOOLTIP_DEMOLISH_BUILDINGS_ETC),
339 SetFill(0, 1), SetSpriteTip(SPR_IMG_BUY_LAND, STR_LANDSCAPING_TOOLTIP_PURCHASE_LAND),
341 SetFill(0, 1), SetSpriteTip(SPR_IMG_PLANTTREES, STR_SCENEDIT_TOOLBAR_PLANT_TREES_TOOLTIP),
343 SetFill(0, 1), SetSpriteTip(SPR_IMG_SIGN, STR_SCENEDIT_TOOLBAR_PLACE_SIGN_TOOLTIP),
346 SetFill(0, 1), SetSpriteTip(SPR_IMG_TRANSMITTER, STR_SCENEDIT_TOOLBAR_PLACE_OBJECT_TOOLTIP),
347 EndContainer(),
348 EndContainer(),
349};
350
351static WindowDesc _terraform_desc(
352 WDP_MANUAL, "toolbar_landscape", 0, 0,
355 _nested_terraform_widgets,
356 &TerraformToolbarWindow::hotkeys
357);
358
365{
366 if (!Company::IsValidID(_local_company)) return nullptr;
367
368 /* Delete the terraform toolbar to place it again. */
370
371 if (link == nullptr) return AllocateWindowDescFront<TerraformToolbarWindow>(_terraform_desc, 0);
372
373 Window *w = AllocateWindowDescFront<TerraformToolbarWindow>(_terraform_desc, 0);
374 /* Put the linked toolbar to the left / right of the main toolbar. */
375 link->left = w->left + (_current_text_dir == TD_RTL ? w->width : -link->width);
376 link->top = w->top;
377 link->SetDirty();
378
379 return w;
380}
381
382static uint8_t _terraform_size = 1;
383
393static void CommonRaiseLowerBigLand(TileIndex tile, bool mode)
394{
395 if (_terraform_size == 1) {
396 StringID msg =
397 mode ? STR_ERROR_CAN_T_RAISE_LAND_HERE : STR_ERROR_CAN_T_LOWER_LAND_HERE;
398
399 Command<CMD_TERRAFORM_LAND>::Post(msg, CcTerraform, tile, SLOPE_N, mode);
400 } else {
401 assert(_terraform_size != 0);
402 TileArea ta(tile, _terraform_size, _terraform_size);
403 ta.ClampToMap();
404
405 if (ta.w == 0 || ta.h == 0) return;
406
408
409 uint h;
410 if (mode != 0) {
411 /* Raise land */
412 h = MAX_TILE_HEIGHT;
413 for (TileIndex tile2 : ta) {
414 h = std::min(h, TileHeight(tile2));
415 }
416 } else {
417 /* Lower land */
418 h = 0;
419 for (TileIndex tile2 : ta) {
420 h = std::max(h, TileHeight(tile2));
421 }
422 }
423
424 for (TileIndex tile2 : ta) {
425 if (TileHeight(tile2) == h) {
427 }
428 }
429 }
430}
431
432static const int8_t _multi_terraform_coords[][2] = {
433 { 0, -2},
434 { 4, 0}, { -4, 0}, { 0, 2},
435 { -8, 2}, { -4, 4}, { 0, 6}, { 4, 4}, { 8, 2},
436 {-12, 0}, { -8, -2}, { -4, -4}, { 0, -6}, { 4, -4}, { 8, -2}, { 12, 0},
437 {-16, 2}, {-12, 4}, { -8, 6}, { -4, 8}, { 0, 10}, { 4, 8}, { 8, 6}, { 12, 4}, { 16, 2},
438 {-20, 0}, {-16, -2}, {-12, -4}, { -8, -6}, { -4, -8}, { 0,-10}, { 4, -8}, { 8, -6}, { 12, -4}, { 16, -2}, { 20, 0},
439 {-24, 2}, {-20, 4}, {-16, 6}, {-12, 8}, { -8, 10}, { -4, 12}, { 0, 14}, { 4, 12}, { 8, 10}, { 12, 8}, { 16, 6}, { 20, 4}, { 24, 2},
440 {-28, 0}, {-24, -2}, {-20, -4}, {-16, -6}, {-12, -8}, { -8,-10}, { -4,-12}, { 0,-14}, { 4,-12}, { 8,-10}, { 12, -8}, { 16, -6}, { 20, -4}, { 24, -2}, { 28, 0},
441};
442
443static constexpr std::initializer_list<NWidgetPart> _nested_scen_edit_land_gen_widgets = {
445 NWidget(WWT_CLOSEBOX, COLOUR_DARK_GREEN),
446 NWidget(WWT_CAPTION, COLOUR_DARK_GREEN), SetStringTip(STR_TERRAFORM_TOOLBAR_LAND_GENERATION_CAPTION, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS),
447 NWidget(WWT_SHADEBOX, COLOUR_DARK_GREEN),
448 NWidget(WWT_STICKYBOX, COLOUR_DARK_GREEN),
449 EndContainer(),
450 NWidget(WWT_PANEL, COLOUR_DARK_GREEN),
451 NWidget(NWID_HORIZONTAL), SetPadding(2, 2, 7, 2),
454 SetFill(0, 1), SetSpriteTip(SPR_IMG_DYNAMITE, STR_TOOLTIP_DEMOLISH_BUILDINGS_ETC),
456 SetFill(0, 1), SetSpriteTip(SPR_IMG_TERRAFORM_DOWN, STR_LANDSCAPING_TOOLTIP_LOWER_A_CORNER_OF_LAND),
458 SetFill(0, 1), SetSpriteTip(SPR_IMG_TERRAFORM_UP, STR_LANDSCAPING_TOOLTIP_RAISE_A_CORNER_OF_LAND),
460 SetFill(0, 1), SetSpriteTip(SPR_IMG_LEVEL_LAND, STR_LANDSCAPING_LEVEL_LAND_TOOLTIP),
462 SetFill(0, 1), SetSpriteTip(SPR_IMG_ROCKS, STR_TERRAFORM_TOOLTIP_PLACE_ROCKY_AREAS_ON_LANDSCAPE),
465 SetFill(0, 1), SetSpriteTip(SPR_IMG_DESERT, STR_TERRAFORM_TOOLTIP_DEFINE_DESERT_AREA),
466 EndContainer(),
468 SetFill(0, 1), SetSpriteTip(SPR_IMG_TRANSMITTER, STR_SCENEDIT_TOOLBAR_PLACE_OBJECT_TOOLTIP),
470 EndContainer(),
473 NWidget(WWT_EMPTY, INVALID_COLOUR, WID_ETT_DOTS), SetMinimalSize(59, 31), SetStringTip(STR_EMPTY),
477 NWidget(WWT_IMGBTN, COLOUR_GREY, WID_ETT_INCREASE_SIZE), SetMinimalSize(12, 12), SetSpriteTip(SPR_ARROW_UP, STR_TERRAFORM_TOOLTIP_INCREASE_SIZE_OF_LAND_AREA),
479 NWidget(WWT_IMGBTN, COLOUR_GREY, WID_ETT_DECREASE_SIZE), SetMinimalSize(12, 12), SetSpriteTip(SPR_ARROW_DOWN, STR_TERRAFORM_TOOLTIP_DECREASE_SIZE_OF_LAND_AREA),
481 EndContainer(),
483 EndContainer(),
486 SetFill(1, 0), SetStringTip(STR_TERRAFORM_SE_NEW_WORLD, STR_TERRAFORM_TOOLTIP_GENERATE_RANDOM_LAND), SetPadding(0, 2, 0, 2),
488 SetFill(1, 0), SetStringTip(STR_TERRAFORM_RESET_LANDSCAPE, STR_TERRAFORM_RESET_LANDSCAPE_TOOLTIP), SetPadding(1, 2, 2, 2),
489 EndContainer(),
490};
491
496static void ResetLandscapeConfirmationCallback(Window *, bool confirmed)
497{
498 if (confirmed) {
499 /* Set generating_world to true to get instant-green grass after removing
500 * company property. */
501 Backup<bool> old_generating_world(_generating_world, true);
502
503 /* Delete all companies */
504 for (Company *c : Company::Iterate()) {
506 delete c;
507 }
508
509 old_generating_world.Restore();
510
511 /* Delete all station signs */
512 for (BaseStation *st : BaseStation::Iterate()) {
513 /* There can be buoys, remove them */
515 if (!st->IsInUse()) delete st;
516 }
517
518 /* Now that all vehicles are gone, we can reset the engine pool. Maybe it reduces some NewGRF changing-mess */
520
522 }
523}
524
528
530 {
531 this->CreateNestedTree();
532 NWidgetStacked *show_desert = this->GetWidget<NWidgetStacked>(WID_ETT_SHOW_PLACE_DESERT);
533 show_desert->SetDisplayedPlane(_settings_game.game_creation.landscape == LandscapeType::Tropic ? 0 : SZSP_NONE);
534 this->FinishInitNested(window_number);
535 }
536
537 void OnPaint() override
538 {
539 this->DrawWidgets();
540
541 if (this->IsWidgetLowered(WID_ETT_LOWER_LAND) || this->IsWidgetLowered(WID_ETT_RAISE_LAND)) { // change area-size if raise/lower corner is selected
542 SetTileSelectSize(_terraform_size, _terraform_size);
543 }
544 }
545
546 void UpdateWidgetSize(WidgetID widget, Dimension &size, [[maybe_unused]] const Dimension &padding, [[maybe_unused]] Dimension &fill, [[maybe_unused]] Dimension &resize) override
547 {
548 if (widget != WID_ETT_DOTS) return;
549
550 size.width = std::max<uint>(size.width, ScaleGUITrad(59));
551 size.height = std::max<uint>(size.height, ScaleGUITrad(31));
552 }
553
554 void DrawWidget(const Rect &r, WidgetID widget) const override
555 {
556 if (widget != WID_ETT_DOTS) return;
557
558 int center_x = RoundDivSU(r.left + r.right, 2);
559 int center_y = RoundDivSU(r.top + r.bottom, 2);
560
561 int n = _terraform_size * _terraform_size;
562 const int8_t *coords = &_multi_terraform_coords[0][0];
563
564 assert(n != 0);
565 do {
566 DrawSprite(SPR_WHITE_POINT, PAL_NONE, center_x + ScaleGUITrad(coords[0]), center_y + ScaleGUITrad(coords[1]));
567 coords += 2;
568 } while (--n);
569 }
570
571 void OnClick([[maybe_unused]] Point pt, WidgetID widget, [[maybe_unused]] int click_count) override
572 {
573 if (widget < WID_ETT_BUTTONS_START) return;
574
575 switch (widget) {
576 case WID_ETT_DEMOLISH: // Demolish aka dynamite button
578 this->last_user_action = widget;
579 break;
580
581 case WID_ETT_LOWER_LAND: // Lower land button
583 this->last_user_action = widget;
584 break;
585
586 case WID_ETT_RAISE_LAND: // Raise land button
588 this->last_user_action = widget;
589 break;
590
591 case WID_ETT_LEVEL_LAND: // Level land button
592 HandlePlacePushButton(this, WID_ETT_LEVEL_LAND, SPR_CURSOR_LEVEL_LAND, HT_POINT | HT_DIAGONAL);
593 this->last_user_action = widget;
594 break;
595
596 case WID_ETT_PLACE_ROCKS: // Place rocks button
597 HandlePlacePushButton(this, WID_ETT_PLACE_ROCKS, SPR_CURSOR_ROCKY_AREA, HT_RECT);
598 this->last_user_action = widget;
599 break;
600
601 case WID_ETT_PLACE_DESERT: // Place desert button (in tropical climate)
602 HandlePlacePushButton(this, WID_ETT_PLACE_DESERT, SPR_CURSOR_DESERT, HT_RECT);
603 this->last_user_action = widget;
604 break;
605
606 case WID_ETT_PLACE_OBJECT: // Place transmitter button
608 break;
609
611 case WID_ETT_DECREASE_SIZE: { // Increase/Decrease terraform size
612 int size = (widget == WID_ETT_INCREASE_SIZE) ? 1 : -1;
613 this->HandleButtonClick(widget);
614 size += _terraform_size;
615
616 if (!IsInsideMM(size, 1, 8 + 1)) return;
617 _terraform_size = size;
618
619 this->SetDirty();
620 break;
621 }
622
623 case WID_ETT_NEW_SCENARIO: // gen random land
624 this->HandleButtonClick(widget);
626 break;
627
628 case WID_ETT_RESET_LANDSCAPE: // Reset landscape
629 ShowQuery(
630 GetEncodedString(STR_QUERY_RESET_LANDSCAPE_CAPTION),
631 GetEncodedString(STR_RESET_LANDSCAPE_CONFIRMATION_TEXT),
633 break;
634
635 default: NOT_REACHED();
636 }
637 }
638
639 void OnTimeout() override
640 {
641 for (const auto &pair : this->widget_lookup) {
642 if (pair.first < WID_ETT_START || (pair.first >= WID_ETT_BUTTONS_START && pair.first < WID_ETT_BUTTONS_END)) continue; // skip the buttons
643 this->RaiseWidgetWhenLowered(pair.first);
644 }
645 }
646
647 void OnPlaceObject([[maybe_unused]] Point pt, TileIndex tile) override
648 {
649 switch (this->last_user_action) {
650 case WID_ETT_DEMOLISH: // Demolish aka dynamite button
652 break;
653
654 case WID_ETT_LOWER_LAND: // Lower land button
655 CommonRaiseLowerBigLand(tile, false);
656 break;
657
658 case WID_ETT_RAISE_LAND: // Raise land button
659 CommonRaiseLowerBigLand(tile, true);
660 break;
661
662 case WID_ETT_LEVEL_LAND: // Level land button
664 break;
665
666 case WID_ETT_PLACE_ROCKS: // Place rocks button
668 break;
669
670 case WID_ETT_PLACE_DESERT: // Place desert button (in tropical climate)
672 break;
673
674 default: NOT_REACHED();
675 }
676 }
677
678 void OnPlaceDrag(ViewportPlaceMethod select_method, [[maybe_unused]] ViewportDragDropSelectionProcess select_proc, [[maybe_unused]] Point pt) override
679 {
680 VpSelectTilesWithMethod(pt.x, pt.y, select_method);
681 }
682
683 void OnPlaceMouseUp([[maybe_unused]] ViewportPlaceMethod select_method, ViewportDragDropSelectionProcess select_proc, [[maybe_unused]] Point pt, TileIndex start_tile, TileIndex end_tile) override
684 {
685 if (pt.x != -1) {
686 switch (select_proc) {
687 default: NOT_REACHED();
692 case DDSP_LEVEL_AREA:
694 GUIPlaceProcDragXY(select_proc, start_tile, end_tile);
695 break;
696 }
697 }
698 }
699
700 void OnPlaceObjectAbort() override
701 {
702 this->RaiseButtons();
703 this->SetDirty();
704 }
705
712 {
713 if (_game_mode != GM_EDITOR) return ES_NOT_HANDLED;
715 if (w == nullptr) return ES_NOT_HANDLED;
716 return w->OnHotkey(hotkey);
717 }
718
719 static inline HotkeyList hotkeys{"terraform_editor", {
720 Hotkey('D' | WKC_GLOBAL_HOTKEY, "dynamite", WID_ETT_DEMOLISH),
724 Hotkey('R', "rocky", WID_ETT_PLACE_ROCKS),
725 Hotkey('T', "desert", WID_ETT_PLACE_DESERT),
726 Hotkey('O', "object", WID_ETT_PLACE_OBJECT),
728};
729
730static WindowDesc _scen_edit_land_gen_desc(
731 WDP_AUTO, "toolbar_landscape_scen", 0, 0,
734 _nested_scen_edit_land_gen_widgets,
735 &ScenarioEditorLandscapeGenerationWindow::hotkeys
736);
737
743{
744 return AllocateWindowDescFront<ScenarioEditorLandscapeGenerationWindow>(_scen_edit_land_gen_desc, 0);
745}
Class for backupping variables and making sure they are restored later.
Base classes/functions for base stations.
Common return value for all commands.
bool Succeeded() const
Did this command succeed?
Stacked widgets, widgets all occupying the same space in the window.
bool SetDisplayedPlane(int plane)
Select which plane to show (for NWID_SELECTION only).
Definition widget.cpp:1422
static uint GetUIClassCount()
Get the number of classes available to the user.
Map accessors for 'clear' tiles.
@ CLEAR_ROCKS
3
Definition clear_map.h:22
void MakeClear(Tile t, ClearGround g, uint density)
Make a clear tile.
Definition clear_map.h:247
Functions related to commands.
@ Execute
execute the given command
@ Bankrupt
company bankrupts, skip money check, skip vehicle on tile check in some cases
Commands
List of commands.
Definition of stuff that is very close to a company, like the company struct itself.
CompanyID _local_company
Company controlled by the human player at this client. Can also be COMPANY_SPECTATOR.
Functions related to companies.
void ChangeOwnershipOfCompanyItems(Owner old_owner, Owner new_owner)
Change the ownership of all the items of a company.
Definition economy.cpp:322
static constexpr Owner INVALID_OWNER
An invalid owner.
Base class for engines.
bool _generating_world
Whether we are generating the map or not.
Definition genworld.cpp:74
Functions related to world/map generation.
void ShowCreateScenario()
Show the window to create a scenario.
bool _ctrl_pressed
Is Ctrl pressed?
Definition gfx.cpp:39
void DrawSprite(SpriteID img, PaletteID pal, int x, int y, const SubSprite *sub, ZoomLevel zoom)
Draw a sprite, not in a viewport.
Definition gfx.cpp:1032
@ WKC_GLOBAL_HOTKEY
Fake keycode bit to indicate global hotkeys.
Definition gfx_type.h:35
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 SetToolbarMinimalSize(int width)
Widget part function to setting the minimal size for a toolbar button.
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 SetStringTip(StringID string, StringID tip={})
Widget part function for setting the string and tooltip.
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.
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.
void SetDirty() const
Mark entire window as dirty (in need of re-paint)
Definition window.cpp:966
void MarkWholeScreenDirty()
This function mark the whole screen as dirty.
Definition gfx.cpp:1547
void MarkTileDirtyByTile(TileIndex tile, int bridge_level_offset, int tile_height_override)
Mark a tile given by its index dirty for repaint.
GUI functions that shouldn't be here.
Hotkey related functions.
definition of HouseSpec and accessors
Command definitions related to landscape (slopes etc.).
Types related to the landscape.
bool HandlePlacePushButton(Window *w, WidgetID widget, CursorID cursor, HighLightStyle mode)
This code is shared for the majority of the pushbuttons.
Definition main_gui.cpp:63
TileIndexDiff TileDiffXY(int x, int y)
Calculates an offset for the given coordinate(-offset).
Definition map_func.h:401
static debug_inline uint TileY(TileIndex tile)
Get the Y component of a tile.
Definition map_func.h:437
static debug_inline uint TileX(TileIndex tile)
Get the X component of a tile.
Definition map_func.h:427
@ LM_LEVEL
Level the land.
Definition map_type.h:44
@ LM_LOWER
Lower the land.
Definition map_type.h:45
@ LM_RAISE
Raise the land.
Definition map_type.h:46
constexpr bool IsInsideMM(const size_t x, const size_t min, const size_t max) noexcept
Checks if a value is in an interval.
constexpr int RoundDivSU(int a, uint b)
Computes round(a / b) for signed a and unsigned b.
void ShowQuery(EncodedString &&caption, EncodedString &&message, Window *parent, QueryCallbackProc *callback, bool focus)
Show a confirmation window with standard 'yes' and 'no' buttons The window is aligned to the centre o...
Functions related to NewGRF objects.
Functions related to objects.
Window * ShowBuildObjectPicker()
Show our object picker.
Command definitions related to objects.
static const ObjectType OBJECT_OWNED_LAND
Owned land 'flag'.
Definition object_type.h:21
Command definitions for rail.
A number of safeguards to prevent using unsafe methods.
GameSettings _settings_game
Game settings of a running game or the scenario editor.
Definition settings.cpp:61
ClientSettings _settings_client
The current settings for this game.
Definition settings.cpp:60
void PlaceProc_Sign(TileIndex tile)
PlaceProc function, called when someone pressed the button if the sign-tool is selected.
Functions related to signs.
@ SLOPE_N
the north corner of the tile is raised
Definition slope_type.h:53
Functions related to sound.
@ SND_1F_CONSTRUCTION_OTHER
29 == 0x1D Construction: other (non-water, non-rail, non-bridge)
Definition sound_type.h:76
static const CursorID ANIMCURSOR_DEMOLISH
704 - 707 - demolish dynamite
Definition sprites.h:1522
static const CursorID ANIMCURSOR_LOWERLAND
699 - 701 - lower land tool
Definition sprites.h:1523
static const CursorID ANIMCURSOR_RAISELAND
696 - 698 - raise land tool
Definition sprites.h:1524
bool IsBuoyTile(Tile t)
Is tile t a buoy tile?
Definition of base types and functions in a cross-platform compatible way.
EncodedString GetEncodedString(StringID str)
Encode a string with no parameters into an encoded string.
Definition strings.cpp:90
TextDirection _current_text_dir
Text direction of the currently selected language.
Definition strings.cpp:56
Functions related to OTTD's strings.
uint32_t StringID
Numeric value that represents a string, independent of the selected language.
@ TD_RTL
Text is written right-to-left by default.
Class to backup a specific variable and restore it later.
void Restore()
Restore the variable.
Base class for all station-ish types.
SoundSettings sound
sound effect settings
GUISettings gui
settings related to the GUI
bool freeform_edges
allow terraforming the tiles at the map edges
T y
Y coordinate.
Dimensions (a width and height) of a rectangle in 2D.
static bool ResetToCurrentNewGRFConfig()
Tries to reset the engine mapping to match the current NewGRF configuration.
Definition engine.cpp:584
bool link_terraform_toolbar
display terraform toolbar when displaying rail, road, water and airport toolbars
LandscapeType landscape
the landscape we're currently in
ConstructionSettings construction
construction of things in-game
GameCreationSettings game_creation
settings used during the creation of a game (map)
List of hotkeys for a window.
Definition hotkeys.h:37
All data for a single hotkey.
Definition hotkeys.h:21
static uint MaxY()
Gets the maximum Y coordinate within the map, including MP_VOID.
Definition map_func.h:308
static debug_inline uint MaxX()
Gets the maximum X coordinate within the map, including MP_VOID.
Definition map_func.h:299
Represents the covered area of e.g.
void ClampToMap()
Clamp the tile area to map borders.
Definition tilearea.cpp:142
uint16_t w
The width of the area.
uint16_t h
The height of the area.
static Pool::IterateWrapper< Titem > Iterate(size_t from=0)
Returns an iterable ensemble of all valid Titem.
static bool IsValidID(auto index)
Tests whether given index can be used to get valid (non-nullptr) Titem.
Specification of a rectangle with absolute coordinates of all edges.
Landscape generation window handler in the scenario editor.
void OnClick(Point pt, WidgetID widget, int click_count) override
A click with the left mouse button has been made on the window.
void OnPlaceObject(Point pt, TileIndex tile) override
The user clicked some place on the map when a tile highlight mode has been set.
void OnPlaceObjectAbort() override
The user cancelled a tile highlight mode that has been set.
void OnPaint() override
The window must be repainted.
WidgetID last_user_action
Last started user action.
void DrawWidget(const Rect &r, WidgetID widget) const override
Draw the contents of a nested widget.
void OnPlaceMouseUp(ViewportPlaceMethod select_method, ViewportDragDropSelectionProcess select_proc, Point pt, TileIndex start_tile, TileIndex end_tile) override
The user has dragged over the map when the tile highlight mode has been set.
void OnPlaceDrag(ViewportPlaceMethod select_method, ViewportDragDropSelectionProcess select_proc, Point pt) override
The user is dragging over the map when the tile highlight mode has been set.
void OnTimeout() override
Called when this window's timeout has been reached.
static EventState TerraformToolbarEditorGlobalHotkeys(int hotkey)
Handler for global hotkeys of the ScenarioEditorLandscapeGenerationWindow.
void UpdateWidgetSize(WidgetID widget, Dimension &size, const Dimension &padding, Dimension &fill, Dimension &resize) override
Update size and resize step of a widget in the window.
bool confirm
Play sound effect on successful constructions or other actions.
Terra form toolbar managing class.
void OnPlaceMouseUp(ViewportPlaceMethod select_method, ViewportDragDropSelectionProcess select_proc, Point pt, TileIndex start_tile, TileIndex end_tile) override
The user has dragged over the map when the tile highlight mode has been set.
void OnPlaceObjectAbort() override
The user cancelled a tile highlight mode that has been set.
void OnPlaceDrag(ViewportPlaceMethod select_method, ViewportDragDropSelectionProcess select_proc, Point pt) override
The user is dragging over the map when the tile highlight mode has been set.
void OnClick(Point pt, WidgetID widget, int click_count) override
A click with the left mouse button has been made on the window.
void OnInit() override
Notification that the nested widget tree gets initialized.
Point OnInitialPosition(int16_t sm_width, int16_t sm_height, int window_number) override
Compute the initial position of the window.
static EventState TerraformToolbarGlobalHotkeys(int hotkey)
Handler for global hotkeys of the TerraformToolbarWindow.
WidgetID last_user_action
Last started user action.
void OnPlaceObject(Point pt, TileIndex tile) override
The user clicked some place on the map when a tile highlight mode has been set.
High level window description.
Definition window_gui.h:168
Number to differentiate different windows of the same class.
Data structure for an opened window.
Definition window_gui.h:274
void FinishInitNested(WindowNumber window_number=0)
Perform the second part of the initialization of a nested widget tree.
Definition window.cpp:1807
void DrawWidgets() const
Paint all widgets of a window.
Definition widget.cpp:766
void RaiseWidgetWhenLowered(WidgetID widget_index)
Marks a widget as raised and dirty (redraw), when it is marked as lowered.
Definition window_gui.h:479
ResizeInfo resize
Resize information.
Definition window_gui.h:315
void CreateNestedTree()
Perform the first part of the initialization of a nested widget tree.
Definition window.cpp:1797
bool IsWidgetLowered(WidgetID widget_index) const
Gets the lowered state of a widget.
Definition window_gui.h:492
void RaiseButtons(bool autoraise=false)
Raise the buttons of the window.
Definition window.cpp:530
int left
x position of left edge of the window
Definition window_gui.h:310
int top
y position of top edge of the window
Definition window_gui.h:311
WidgetLookup widget_lookup
Indexed access to the nested widget tree. Do not access directly, use Window::GetWidget() instead.
Definition window_gui.h:323
void HandleButtonClick(WidgetID widget)
Do all things to make a button look clicked and mark it to be unclicked in a few ticks.
Definition window.cpp:595
virtual EventState OnHotkey(int hotkey)
A hotkey has been pressed.
Definition window.cpp:570
int width
width of the window (number of pixels to the right in x direction)
Definition window_gui.h:312
WindowNumber window_number
Window number within the window class.
Definition window_gui.h:303
Command definitions related to terraforming.
bool GUIPlaceProcDragXY(ViewportDragDropSelectionProcess proc, TileIndex start_tile, TileIndex end_tile)
A central place to handle all X_AND_Y dragged GUI functions.
static void ResetLandscapeConfirmationCallback(Window *, bool confirmed)
Callback function for the scenario editor 'reset landscape' confirmation window.
void PlaceProc_DemolishArea(TileIndex tile)
Start a drag for demolishing an area.
Window * ShowEditorTerraformToolbar()
Show the toolbar for terraforming in the scenario editor.
static void GenerateRockyArea(TileIndex end, TileIndex start)
Scenario editor command that generates rocky areas.
static void CommonRaiseLowerBigLand(TileIndex tile, bool mode)
Raise/Lower a bigger chunk of land at the same time in the editor.
Window * ShowTerraformToolbar(Window *link)
Show the toolbar for terraforming in the game.
static void GenerateDesertArea(TileIndex end, TileIndex start)
Scenario editor command that generates desert areas.
GUI stuff related to terraforming.
Types related to the terraform widgets.
@ WID_ETT_INCREASE_SIZE
Upwards arrow button to increase terraforming size.
@ WID_ETT_PLACE_ROCKS
Place rocks button.
@ WID_ETT_DOTS
Invisible widget for rendering the terraform size on.
@ WID_ETT_DECREASE_SIZE
Downwards arrow button to decrease terraforming size.
@ WID_ETT_SHOW_PLACE_DESERT
Should the place desert button be shown?
@ WID_ETT_PLACE_OBJECT
Place transmitter button.
@ WID_ETT_PLACE_DESERT
Place desert button (in tropical climate).
@ WID_ETT_NEW_SCENARIO
Button for generating a new scenario.
@ WID_ETT_RESET_LANDSCAPE
Button for removing all company-owned property.
@ WID_ETT_BUTTONS_START
Start of pushable buttons.
@ WID_ETT_LEVEL_LAND
Level land button.
@ WID_ETT_LOWER_LAND
Lower land button.
@ WID_ETT_START
Used for iterations.
@ WID_ETT_RAISE_LAND
Raise land button.
@ WID_ETT_BUTTONS_END
End of pushable buttons.
@ WID_ETT_DEMOLISH
Demolish aka dynamite button.
@ WID_TT_LEVEL_LAND
Level land button.
@ WID_TT_DEMOLISH
Demolish aka dynamite button.
@ WID_TT_SHOW_PLACE_OBJECT
Should the place object button be shown?
@ WID_TT_RAISE_LAND
Raise land button.
@ WID_TT_PLACE_OBJECT
Place object button.
@ WID_TT_PLANT_TREES
Plant trees button (note: opens separate window, no place-push-button).
@ WID_TT_PLACE_SIGN
Place sign button.
@ WID_TT_BUY_LAND
Buy land button.
@ WID_TT_BUTTONS_START
Start of pushable buttons.
@ WID_TT_LOWER_LAND
Lower land button.
Stuff related to the text buffer GUI.
static debug_inline TileType GetTileType(Tile tile)
Get the tiletype of a given tile.
Definition tile_map.h:96
void SetTropicZone(Tile tile, TropicZone type)
Set the tropic zone.
Definition tile_map.h:225
static debug_inline uint TileHeight(Tile tile)
Returns the height of a tile.
Definition tile_map.h:29
static constexpr uint MAX_TILE_HEIGHT
Maximum allowed tile height.
Definition tile_type.h:24
@ TROPICZONE_DESERT
Tile is desert.
Definition tile_type.h:78
@ TROPICZONE_NORMAL
Normal tropiczone.
Definition tile_type.h:77
@ MP_TREES
Tile got trees.
Definition tile_type.h:52
@ MP_CLEAR
A tile without any structures, i.e. grass, rocks, farm fields etc.
Definition tile_type.h:48
Functions related to tile highlights.
void VpSelectTilesWithMethod(int x, int y, ViewportPlaceMethod method)
Selects tiles while dragging.
void VpStartPlaceSizing(TileIndex tile, ViewportPlaceMethod method, ViewportDragDropSelectionProcess process)
highlighting tiles while only going over them with the mouse
@ HT_DIAGONAL
Also allow 'diagonal rectangles'. Only usable in combination with HT_RECT or HT_POINT.
@ HT_POINT
point (lower land, raise land, level land, ...)
@ HT_RECT
rectangle (stations, depots, ...)
Map accessors for tree tiles.
TreeGround GetTreeGround(Tile t)
Returns the groundtype for tree tiles.
Definition tree_map.h:102
@ TREE_GROUND_SHORE
shore
Definition tree_map.h:56
void SetTileSelectSize(int w, int h)
Highlight w by h tiles at the cursor.
void SetRedErrorSquare(TileIndex tile)
Set a tile to display a red error square.
Functions related to (drawing on) viewports.
ViewportPlaceMethod
Viewport place method (type of highlighted area and placed objects)
@ VPM_X_AND_Y
area of land in X and Y directions
ViewportDragDropSelectionProcess
Drag and drop selection process, or, what to do with an area of land when you've selected it.
@ DDSP_CREATE_DESERT
Fill area with desert.
@ DDSP_LOWER_AND_LEVEL_AREA
Lower / level area.
@ DDSP_DEMOLISH_AREA
Clear area.
@ DDSP_CREATE_ROCKS
Fill area with rocks.
@ DDSP_RAISE_AND_LEVEL_AREA
Raise / level area.
@ DDSP_LEVEL_AREA
Level area.
@ DDSP_BUILD_OBJECT
Build an object.
static RectPadding ScaleGUITrad(const RectPadding &r)
Scale a RectPadding to GUI zoom level.
Definition widget.cpp:49
@ WWT_IMGBTN
(Toggle) Button with image
Definition widget_type.h:42
@ WWT_PUSHIMGBTN
Normal push-button (no toggle button) with image caption.
@ NWID_SPACER
Invisible widget that takes some space.
Definition widget_type.h:71
@ NWID_HORIZONTAL
Horizontal container.
Definition widget_type.h:67
@ WWT_TEXTBTN
(Toggle) Button with text
Definition widget_type.h:45
@ WWT_PANEL
Simple depressed panel.
Definition widget_type.h:40
@ WWT_STICKYBOX
Sticky box (at top-right of a window, after WWT_DEFSIZEBOX)
Definition widget_type.h:58
@ WWT_SHADEBOX
Shade box (at top-right of a window, between WWT_DEBUGBOX and WWT_DEFSIZEBOX)
Definition widget_type.h:56
@ WWT_CAPTION
Window caption (window title between closebox and stickybox)
Definition widget_type.h:53
@ NWID_VERTICAL
Vertical container.
Definition widget_type.h:69
@ WWT_CLOSEBOX
Close box (at top-left of a window)
Definition widget_type.h:61
@ WWT_EMPTY
Empty widget, place holder to reserve space in widget tree.
Definition widget_type.h:38
@ NWID_SELECTION
Stacked widgets, only one visible at a time (eg in a panel with tabs).
Definition widget_type.h:72
@ SZSP_NONE
Display plane with zero size in both directions (none filling and resizing).
void CloseWindowById(WindowClass cls, WindowNumber number, bool force, int data)
Close a window by its class and window number (if it is open).
Definition window.cpp:1193
Window * FindWindowByClass(WindowClass cls)
Find any window by its class.
Definition window.cpp:1166
Point GetToolbarAlignedWindowPosition(int window_width)
Computer the position of the top-left corner of a window to be opened right under the toolbar.
Definition window.cpp:1683
void InvalidateWindowClassesData(WindowClass cls, int data, bool gui_scope)
Mark window data of all windows of a given class as invalid (in need of re-computing) Note that by de...
Definition window.cpp:3311
Window functions not directly related to making/drawing windows.
Functions, definitions and such used only by the GUI.
@ Construction
This window is used for construction; close it whenever changing company.
@ WDP_AUTO
Find a place automatically.
Definition window_gui.h:144
@ WDP_MANUAL
Manually align the window (so no automatic location finding)
Definition window_gui.h:143
int WidgetID
Widget ID.
Definition window_type.h:20
EventState
State of handling an event.
@ ES_NOT_HANDLED
The passed event is not handled.
static constexpr WidgetID INVALID_WIDGET
An invalid widget index.
Definition window_type.h:23
@ WC_BUILD_TOOLBAR
Build toolbar; Window numbers:
Definition window_type.h:78
@ WC_NONE
No window, redirects to WC_MAIN_WINDOW.
Definition window_type.h:50
@ WC_SCEN_LAND_GEN
Landscape generation (in Scenario Editor); Window numbers:
@ WC_TOWN_VIEW
Town view; Window numbers:
Functions related to zooming.