OpenTTD Source  12.0-beta2
smallmap_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 "clear_map.h"
12 #include "industry.h"
13 #include "station_map.h"
14 #include "landscape.h"
15 #include "tree_map.h"
16 #include "viewport_func.h"
17 #include "town.h"
18 #include "tunnelbridge_map.h"
19 #include "core/endian_func.hpp"
20 #include "vehicle_base.h"
21 #include "sound_func.h"
22 #include "window_func.h"
23 #include "company_base.h"
24 #include "guitimer_func.h"
25 #include "zoom_func.h"
26 
27 #include "smallmap_gui.h"
28 
29 #include "table/strings.h"
30 
31 #include <bitset>
32 
33 #include "safeguards.h"
34 
38 
40 static uint8 _linkstat_colours_in_legenda[] = {0, 1, 3, 5, 7, 9, 11};
41 
42 static const int NUM_NO_COMPANY_ENTRIES = 4;
43 
45 #define MK(a, b) {a, b, INVALID_INDUSTRYTYPE, 0, INVALID_COMPANY, true, false, false}
46 
48 #define MC(col_break) {0, STR_TINY_BLACK_HEIGHT, INVALID_INDUSTRYTYPE, 0, INVALID_COMPANY, true, false, col_break}
49 
51 #define MO(a, b) {a, b, INVALID_INDUSTRYTYPE, 0, INVALID_COMPANY, true, false, false}
52 
54 #define MOEND() {0, 0, INVALID_INDUSTRYTYPE, 0, OWNER_NONE, true, true, false}
55 
57 #define MKEND() {0, STR_NULL, INVALID_INDUSTRYTYPE, 0, INVALID_COMPANY, true, true, false}
58 
63 #define MS(a, b) {a, b, INVALID_INDUSTRYTYPE, 0, INVALID_COMPANY, true, false, true}
64 
67  MK(PC_BLACK, STR_SMALLMAP_LEGENDA_ROADS),
68  MK(PC_GREY, STR_SMALLMAP_LEGENDA_RAILROADS),
69  MK(PC_LIGHT_BLUE, STR_SMALLMAP_LEGENDA_STATIONS_AIRPORTS_DOCKS),
70  MK(PC_DARK_RED, STR_SMALLMAP_LEGENDA_BUILDINGS_INDUSTRIES),
71  MK(PC_WHITE, STR_SMALLMAP_LEGENDA_VEHICLES),
72 
73  /* Placeholders for the colours and heights of the legend.
74  * The following values are set at BuildLandLegend() based
75  * on each colour scheme and the maximum map height. */
76  MC(true),
77  MC(false),
78  MC(false),
79  MC(false),
80  MC(false),
81  MC(false),
82  MC(true),
83  MC(false),
84  MC(false),
85  MC(false),
86  MC(false),
87  MC(false),
88  MKEND()
89 };
90 
91 static const LegendAndColour _legend_vehicles[] = {
92  MK(PC_RED, STR_SMALLMAP_LEGENDA_TRAINS),
93  MK(PC_YELLOW, STR_SMALLMAP_LEGENDA_ROAD_VEHICLES),
94  MK(PC_LIGHT_BLUE, STR_SMALLMAP_LEGENDA_SHIPS),
95  MK(PC_WHITE, STR_SMALLMAP_LEGENDA_AIRCRAFT),
96 
97  MS(PC_BLACK, STR_SMALLMAP_LEGENDA_TRANSPORT_ROUTES),
98  MK(PC_DARK_RED, STR_SMALLMAP_LEGENDA_BUILDINGS_INDUSTRIES),
99  MKEND()
100 };
101 
102 static const LegendAndColour _legend_routes[] = {
103  MK(PC_BLACK, STR_SMALLMAP_LEGENDA_ROADS),
104  MK(PC_GREY, STR_SMALLMAP_LEGENDA_RAILROADS),
105  MK(PC_DARK_RED, STR_SMALLMAP_LEGENDA_BUILDINGS_INDUSTRIES),
106 
107  MS(PC_VERY_DARK_BROWN, STR_SMALLMAP_LEGENDA_RAILROAD_STATION),
108  MK(PC_ORANGE, STR_SMALLMAP_LEGENDA_TRUCK_LOADING_BAY),
109  MK(PC_YELLOW, STR_SMALLMAP_LEGENDA_BUS_STATION),
110  MK(PC_RED, STR_SMALLMAP_LEGENDA_AIRPORT_HELIPORT),
111  MK(PC_LIGHT_BLUE, STR_SMALLMAP_LEGENDA_DOCK),
112  MKEND()
113 };
114 
115 static const LegendAndColour _legend_vegetation[] = {
116  MK(PC_ROUGH_LAND, STR_SMALLMAP_LEGENDA_ROUGH_LAND),
117  MK(PC_GRASS_LAND, STR_SMALLMAP_LEGENDA_GRASS_LAND),
118  MK(PC_BARE_LAND, STR_SMALLMAP_LEGENDA_BARE_LAND),
119  MK(PC_RAINFOREST, STR_SMALLMAP_LEGENDA_RAINFOREST),
120  MK(PC_FIELDS, STR_SMALLMAP_LEGENDA_FIELDS),
121  MK(PC_TREES, STR_SMALLMAP_LEGENDA_TREES),
122 
123  MS(PC_GREEN, STR_SMALLMAP_LEGENDA_FOREST),
124  MK(PC_GREY, STR_SMALLMAP_LEGENDA_ROCKS),
125  MK(PC_ORANGE, STR_SMALLMAP_LEGENDA_DESERT),
126  MK(PC_LIGHT_BLUE, STR_SMALLMAP_LEGENDA_SNOW),
127  MK(PC_BLACK, STR_SMALLMAP_LEGENDA_TRANSPORT_ROUTES),
128  MK(PC_DARK_RED, STR_SMALLMAP_LEGENDA_BUILDINGS_INDUSTRIES),
129  MKEND()
130 };
131 
132 static LegendAndColour _legend_land_owners[NUM_NO_COMPANY_ENTRIES + MAX_COMPANIES + 1] = {
133  MO(PC_WATER, STR_SMALLMAP_LEGENDA_WATER),
134  MO(0x00, STR_SMALLMAP_LEGENDA_NO_OWNER), // This colour will vary depending on settings.
135  MO(PC_DARK_RED, STR_SMALLMAP_LEGENDA_TOWNS),
136  MO(PC_DARK_GREY, STR_SMALLMAP_LEGENDA_INDUSTRIES),
137  /* The legend will be terminated the first time it is used. */
138  MOEND(),
139 };
140 
141 #undef MK
142 #undef MC
143 #undef MS
144 #undef MO
145 #undef MOEND
146 #undef MKEND
147 
158 static bool _smallmap_show_heightmap = false;
165 
170 {
171  uint j = 0;
172 
173  /* Add each name */
174  for (IndustryType ind : _sorted_industry_types) {
175  const IndustrySpec *indsp = GetIndustrySpec(ind);
176  if (indsp->enabled) {
177  _legend_from_industries[j].legend = indsp->name;
179  _legend_from_industries[j].type = ind;
182  _legend_from_industries[j].end = false;
183 
184  /* Store widget number for this industry type. */
185  _industry_to_list_pos[ind] = j;
186  j++;
187  }
188  }
189  /* Terminate the list */
190  _legend_from_industries[j].end = true;
191 
192  /* Store number of enabled industries */
194 }
195 
200 {
201  /* Clear the legend */
202  memset(_legend_linkstats, 0, sizeof(_legend_linkstats));
203 
204  uint i = 0;
205  for (; i < _sorted_cargo_specs.size(); ++i) {
206  const CargoSpec *cs = _sorted_cargo_specs[i];
207 
208  _legend_linkstats[i].legend = cs->name;
209  _legend_linkstats[i].colour = cs->legend_colour;
210  _legend_linkstats[i].type = cs->Index();
211  _legend_linkstats[i].show_on_map = true;
212  }
213 
214  _legend_linkstats[i].col_break = true;
216 
218  _legend_linkstats[i].legend = STR_EMPTY;
220  _legend_linkstats[i].show_on_map = true;
221  }
222 
223  _legend_linkstats[_smallmap_cargo_count].legend = STR_LINKGRAPH_LEGEND_UNUSED;
224  _legend_linkstats[i - 1].legend = STR_LINKGRAPH_LEGEND_OVERLOADED;
225  _legend_linkstats[(_smallmap_cargo_count + i - 1) / 2].legend = STR_LINKGRAPH_LEGEND_SATURATED;
226  _legend_linkstats[i].end = true;
227 }
228 
229 static const LegendAndColour * const _legend_table[] = {
231  _legend_vehicles,
234  _legend_routes,
235  _legend_vegetation,
236  _legend_land_owners,
237 };
238 
239 #define MKCOLOUR(x) TO_LE32X(x)
240 
241 #define MKCOLOUR_XXXX(x) (MKCOLOUR(0x01010101) * (uint)(x))
242 #define MKCOLOUR_X0X0(x) (MKCOLOUR(0x01000100) * (uint)(x))
243 #define MKCOLOUR_0X0X(x) (MKCOLOUR(0x00010001) * (uint)(x))
244 #define MKCOLOUR_0XX0(x) (MKCOLOUR(0x00010100) * (uint)(x))
245 #define MKCOLOUR_X00X(x) (MKCOLOUR(0x01000001) * (uint)(x))
246 
247 #define MKCOLOUR_XYXY(x, y) (MKCOLOUR_X0X0(x) | MKCOLOUR_0X0X(y))
248 #define MKCOLOUR_XYYX(x, y) (MKCOLOUR_X00X(x) | MKCOLOUR_0XX0(y))
249 
250 #define MKCOLOUR_0000 MKCOLOUR_XXXX(0x00)
251 #define MKCOLOUR_0FF0 MKCOLOUR_0XX0(0xFF)
252 #define MKCOLOUR_F00F MKCOLOUR_X00X(0xFF)
253 #define MKCOLOUR_FFFF MKCOLOUR_XXXX(0xFF)
254 
255 #include "table/heightmap_colours.h"
256 
259  uint32 *height_colours;
260  const uint32 *height_colours_base;
261  size_t colour_count;
262  uint32 default_colour;
263 };
264 
267  {nullptr, _green_map_heights, lengthof(_green_map_heights), MKCOLOUR_XXXX(0x54)},
268  {nullptr, _dark_green_map_heights, lengthof(_dark_green_map_heights), MKCOLOUR_XXXX(0x62)},
269  {nullptr, _violet_map_heights, lengthof(_violet_map_heights), MKCOLOUR_XXXX(0x81)},
270 };
271 
276 {
277  /* The smallmap window has never been initialized, so no need to change the legend. */
278  if (_heightmap_schemes[0].height_colours == nullptr) return;
279 
280  /*
281  * The general idea of this function is to fill the legend with an appropriate evenly spaced
282  * selection of height levels. All entries with STR_TINY_BLACK_HEIGHT are reserved for this.
283  * At the moment there are twelve of these.
284  *
285  * The table below defines up to which height level a particular delta in the legend should be
286  * used. One could opt for just dividing the maximum height and use that as delta, but that
287  * creates many "ugly" legend labels, e.g. once every 950 meter. As a result, this table will
288  * reduce the number of deltas to 7: every 100m, 200m, 300m, 500m, 750m, 1000m and 1250m. The
289  * deltas are closer together at the lower numbers because going from 12 entries to just 4, as
290  * would happen when replacing 200m and 300m by 250m, would mean the legend would be short and
291  * that might not be considered appropriate.
292  *
293  * The current method yields at least 7 legend entries and at most 12. It can be increased to
294  * 8 by adding a 150m and 400m option, but especially 150m creates ugly heights.
295  *
296  * It tries to evenly space the legend items over the two columns that are there for the legend.
297  */
298 
299  /* Table for delta; if max_height is less than the first column, use the second column as value. */
300  uint deltas[][2] = { { 24, 2 }, { 48, 4 }, { 72, 6 }, { 120, 10 }, { 180, 15 }, { 240, 20 }, { MAX_TILE_HEIGHT + 1, 25 }};
301  uint i = 0;
302  for (; _settings_game.construction.map_height_limit >= deltas[i][0]; i++) {
303  /* Nothing to do here. */
304  }
305  uint delta = deltas[i][1];
306 
307  int total_entries = (_settings_game.construction.map_height_limit / delta) + 1;
308  int rows = CeilDiv(total_entries, 2);
309  int j = 0;
310 
311  for (i = 0; i < lengthof(_legend_land_contours) - 1 && j < total_entries; i++) {
312  if (_legend_land_contours[i].legend != STR_TINY_BLACK_HEIGHT) continue;
313 
314  _legend_land_contours[i].col_break = j % rows == 0;
315  _legend_land_contours[i].end = false;
316  _legend_land_contours[i].height = j * delta;
318  j++;
319  }
320  _legend_land_contours[i].end = true;
321 }
322 
327 {
329 
330  int i = NUM_NO_COMPANY_ENTRIES;
331  for (const Company *c : Company::Iterate()) {
332  _legend_land_owners[i].colour = _colour_gradient[c->colour][5];
333  _legend_land_owners[i].company = c->index;
334  _legend_land_owners[i].show_on_map = true;
335  _legend_land_owners[i].col_break = false;
336  _legend_land_owners[i].end = false;
337  _company_to_list_pos[c->index] = i;
338  i++;
339  }
340 
341  /* Terminate the list */
342  _legend_land_owners[i].end = true;
343 
344  /* Store maximum amount of owner legend entries. */
346 }
347 
348 struct AndOr {
349  uint32 mor;
350  uint32 mand;
351 };
352 
353 static inline uint32 ApplyMask(uint32 colour, const AndOr *mask)
354 {
355  return (colour & mask->mand) | mask->mor;
356 }
357 
358 
360 static const AndOr _smallmap_contours_andor[] = {
361  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_CLEAR
362  {MKCOLOUR_0XX0(PC_GREY ), MKCOLOUR_F00F}, // MP_RAILWAY
363  {MKCOLOUR_0XX0(PC_BLACK ), MKCOLOUR_F00F}, // MP_ROAD
364  {MKCOLOUR_0XX0(PC_DARK_RED ), MKCOLOUR_F00F}, // MP_HOUSE
365  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_TREES
366  {MKCOLOUR_XXXX(PC_LIGHT_BLUE), MKCOLOUR_0000}, // MP_STATION
367  {MKCOLOUR_XXXX(PC_WATER ), MKCOLOUR_0000}, // MP_WATER
368  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_VOID
369  {MKCOLOUR_XXXX(PC_DARK_RED ), MKCOLOUR_0000}, // MP_INDUSTRY
370  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_TUNNELBRIDGE
371  {MKCOLOUR_0XX0(PC_DARK_RED ), MKCOLOUR_F00F}, // MP_OBJECT
372  {MKCOLOUR_0XX0(PC_GREY ), MKCOLOUR_F00F},
373 };
374 
376 static const AndOr _smallmap_vehicles_andor[] = {
377  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_CLEAR
378  {MKCOLOUR_0XX0(PC_BLACK ), MKCOLOUR_F00F}, // MP_RAILWAY
379  {MKCOLOUR_0XX0(PC_BLACK ), MKCOLOUR_F00F}, // MP_ROAD
380  {MKCOLOUR_0XX0(PC_DARK_RED ), MKCOLOUR_F00F}, // MP_HOUSE
381  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_TREES
382  {MKCOLOUR_0XX0(PC_BLACK ), MKCOLOUR_F00F}, // MP_STATION
383  {MKCOLOUR_XXXX(PC_WATER ), MKCOLOUR_0000}, // MP_WATER
384  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_VOID
385  {MKCOLOUR_XXXX(PC_DARK_RED ), MKCOLOUR_0000}, // MP_INDUSTRY
386  {MKCOLOUR_0000 , MKCOLOUR_FFFF}, // MP_TUNNELBRIDGE
387  {MKCOLOUR_0XX0(PC_DARK_RED ), MKCOLOUR_F00F}, // MP_OBJECT
388  {MKCOLOUR_0XX0(PC_BLACK ), MKCOLOUR_F00F},
389 };
390 
392 static const byte _tiletype_importance[] = {
393  2, // MP_CLEAR
394  8, // MP_RAILWAY
395  7, // MP_ROAD
396  5, // MP_HOUSE
397  2, // MP_TREES
398  9, // MP_STATION
399  2, // MP_WATER
400  1, // MP_VOID
401  6, // MP_INDUSTRY
402  8, // MP_TUNNELBRIDGE
403  2, // MP_OBJECT
404  0,
405 };
406 
407 
414 static inline uint32 GetSmallMapContoursPixels(TileIndex tile, TileType t)
415 {
417  return ApplyMask(cs->height_colours[TileHeight(tile)], &_smallmap_contours_andor[t]);
418 }
419 
427 static inline uint32 GetSmallMapVehiclesPixels(TileIndex tile, TileType t)
428 {
430  return ApplyMask(cs->default_colour, &_smallmap_vehicles_andor[t]);
431 }
432 
440 static inline uint32 GetSmallMapIndustriesPixels(TileIndex tile, TileType t)
441 {
444 }
445 
453 static inline uint32 GetSmallMapRoutesPixels(TileIndex tile, TileType t)
454 {
455  switch (t) {
456  case MP_STATION:
457  switch (GetStationType(tile)) {
458  case STATION_RAIL: return MKCOLOUR_XXXX(PC_VERY_DARK_BROWN);
459  case STATION_AIRPORT: return MKCOLOUR_XXXX(PC_RED);
460  case STATION_TRUCK: return MKCOLOUR_XXXX(PC_ORANGE);
461  case STATION_BUS: return MKCOLOUR_XXXX(PC_YELLOW);
462  case STATION_DOCK: return MKCOLOUR_XXXX(PC_LIGHT_BLUE);
463  default: return MKCOLOUR_FFFF;
464  }
465 
466  case MP_RAILWAY: {
467  AndOr andor = {
468  MKCOLOUR_0XX0(GetRailTypeInfo(GetRailType(tile))->map_colour),
470  };
471 
473  return ApplyMask(cs->default_colour, &andor);
474  }
475 
476  case MP_ROAD: {
477  const RoadTypeInfo *rti = nullptr;
478  if (GetRoadTypeRoad(tile) != INVALID_ROADTYPE) {
479  rti = GetRoadTypeInfo(GetRoadTypeRoad(tile));
480  } else {
481  rti = GetRoadTypeInfo(GetRoadTypeTram(tile));
482  }
483  if (rti != nullptr) {
484  AndOr andor = {
485  MKCOLOUR_0XX0(rti->map_colour),
487  };
488 
490  return ApplyMask(cs->default_colour, &andor);
491  }
492  FALLTHROUGH;
493  }
494 
495  default:
496  /* Ground colour */
498  return ApplyMask(cs->default_colour, &_smallmap_contours_andor[t]);
499  }
500 }
501 
509 static inline uint32 GetSmallMapLinkStatsPixels(TileIndex tile, TileType t)
510 {
512 }
513 
514 static const uint32 _vegetation_clear_bits[] = {
515  MKCOLOUR_XXXX(PC_GRASS_LAND),
516  MKCOLOUR_XXXX(PC_ROUGH_LAND),
517  MKCOLOUR_XXXX(PC_GREY),
518  MKCOLOUR_XXXX(PC_FIELDS),
519  MKCOLOUR_XXXX(PC_LIGHT_BLUE),
520  MKCOLOUR_XXXX(PC_ORANGE),
521  MKCOLOUR_XXXX(PC_GRASS_LAND),
522  MKCOLOUR_XXXX(PC_GRASS_LAND),
523 };
524 
532 static inline uint32 GetSmallMapVegetationPixels(TileIndex tile, TileType t)
533 {
534  switch (t) {
535  case MP_CLEAR:
536  if (IsClearGround(tile, CLEAR_GRASS)) {
537  if (GetClearDensity(tile) < 3) return MKCOLOUR_XXXX(PC_BARE_LAND);
538  if (GetTropicZone(tile) == TROPICZONE_RAINFOREST) return MKCOLOUR_XXXX(PC_RAINFOREST);
539  }
540  return _vegetation_clear_bits[GetClearGround(tile)];
541 
542  case MP_INDUSTRY:
543  return IsTileForestIndustry(tile) ? MKCOLOUR_XXXX(PC_GREEN) : MKCOLOUR_XXXX(PC_DARK_RED);
544 
545  case MP_TREES:
547  return (_settings_game.game_creation.landscape == LT_ARCTIC) ? MKCOLOUR_XYYX(PC_LIGHT_BLUE, PC_TREES) : MKCOLOUR_XYYX(PC_ORANGE, PC_TREES);
548  }
549  return (GetTropicZone(tile) == TROPICZONE_RAINFOREST) ? MKCOLOUR_XYYX(PC_RAINFOREST, PC_TREES) : MKCOLOUR_XYYX(PC_GRASS_LAND, PC_TREES);
550 
551  default:
552  return ApplyMask(MKCOLOUR_XXXX(PC_GRASS_LAND), &_smallmap_vehicles_andor[t]);
553  }
554 }
555 
563 static inline uint32 GetSmallMapOwnerPixels(TileIndex tile, TileType t)
564 {
565  Owner o;
566 
567  switch (t) {
568  case MP_INDUSTRY: return MKCOLOUR_XXXX(PC_DARK_GREY);
569  case MP_HOUSE: return MKCOLOUR_XXXX(PC_DARK_RED);
570  default: o = GetTileOwner(tile); break;
571  /* FIXME: For MP_ROAD there are multiple owners.
572  * GetTileOwner returns the rail owner (level crossing) resp. the owner of ROADTYPE_ROAD (normal road),
573  * even if there are no ROADTYPE_ROAD bits on the tile.
574  */
575  }
576 
577  if ((o < MAX_COMPANIES && !_legend_land_owners[_company_to_list_pos[o]].show_on_map) || o == OWNER_NONE || o == OWNER_WATER) {
578  if (t == MP_WATER) return MKCOLOUR_XXXX(PC_WATER);
581  } else if (o == OWNER_TOWN) {
582  return MKCOLOUR_XXXX(PC_DARK_RED);
583  }
584 
585  return MKCOLOUR_XXXX(_legend_land_owners[_company_to_list_pos[o]].colour);
586 }
587 
589 static const byte _vehicle_type_colours[6] = {
591 };
592 
593 
596 {
598 }
599 
600 inline Point SmallMapWindow::SmallmapRemapCoords(int x, int y) const
601 {
602  Point pt;
603  pt.x = (y - x) * 2;
604  pt.y = y + x;
605  return pt;
606 }
607 
614 inline Point SmallMapWindow::RemapTile(int tile_x, int tile_y) const
615 {
616  int x_offset = tile_x - this->scroll_x / (int)TILE_SIZE;
617  int y_offset = tile_y - this->scroll_y / (int)TILE_SIZE;
618 
619  if (this->zoom == 1) return SmallmapRemapCoords(x_offset, y_offset);
620 
621  /* For negative offsets, round towards -inf. */
622  if (x_offset < 0) x_offset -= this->zoom - 1;
623  if (y_offset < 0) y_offset -= this->zoom - 1;
624 
625  return SmallmapRemapCoords(x_offset / this->zoom, y_offset / this->zoom);
626 }
627 
638 inline Point SmallMapWindow::PixelToTile(int px, int py, int *sub, bool add_sub) const
639 {
640  if (add_sub) px += this->subscroll; // Total horizontal offset.
641 
642  /* For each two rows down, add a x and a y tile, and
643  * For each four pixels to the right, move a tile to the right. */
644  Point pt = {((py >> 1) - (px >> 2)) * this->zoom, ((py >> 1) + (px >> 2)) * this->zoom};
645  px &= 3;
646 
647  if (py & 1) { // Odd number of rows, handle the 2 pixel shift.
648  if (px < 2) {
649  pt.x += this->zoom;
650  px += 2;
651  } else {
652  pt.y += this->zoom;
653  px -= 2;
654  }
655  }
656 
657  *sub = px;
658  return pt;
659 }
660 
670 Point SmallMapWindow::ComputeScroll(int tx, int ty, int x, int y, int *sub)
671 {
672  assert(x >= 0 && y >= 0);
673 
674  int new_sub;
675  Point tile_xy = PixelToTile(x, y, &new_sub, false);
676  tx -= tile_xy.x;
677  ty -= tile_xy.y;
678 
679  Point scroll;
680  if (new_sub == 0) {
681  *sub = 0;
682  scroll.x = (tx + this->zoom) * TILE_SIZE;
683  scroll.y = (ty - this->zoom) * TILE_SIZE;
684  } else {
685  *sub = 4 - new_sub;
686  scroll.x = (tx + 2 * this->zoom) * TILE_SIZE;
687  scroll.y = (ty - 2 * this->zoom) * TILE_SIZE;
688  }
689  return scroll;
690 }
691 
699 {
700  static const int zoomlevels[] = {1, 2, 4, 6, 8}; // Available zoom levels. Bigger number means more zoom-out (further away).
701  static const int MIN_ZOOM_INDEX = 0;
702  static const int MAX_ZOOM_INDEX = lengthof(zoomlevels) - 1;
703 
704  int new_index, cur_index, sub;
705  Point tile;
706  switch (change) {
707  case ZLC_INITIALIZE:
708  cur_index = - 1; // Definitely different from new_index.
709  new_index = MIN_ZOOM_INDEX;
710  tile.x = tile.y = 0;
711  break;
712 
713  case ZLC_ZOOM_IN:
714  case ZLC_ZOOM_OUT:
715  for (cur_index = MIN_ZOOM_INDEX; cur_index <= MAX_ZOOM_INDEX; cur_index++) {
716  if (this->zoom == zoomlevels[cur_index]) break;
717  }
718  assert(cur_index <= MAX_ZOOM_INDEX);
719 
720  tile = this->PixelToTile(zoom_pt->x, zoom_pt->y, &sub);
721  new_index = Clamp(cur_index + ((change == ZLC_ZOOM_IN) ? -1 : 1), MIN_ZOOM_INDEX, MAX_ZOOM_INDEX);
722  break;
723 
724  default: NOT_REACHED();
725  }
726 
727  if (new_index != cur_index) {
728  this->zoom = zoomlevels[new_index];
729  if (cur_index >= 0) {
730  Point new_tile = this->PixelToTile(zoom_pt->x, zoom_pt->y, &sub);
731  this->SetNewScroll(this->scroll_x + (tile.x - new_tile.x) * TILE_SIZE,
732  this->scroll_y + (tile.y - new_tile.y) * TILE_SIZE, sub);
733  } else if (this->map_type == SMT_LINKSTATS) {
734  this->overlay->SetDirty();
735  }
736  this->SetWidgetDisabledState(WID_SM_ZOOM_IN, this->zoom == zoomlevels[MIN_ZOOM_INDEX]);
737  this->SetWidgetDisabledState(WID_SM_ZOOM_OUT, this->zoom == zoomlevels[MAX_ZOOM_INDEX]);
738  this->SetDirty();
739  }
740 }
741 
747 inline uint32 SmallMapWindow::GetTileColours(const TileArea &ta) const
748 {
749  int importance = 0;
750  TileIndex tile = INVALID_TILE; // Position of the most important tile.
751  TileType et = MP_VOID; // Effective tile type at that position.
752 
753  for (TileIndex ti : ta) {
754  TileType ttype = GetTileType(ti);
755 
756  switch (ttype) {
757  case MP_TUNNELBRIDGE: {
759 
760  switch (tt) {
761  case TRANSPORT_RAIL: ttype = MP_RAILWAY; break;
762  case TRANSPORT_ROAD: ttype = MP_ROAD; break;
763  default: ttype = MP_WATER; break;
764  }
765  break;
766  }
767 
768  case MP_INDUSTRY:
769  /* Special handling of industries while in "Industries" smallmap view. */
770  if (this->map_type == SMT_INDUSTRY) {
771  /* If industry is allowed to be seen, use its colour on the map.
772  * This has the highest priority above any value in _tiletype_importance. */
773  IndustryType type = Industry::GetByTile(ti)->type;
774  if (_legend_from_industries[_industry_to_list_pos[type]].show_on_map) {
775  if (type == _smallmap_industry_highlight) {
776  if (_smallmap_industry_highlight_state) return MKCOLOUR_XXXX(PC_WHITE);
777  } else {
778  return GetIndustrySpec(type)->map_colour * 0x01010101;
779  }
780  }
781  /* Otherwise make it disappear */
782  ttype = IsTileOnWater(ti) ? MP_WATER : MP_CLEAR;
783  }
784  break;
785 
786  default:
787  break;
788  }
789 
790  if (_tiletype_importance[ttype] > importance) {
791  importance = _tiletype_importance[ttype];
792  tile = ti;
793  et = ttype;
794  }
795  }
796 
797  switch (this->map_type) {
798  case SMT_CONTOUR:
799  return GetSmallMapContoursPixels(tile, et);
800 
801  case SMT_VEHICLES:
802  return GetSmallMapVehiclesPixels(tile, et);
803 
804  case SMT_INDUSTRY:
805  return GetSmallMapIndustriesPixels(tile, et);
806 
807  case SMT_LINKSTATS:
808  return GetSmallMapLinkStatsPixels(tile, et);
809 
810  case SMT_ROUTES:
811  return GetSmallMapRoutesPixels(tile, et);
812 
813  case SMT_VEGETATION:
814  return GetSmallMapVegetationPixels(tile, et);
815 
816  case SMT_OWNER:
817  return GetSmallMapOwnerPixels(tile, et);
818 
819  default: NOT_REACHED();
820  }
821 }
822 
836 void SmallMapWindow::DrawSmallMapColumn(void *dst, uint xc, uint yc, int pitch, int reps, int start_pos, int end_pos, Blitter *blitter) const
837 {
838  void *dst_ptr_abs_end = blitter->MoveTo(_screen.dst_ptr, 0, _screen.height);
839  uint min_xy = _settings_game.construction.freeform_edges ? 1 : 0;
840 
841  do {
842  /* Check if the tile (xc,yc) is within the map range */
843  if (xc >= MapMaxX() || yc >= MapMaxY()) continue;
844 
845  /* Check if the dst pointer points to a pixel inside the screen buffer */
846  if (dst < _screen.dst_ptr) continue;
847  if (dst >= dst_ptr_abs_end) continue;
848 
849  /* Construct tilearea covered by (xc, yc, xc + this->zoom, yc + this->zoom) such that it is within min_xy limits. */
850  TileArea ta;
851  if (min_xy == 1 && (xc == 0 || yc == 0)) {
852  if (this->zoom == 1) continue; // The tile area is empty, don't draw anything.
853 
854  ta = TileArea(TileXY(std::max(min_xy, xc), std::max(min_xy, yc)), this->zoom - (xc == 0), this->zoom - (yc == 0));
855  } else {
856  ta = TileArea(TileXY(xc, yc), this->zoom, this->zoom);
857  }
858  ta.ClampToMap(); // Clamp to map boundaries (may contain MP_VOID tiles!).
859 
860  uint32 val = this->GetTileColours(ta);
861  uint8 *val8 = (uint8 *)&val;
862  int idx = std::max(0, -start_pos);
863  for (int pos = std::max(0, start_pos); pos < end_pos; pos++) {
864  blitter->SetPixel(dst, idx, 0, val8[idx]);
865  idx++;
866  }
867  /* Switch to next tile in the column */
868  } while (xc += this->zoom, yc += this->zoom, dst = blitter->MoveTo(dst, pitch, 0), --reps != 0);
869 }
870 
876 void SmallMapWindow::DrawVehicles(const DrawPixelInfo *dpi, Blitter *blitter) const
877 {
878  for (const Vehicle *v : Vehicle::Iterate()) {
879  if (v->type == VEH_EFFECT) continue;
880  if (v->vehstatus & (VS_HIDDEN | VS_UNCLICKABLE)) continue;
881 
882  /* Remap into flat coordinates. */
883  Point pt = this->RemapTile(v->x_pos / (int)TILE_SIZE, v->y_pos / (int)TILE_SIZE);
884 
885  int y = pt.y - dpi->top;
886  if (!IsInsideMM(y, 0, dpi->height)) continue; // y is out of bounds.
887 
888  bool skip = false; // Default is to draw both pixels.
889  int x = pt.x - this->subscroll - 3 - dpi->left; // Offset X coordinate.
890  if (x < 0) {
891  /* if x+1 is 0, that means we're on the very left edge,
892  * and should thus only draw a single pixel */
893  if (++x != 0) continue;
894  skip = true;
895  } else if (x >= dpi->width - 1) {
896  /* Check if we're at the very right edge, and if so draw only a single pixel */
897  if (x != dpi->width - 1) continue;
898  skip = true;
899  }
900 
901  /* Calculate pointer to pixel and the colour */
902  byte colour = (this->map_type == SMT_VEHICLES) ? _vehicle_type_colours[v->type] : PC_WHITE;
903 
904  /* And draw either one or two pixels depending on clipping */
905  blitter->SetPixel(dpi->dst_ptr, x, y, colour);
906  if (!skip) blitter->SetPixel(dpi->dst_ptr, x + 1, y, colour);
907  }
908 }
909 
915 {
916  for (const Town *t : Town::Iterate()) {
917  /* Remap the town coordinate */
918  Point pt = this->RemapTile(TileX(t->xy), TileY(t->xy));
919  int x = pt.x - this->subscroll - (t->cache.sign.width_small >> 1);
920  int y = pt.y;
921 
922  /* Check if the town sign is within bounds */
923  if (x + t->cache.sign.width_small > dpi->left &&
924  x < dpi->left + dpi->width &&
925  y + FONT_HEIGHT_SMALL > dpi->top &&
926  y < dpi->top + dpi->height) {
927  /* And draw it. */
928  SetDParam(0, t->index);
929  DrawString(x, x + t->cache.sign.width_small, y, STR_SMALLMAP_TOWN);
930  }
931  }
932 }
933 
938 {
939  /* Find main viewport. */
941 
942  Point upper_left_smallmap_coord = InverseRemapCoords2(vp->virtual_left, vp->virtual_top);
943  Point lower_right_smallmap_coord = InverseRemapCoords2(vp->virtual_left + vp->virtual_width - 1, vp->virtual_top + vp->virtual_height - 1);
944 
945  Point upper_left = this->RemapTile(upper_left_smallmap_coord.x / (int)TILE_SIZE, upper_left_smallmap_coord.y / (int)TILE_SIZE);
946  upper_left.x -= this->subscroll;
947 
948  Point lower_right = this->RemapTile(lower_right_smallmap_coord.x / (int)TILE_SIZE, lower_right_smallmap_coord.y / (int)TILE_SIZE);
949  lower_right.x -= this->subscroll;
950 
951  SmallMapWindow::DrawVertMapIndicator(upper_left.x, upper_left.y, lower_right.y);
952  SmallMapWindow::DrawVertMapIndicator(lower_right.x, upper_left.y, lower_right.y);
953 
954  SmallMapWindow::DrawHorizMapIndicator(upper_left.x, lower_right.x, upper_left.y);
955  SmallMapWindow::DrawHorizMapIndicator(upper_left.x, lower_right.x, lower_right.y);
956 }
957 
970 {
972  DrawPixelInfo *old_dpi;
973 
974  old_dpi = _cur_dpi;
975  _cur_dpi = dpi;
976 
977  /* Clear it */
978  GfxFillRect(dpi->left, dpi->top, dpi->left + dpi->width - 1, dpi->top + dpi->height - 1, PC_BLACK);
979 
980  /* Which tile is displayed at (dpi->left, dpi->top)? */
981  int dx;
982  Point tile = this->PixelToTile(dpi->left, dpi->top, &dx);
983  int tile_x = this->scroll_x / (int)TILE_SIZE + tile.x;
984  int tile_y = this->scroll_y / (int)TILE_SIZE + tile.y;
985 
986  void *ptr = blitter->MoveTo(dpi->dst_ptr, -dx - 4, 0);
987  int x = - dx - 4;
988  int y = 0;
989 
990  for (;;) {
991  /* Distance from left edge */
992  if (x >= -3) {
993  if (x >= dpi->width) break; // Exit the loop.
994 
995  int end_pos = std::min(dpi->width, x + 4);
996  int reps = (dpi->height - y + 1) / 2; // Number of lines.
997  if (reps > 0) {
998  this->DrawSmallMapColumn(ptr, tile_x, tile_y, dpi->pitch * 2, reps, x, end_pos, blitter);
999  }
1000  }
1001 
1002  if (y == 0) {
1003  tile_y += this->zoom;
1004  y++;
1005  ptr = blitter->MoveTo(ptr, 0, 1);
1006  } else {
1007  tile_x -= this->zoom;
1008  y--;
1009  ptr = blitter->MoveTo(ptr, 0, -1);
1010  }
1011  ptr = blitter->MoveTo(ptr, 2, 0);
1012  x += 2;
1013  }
1014 
1015  /* Draw vehicles */
1016  if (this->map_type == SMT_CONTOUR || this->map_type == SMT_VEHICLES) this->DrawVehicles(dpi, blitter);
1017 
1018  /* Draw link stat overlay */
1019  if (this->map_type == SMT_LINKSTATS) this->overlay->Draw(dpi);
1020 
1021  /* Draw town names */
1022  if (this->show_towns) this->DrawTowns(dpi);
1023 
1024  /* Draw map indicators */
1025  this->DrawMapIndicators();
1026 
1027  _cur_dpi = old_dpi;
1028 }
1029 
1034 {
1035  StringID legend_tooltip;
1036  StringID enable_all_tooltip;
1037  StringID disable_all_tooltip;
1038  int plane;
1039  switch (this->map_type) {
1040  case SMT_INDUSTRY:
1041  legend_tooltip = STR_SMALLMAP_TOOLTIP_INDUSTRY_SELECTION;
1042  enable_all_tooltip = STR_SMALLMAP_TOOLTIP_ENABLE_ALL_INDUSTRIES;
1043  disable_all_tooltip = STR_SMALLMAP_TOOLTIP_DISABLE_ALL_INDUSTRIES;
1044  plane = 0;
1045  break;
1046 
1047  case SMT_OWNER:
1048  legend_tooltip = STR_SMALLMAP_TOOLTIP_COMPANY_SELECTION;
1049  enable_all_tooltip = STR_SMALLMAP_TOOLTIP_ENABLE_ALL_COMPANIES;
1050  disable_all_tooltip = STR_SMALLMAP_TOOLTIP_DISABLE_ALL_COMPANIES;
1051  plane = 0;
1052  break;
1053 
1054  case SMT_LINKSTATS:
1055  legend_tooltip = STR_SMALLMAP_TOOLTIP_CARGO_SELECTION;
1056  enable_all_tooltip = STR_SMALLMAP_TOOLTIP_ENABLE_ALL_CARGOS;
1057  disable_all_tooltip = STR_SMALLMAP_TOOLTIP_DISABLE_ALL_CARGOS;
1058  plane = 0;
1059  break;
1060 
1061  default:
1062  legend_tooltip = STR_NULL;
1063  enable_all_tooltip = STR_NULL;
1064  disable_all_tooltip = STR_NULL;
1065  plane = 1;
1066  break;
1067  }
1068 
1069  this->GetWidget<NWidgetCore>(WID_SM_LEGEND)->SetDataTip(STR_NULL, legend_tooltip);
1070  this->GetWidget<NWidgetCore>(WID_SM_ENABLE_ALL)->SetDataTip(STR_SMALLMAP_ENABLE_ALL, enable_all_tooltip);
1071  this->GetWidget<NWidgetCore>(WID_SM_DISABLE_ALL)->SetDataTip(STR_SMALLMAP_DISABLE_ALL, disable_all_tooltip);
1072  this->GetWidget<NWidgetStacked>(WID_SM_SELECT_BUTTONS)->SetDisplayedPlane(plane);
1073 }
1074 
1075 SmallMapWindow::SmallMapWindow(WindowDesc *desc, int window_number) : Window(desc), refresh(GUITimer(FORCE_REFRESH_PERIOD))
1076 {
1078  this->overlay = new LinkGraphOverlay(this, WID_SM_MAP, 0, this->GetOverlayCompanyMask(), 1);
1079  this->InitNested(window_number);
1080  this->LowerWidget(this->map_type + WID_SM_CONTOUR);
1081 
1083 
1085 
1087 
1088  this->SetupWidgetData();
1089 
1090  this->SetZoomLevel(ZLC_INITIALIZE, nullptr);
1092  this->SetOverlayCargoMask();
1093 }
1094 
1095 SmallMapWindow::~SmallMapWindow()
1096 {
1097  delete this->overlay;
1098 }
1099 
1100 /* virtual */ void SmallMapWindow::Close()
1101 {
1102  this->BreakIndustryChainLink();
1103  this->Window::Close();
1104 }
1105 
1110 {
1111  /* Rebuild colour indices if necessary. */
1113 
1114  for (uint n = 0; n < lengthof(_heightmap_schemes); n++) {
1115  /* The heights go from 0 up to and including maximum. */
1116  int heights = _settings_game.construction.map_height_limit + 1;
1117  _heightmap_schemes[n].height_colours = ReallocT<uint32>(_heightmap_schemes[n].height_colours, heights);
1118 
1119  for (int z = 0; z < heights; z++) {
1120  size_t access_index = (_heightmap_schemes[n].colour_count * z) / heights;
1121 
1122  /* Choose colour by mapping the range (0..max heightlevel) on the complete colour table. */
1124  }
1125  }
1126 
1128  BuildLandLegend();
1129 }
1130 
1131 /* virtual */ void SmallMapWindow::SetStringParameters(int widget) const
1132 {
1133  switch (widget) {
1134  case WID_SM_CAPTION:
1135  SetDParam(0, STR_SMALLMAP_TYPE_CONTOURS + this->map_type);
1136  break;
1137  }
1138 }
1139 
1140 /* virtual */ void SmallMapWindow::OnInit()
1141 {
1142  uint min_width = 0;
1145  for (uint i = 0; i < lengthof(_legend_table); i++) {
1146  uint height = 0;
1147  uint num_columns = 1;
1148  for (const LegendAndColour *tbl = _legend_table[i]; !tbl->end; ++tbl) {
1149  StringID str;
1150  if (i == SMT_INDUSTRY) {
1151  SetDParam(0, tbl->legend);
1153  str = STR_SMALLMAP_INDUSTRY;
1154  } else if (i == SMT_LINKSTATS) {
1155  SetDParam(0, tbl->legend);
1156  str = STR_SMALLMAP_LINKSTATS;
1157  } else if (i == SMT_OWNER) {
1158  if (tbl->company != INVALID_COMPANY) {
1159  if (!Company::IsValidID(tbl->company)) {
1160  /* Rebuild the owner legend. */
1161  BuildOwnerLegend();
1162  this->OnInit();
1163  return;
1164  }
1165  /* Non-fixed legend entries for the owner view. */
1166  SetDParam(0, tbl->company);
1167  str = STR_SMALLMAP_COMPANY;
1168  } else {
1169  str = tbl->legend;
1170  }
1171  } else {
1172  if (tbl->col_break) {
1173  this->min_number_of_fixed_rows = std::max(this->min_number_of_fixed_rows, height);
1174  height = 0;
1175  num_columns++;
1176  }
1177  height++;
1178  str = tbl->legend;
1179  }
1180  min_width = std::max(GetStringBoundingBox(str).width, min_width);
1181  }
1182  this->min_number_of_fixed_rows = std::max(this->min_number_of_fixed_rows, height);
1183  this->min_number_of_columns = std::max(this->min_number_of_columns, num_columns);
1184  }
1185 
1186  /* Width of the legend blob. */
1187  this->legend_width = (FONT_HEIGHT_SMALL - ScaleFontTrad(1)) * 8 / 5;
1188 
1189  /* The width of a column is the minimum width of all texts + the size of the blob + some spacing */
1190  this->column_width = min_width + this->legend_width + WD_FRAMERECT_LEFT + WD_FRAMERECT_RIGHT;
1191 }
1192 
1193 /* virtual */ void SmallMapWindow::OnPaint()
1194 {
1195  if (this->map_type == SMT_OWNER) {
1196  for (const LegendAndColour *tbl = _legend_table[this->map_type]; !tbl->end; ++tbl) {
1197  if (tbl->company != INVALID_COMPANY && !Company::IsValidID(tbl->company)) {
1198  /* Rebuild the owner legend. */
1199  BuildOwnerLegend();
1200  this->InvalidateData(1);
1201  break;
1202  }
1203  }
1204  }
1205 
1206  this->DrawWidgets();
1207 }
1208 
1209 /* virtual */ void SmallMapWindow::DrawWidget(const Rect &r, int widget) const
1210 {
1211  switch (widget) {
1212  case WID_SM_MAP: {
1213  DrawPixelInfo new_dpi;
1214  if (!FillDrawPixelInfo(&new_dpi, r.left + 1, r.top + 1, r.right - r.left - 1, r.bottom - r.top - 1)) return;
1215  this->DrawSmallMap(&new_dpi);
1216  break;
1217  }
1218 
1219  case WID_SM_LEGEND: {
1220  uint columns = this->GetNumberColumnsLegend(r.right - r.left + 1);
1221  uint number_of_rows = this->GetNumberRowsLegend(columns);
1222  bool rtl = _current_text_dir == TD_RTL;
1223  uint y_org = r.top + WD_FRAMERECT_TOP;
1224  uint x = rtl ? r.right - this->column_width - WD_FRAMERECT_RIGHT : r.left + WD_FRAMERECT_LEFT;
1225  uint y = y_org;
1226  uint i = 0; // Row counter for industry legend.
1227  uint row_height = FONT_HEIGHT_SMALL;
1228  int padding = ScaleFontTrad(1);
1229 
1230  uint text_left = rtl ? 0 : this->legend_width + WD_FRAMERECT_LEFT;
1231  uint text_right = this->column_width - padding - (rtl ? this->legend_width + WD_FRAMERECT_RIGHT : 0);
1232  uint blob_left = rtl ? this->column_width - padding - this->legend_width : 0;
1233  uint blob_right = rtl ? this->column_width - padding : this->legend_width;
1234 
1235  StringID string = STR_NULL;
1236  switch (this->map_type) {
1237  case SMT_INDUSTRY:
1238  string = STR_SMALLMAP_INDUSTRY;
1239  break;
1240  case SMT_LINKSTATS:
1241  string = STR_SMALLMAP_LINKSTATS;
1242  break;
1243  case SMT_OWNER:
1244  string = STR_SMALLMAP_COMPANY;
1245  break;
1246  default:
1247  break;
1248  }
1249 
1250  for (const LegendAndColour *tbl = _legend_table[this->map_type]; !tbl->end; ++tbl) {
1251  if (tbl->col_break || ((this->map_type == SMT_INDUSTRY || this->map_type == SMT_OWNER || this->map_type == SMT_LINKSTATS) && i++ >= number_of_rows)) {
1252  /* Column break needed, continue at top, COLUMN_WIDTH pixels
1253  * (one "row") to the right. */
1254  x += rtl ? -(int)this->column_width : this->column_width;
1255  y = y_org;
1256  i = 1;
1257  }
1258 
1259  uint8 legend_colour = tbl->colour;
1260 
1261  switch (this->map_type) {
1262  case SMT_INDUSTRY:
1263  /* Industry name must be formatted, since it's not in tiny font in the specs.
1264  * So, draw with a parameter and use the STR_SMALLMAP_INDUSTRY string, which is tiny font */
1265  SetDParam(0, tbl->legend);
1267  if (tbl->show_on_map && tbl->type == _smallmap_industry_highlight) {
1269  }
1270  FALLTHROUGH;
1271 
1272  case SMT_LINKSTATS:
1273  SetDParam(0, tbl->legend);
1274  FALLTHROUGH;
1275 
1276  case SMT_OWNER:
1277  if (this->map_type != SMT_OWNER || tbl->company != INVALID_COMPANY) {
1278  if (this->map_type == SMT_OWNER) SetDParam(0, tbl->company);
1279  if (!tbl->show_on_map) {
1280  /* Simply draw the string, not the black border of the legend colour.
1281  * This will enforce the idea of the disabled item */
1282  DrawString(x + text_left, x + text_right, y, string, TC_GREY);
1283  } else {
1284  DrawString(x + text_left, x + text_right, y, string, TC_BLACK);
1285  GfxFillRect(x + blob_left, y + padding, x + blob_right, y + row_height - 1, PC_BLACK); // Outer border of the legend colour
1286  }
1287  break;
1288  }
1289  FALLTHROUGH;
1290 
1291  default:
1292  if (this->map_type == SMT_CONTOUR) SetDParam(0, tbl->height * TILE_HEIGHT_STEP);
1293  /* Anything that is not an industry or a company is using normal process */
1294  GfxFillRect(x + blob_left, y + padding, x + blob_right, y + row_height - 1, PC_BLACK);
1295  DrawString(x + text_left, x + text_right, y, tbl->legend);
1296  break;
1297  }
1298  GfxFillRect(x + blob_left + 1, y + padding + 1, x + blob_right - 1, y + row_height - 2, legend_colour); // Legend colour
1299 
1300  y += row_height;
1301  }
1302  }
1303  }
1304 }
1305 
1311 {
1312  this->RaiseWidget(this->map_type + WID_SM_CONTOUR);
1313  this->map_type = map_type;
1314  this->LowerWidget(this->map_type + WID_SM_CONTOUR);
1315 
1316  this->SetupWidgetData();
1317 
1318  if (map_type == SMT_LINKSTATS) this->overlay->SetDirty();
1319  if (map_type != SMT_INDUSTRY) this->BreakIndustryChainLink();
1320  this->SetDirty();
1321 }
1322 
1331 inline uint SmallMapWindow::GetNumberRowsLegend(uint columns) const
1332 {
1333  /* Reserve one column for link colours */
1334  uint num_rows_linkstats = CeilDiv(_smallmap_cargo_count, columns - 1);
1335  uint num_rows_others = CeilDiv(std::max(_smallmap_industry_count, _smallmap_company_count), columns);
1336  return std::max({this->min_number_of_fixed_rows, num_rows_linkstats, num_rows_others});
1337 }
1338 
1350 void SmallMapWindow::SelectLegendItem(int click_pos, LegendAndColour *legend, int end_legend_item, int begin_legend_item)
1351 {
1352  if (_ctrl_pressed) {
1353  /* Disable all, except the clicked one */
1354  bool changes = false;
1355  for (int i = begin_legend_item; i != end_legend_item; i++) {
1356  bool new_state = (i == click_pos);
1357  if (legend[i].show_on_map != new_state) {
1358  changes = true;
1359  legend[i].show_on_map = new_state;
1360  }
1361  }
1362  if (!changes) {
1363  /* Nothing changed? Then show all (again). */
1364  for (int i = begin_legend_item; i != end_legend_item; i++) {
1365  legend[i].show_on_map = true;
1366  }
1367  }
1368  } else {
1369  legend[click_pos].show_on_map = !legend[click_pos].show_on_map;
1370  }
1371 
1372  if (this->map_type == SMT_INDUSTRY) this->BreakIndustryChainLink();
1373 }
1374 
1379 {
1380  CargoTypes cargo_mask = 0;
1381  for (int i = 0; i != _smallmap_cargo_count; ++i) {
1382  if (_legend_linkstats[i].show_on_map) SetBit(cargo_mask, _legend_linkstats[i].type);
1383  }
1384  this->overlay->SetCargoMask(cargo_mask);
1385 }
1386 
1393 {
1394  const NWidgetBase *wi = this->GetWidget<NWidgetBase>(WID_SM_LEGEND);
1395  uint line = (pt.y - wi->pos_y - WD_FRAMERECT_TOP) / FONT_HEIGHT_SMALL;
1396  uint columns = this->GetNumberColumnsLegend(wi->current_x);
1397  uint number_of_rows = this->GetNumberRowsLegend(columns);
1398  if (line >= number_of_rows) return -1;
1399 
1400  bool rtl = _current_text_dir == TD_RTL;
1401  int x = pt.x - wi->pos_x;
1402  if (rtl) x = wi->current_x - x;
1403  uint column = (x - WD_FRAMERECT_LEFT) / this->column_width;
1404 
1405  return (column * number_of_rows) + line;
1406 }
1407 
1408 /* virtual */ void SmallMapWindow::OnMouseOver(Point pt, int widget)
1409 {
1410  IndustryType new_highlight = INVALID_INDUSTRYTYPE;
1411  if (widget == WID_SM_LEGEND && this->map_type == SMT_INDUSTRY) {
1412  int industry_pos = GetPositionOnLegend(pt);
1413  if (industry_pos >= 0 && industry_pos < _smallmap_industry_count) {
1414  new_highlight = _legend_from_industries[industry_pos].type;
1415  }
1416  }
1417  if (new_highlight != _smallmap_industry_highlight) {
1418  _smallmap_industry_highlight = new_highlight;
1421  this->SetDirty();
1422  }
1423 }
1424 
1425 /* virtual */ void SmallMapWindow::OnClick(Point pt, int widget, int click_count)
1426 {
1427  switch (widget) {
1428  case WID_SM_MAP: { // Map window
1429  if (click_count > 0) this->mouse_capture_widget = widget;
1430 
1431  const NWidgetBase *wid = this->GetWidget<NWidgetBase>(WID_SM_MAP);
1433  int sub;
1434  pt = this->PixelToTile(pt.x - wid->pos_x, pt.y - wid->pos_y, &sub);
1435  ScrollWindowTo(this->scroll_x + pt.x * TILE_SIZE, this->scroll_y + pt.y * TILE_SIZE, -1, w);
1436 
1437  this->SetDirty();
1438  break;
1439  }
1440 
1441  case WID_SM_ZOOM_IN:
1442  case WID_SM_ZOOM_OUT: {
1443  const NWidgetBase *wid = this->GetWidget<NWidgetBase>(WID_SM_MAP);
1444  Point zoom_pt = { (int)wid->current_x / 2, (int)wid->current_y / 2};
1445  this->SetZoomLevel((widget == WID_SM_ZOOM_IN) ? ZLC_ZOOM_IN : ZLC_ZOOM_OUT, &zoom_pt);
1446  if (_settings_client.sound.click_beep) SndPlayFx(SND_15_BEEP);
1447  break;
1448  }
1449 
1450  case WID_SM_CONTOUR: // Show land contours
1451  case WID_SM_VEHICLES: // Show vehicles
1452  case WID_SM_INDUSTRIES: // Show industries
1453  case WID_SM_LINKSTATS: // Show route map
1454  case WID_SM_ROUTES: // Show transport routes
1455  case WID_SM_VEGETATION: // Show vegetation
1456  case WID_SM_OWNERS: // Show land owners
1457  this->SwitchMapType((SmallMapType)(widget - WID_SM_CONTOUR));
1458  if (_settings_client.sound.click_beep) SndPlayFx(SND_15_BEEP);
1459  break;
1460 
1461  case WID_SM_CENTERMAP: // Center the smallmap again
1464  if (_settings_client.sound.click_beep) SndPlayFx(SND_15_BEEP);
1465  break;
1466 
1467  case WID_SM_TOGGLETOWNNAME: // Toggle town names
1468  this->show_towns = !this->show_towns;
1470 
1471  this->SetDirty();
1472  if (_settings_client.sound.click_beep) SndPlayFx(SND_15_BEEP);
1473  break;
1474 
1475  case WID_SM_LEGEND: // Legend
1476  if (this->map_type == SMT_INDUSTRY || this->map_type == SMT_LINKSTATS || this->map_type == SMT_OWNER) {
1477  int click_pos = this->GetPositionOnLegend(pt);
1478  if (click_pos < 0) break;
1479 
1480  /* If industry type small map*/
1481  if (this->map_type == SMT_INDUSTRY) {
1482  /* If click on industries label, find right industry type and enable/disable it. */
1483  if (click_pos < _smallmap_industry_count) {
1485  }
1486  } else if (this->map_type == SMT_LINKSTATS) {
1487  if (click_pos < _smallmap_cargo_count) {
1489  this->SetOverlayCargoMask();
1490  }
1491  } else if (this->map_type == SMT_OWNER) {
1492  if (click_pos < _smallmap_company_count) {
1493  this->SelectLegendItem(click_pos, _legend_land_owners, _smallmap_company_count, NUM_NO_COMPANY_ENTRIES);
1494  }
1495  }
1496  this->SetDirty();
1497  }
1498  break;
1499 
1500  case WID_SM_ENABLE_ALL:
1501  case WID_SM_DISABLE_ALL: {
1502  LegendAndColour *tbl = nullptr;
1503  switch (this->map_type) {
1504  case SMT_INDUSTRY:
1506  this->BreakIndustryChainLink();
1507  break;
1508  case SMT_OWNER:
1509  tbl = &(_legend_land_owners[NUM_NO_COMPANY_ENTRIES]);
1510  break;
1511  case SMT_LINKSTATS:
1512  tbl = _legend_linkstats;
1513  break;
1514  default:
1515  NOT_REACHED();
1516  }
1517  for (;!tbl->end && tbl->legend != STR_LINKGRAPH_LEGEND_UNUSED; ++tbl) {
1518  tbl->show_on_map = (widget == WID_SM_ENABLE_ALL);
1519  }
1520  if (this->map_type == SMT_LINKSTATS) this->SetOverlayCargoMask();
1521  this->SetDirty();
1522  break;
1523  }
1524 
1525  case WID_SM_SHOW_HEIGHT: // Enable/disable showing of heightmap.
1528  this->SetDirty();
1529  break;
1530  }
1531 }
1532 
1541 /* virtual */ void SmallMapWindow::OnInvalidateData(int data, bool gui_scope)
1542 {
1543  if (!gui_scope) return;
1544 
1545  switch (data) {
1546  case 1:
1547  /* The owner legend has already been rebuilt. */
1548  this->ReInit();
1549  break;
1550 
1551  case 0: {
1552  extern std::bitset<NUM_INDUSTRYTYPES> _displayed_industries;
1553  if (this->map_type != SMT_INDUSTRY) this->SwitchMapType(SMT_INDUSTRY);
1554 
1555  for (int i = 0; i != _smallmap_industry_count; i++) {
1557  }
1558  break;
1559  }
1560 
1561  case 2:
1563  break;
1564 
1565  default: NOT_REACHED();
1566  }
1567  this->SetDirty();
1568 }
1569 
1570 /* virtual */ bool SmallMapWindow::OnRightClick(Point pt, int widget)
1571 {
1572  if (widget != WID_SM_MAP || _scrolling_viewport) return false;
1573 
1574  _scrolling_viewport = true;
1575  return true;
1576 }
1577 
1578 /* virtual */ void SmallMapWindow::OnMouseWheel(int wheel)
1579 {
1581  const NWidgetBase *wid = this->GetWidget<NWidgetBase>(WID_SM_MAP);
1582  int cursor_x = _cursor.pos.x - this->left - wid->pos_x;
1583  int cursor_y = _cursor.pos.y - this->top - wid->pos_y;
1584  if (IsInsideMM(cursor_x, 0, wid->current_x) && IsInsideMM(cursor_y, 0, wid->current_y)) {
1585  Point pt = {cursor_x, cursor_y};
1586  this->SetZoomLevel((wheel < 0) ? ZLC_ZOOM_IN : ZLC_ZOOM_OUT, &pt);
1587  }
1588  }
1589 }
1590 
1591 /* virtual */ void SmallMapWindow::OnRealtimeTick(uint delta_ms)
1592 {
1593  /* Update the window every now and then */
1594  if (!this->refresh.Elapsed(delta_ms)) return;
1595 
1596  if (this->map_type == SMT_LINKSTATS) {
1597  uint32 company_mask = this->GetOverlayCompanyMask();
1598  if (this->overlay->GetCompanyMask() != company_mask) {
1599  this->overlay->SetCompanyMask(company_mask);
1600  } else {
1601  this->overlay->SetDirty();
1602  }
1603  }
1605 
1607  this->SetDirty();
1608 }
1609 
1617 void SmallMapWindow::SetNewScroll(int sx, int sy, int sub)
1618 {
1619  const NWidgetBase *wi = this->GetWidget<NWidgetBase>(WID_SM_MAP);
1620  Point hv = InverseRemapCoords(wi->current_x * ZOOM_LVL_BASE * TILE_SIZE / 2, wi->current_y * ZOOM_LVL_BASE * TILE_SIZE / 2);
1621  hv.x *= this->zoom;
1622  hv.y *= this->zoom;
1623 
1624  if (sx < -hv.x) {
1625  sx = -hv.x;
1626  sub = 0;
1627  }
1628  if (sx > (int)(MapMaxX() * TILE_SIZE) - hv.x) {
1629  sx = MapMaxX() * TILE_SIZE - hv.x;
1630  sub = 0;
1631  }
1632  if (sy < -hv.y) {
1633  sy = -hv.y;
1634  sub = 0;
1635  }
1636  if (sy > (int)(MapMaxY() * TILE_SIZE) - hv.y) {
1637  sy = MapMaxY() * TILE_SIZE - hv.y;
1638  sub = 0;
1639  }
1640 
1641  this->scroll_x = sx;
1642  this->scroll_y = sy;
1643  this->subscroll = sub;
1644  if (this->map_type == SMT_LINKSTATS) this->overlay->SetDirty();
1645 }
1646 
1647 /* virtual */ void SmallMapWindow::OnScroll(Point delta)
1648 {
1650 
1651  /* While tile is at (delta.x, delta.y)? */
1652  int sub;
1653  Point pt = this->PixelToTile(delta.x, delta.y, &sub);
1654  this->SetNewScroll(this->scroll_x + pt.x * TILE_SIZE, this->scroll_y + pt.y * TILE_SIZE, sub);
1655 
1656  this->SetDirty();
1657 }
1658 
1663 {
1665  Point viewport_center = InverseRemapCoords2(vp->virtual_left + vp->virtual_width / 2, vp->virtual_top + vp->virtual_height / 2);
1666 
1667  int sub;
1668  const NWidgetBase *wid = this->GetWidget<NWidgetBase>(WID_SM_MAP);
1669  Point sxy = this->ComputeScroll(viewport_center.x / (int)TILE_SIZE, viewport_center.y / (int)TILE_SIZE,
1670  std::max(0, (int)wid->current_x / 2 - 2), wid->current_y / 2, &sub);
1671  this->SetNewScroll(sxy.x, sxy.y, sub);
1672  this->SetDirty();
1673 }
1674 
1681 {
1682  int x = (st->rect.right + st->rect.left + 1) / 2;
1683  int y = (st->rect.bottom + st->rect.top + 1) / 2;
1684  Point ret = this->RemapTile(x, y);
1685 
1686  /* Same magic 3 as in DrawVehicles; that's where I got it from.
1687  * No idea what it is, but without it the result looks bad.
1688  */
1689  ret.x -= 3 + this->subscroll;
1690  return ret;
1691 }
1692 
1694 bool SmallMapWindow::show_towns = true;
1696 
1707 public:
1709  {
1710  this->smallmap_window = nullptr;
1711  }
1712 
1713  void SetupSmallestSize(Window *w, bool init_array) override
1714  {
1715  NWidgetBase *display = this->head;
1716  NWidgetBase *bar = display->next;
1717 
1718  display->SetupSmallestSize(w, init_array);
1719  bar->SetupSmallestSize(w, init_array);
1720 
1721  this->smallmap_window = dynamic_cast<SmallMapWindow *>(w);
1722  assert(this->smallmap_window != nullptr);
1723  this->smallest_x = std::max(display->smallest_x, bar->smallest_x + smallmap_window->GetMinLegendWidth());
1725  this->fill_x = std::max(display->fill_x, bar->fill_x);
1726  this->fill_y = (display->fill_y == 0 && bar->fill_y == 0) ? 0 : std::min(display->fill_y, bar->fill_y);
1727  this->resize_x = std::max(display->resize_x, bar->resize_x);
1728  this->resize_y = std::min(display->resize_y, bar->resize_y);
1729  }
1730 
1731  void AssignSizePosition(SizingType sizing, uint x, uint y, uint given_width, uint given_height, bool rtl) override
1732  {
1733  this->pos_x = x;
1734  this->pos_y = y;
1735  this->current_x = given_width;
1736  this->current_y = given_height;
1737 
1738  NWidgetBase *display = this->head;
1739  NWidgetBase *bar = display->next;
1740 
1741  if (sizing == ST_SMALLEST) {
1742  this->smallest_x = given_width;
1743  this->smallest_y = given_height;
1744  /* Make display and bar exactly equal to their minimal size. */
1745  display->AssignSizePosition(ST_SMALLEST, x, y, display->smallest_x, display->smallest_y, rtl);
1746  bar->AssignSizePosition(ST_SMALLEST, x, y + display->smallest_y, bar->smallest_x, bar->smallest_y, rtl);
1747  }
1748 
1749  uint bar_height = std::max(bar->smallest_y, this->smallmap_window->GetLegendHeight(this->smallmap_window->GetNumberColumnsLegend(given_width - bar->smallest_x)));
1750  uint display_height = given_height - bar_height;
1751  display->AssignSizePosition(ST_RESIZE, x, y, given_width, display_height, rtl);
1752  bar->AssignSizePosition(ST_RESIZE, x, y + display_height, given_width, bar_height, rtl);
1753  }
1754 
1755  NWidgetCore *GetWidgetFromPos(int x, int y) override
1756  {
1757  if (!IsInsideBS(x, this->pos_x, this->current_x) || !IsInsideBS(y, this->pos_y, this->current_y)) return nullptr;
1758  for (NWidgetBase *child_wid = this->head; child_wid != nullptr; child_wid = child_wid->next) {
1759  NWidgetCore *widget = child_wid->GetWidgetFromPos(x, y);
1760  if (widget != nullptr) return widget;
1761  }
1762  return nullptr;
1763  }
1764 
1765  void Draw(const Window *w) override
1766  {
1767  for (NWidgetBase *child_wid = this->head; child_wid != nullptr; child_wid = child_wid->next) child_wid->Draw(w);
1768  }
1769 };
1770 
1773  NWidget(WWT_PANEL, COLOUR_BROWN, WID_SM_MAP_BORDER),
1774  NWidget(WWT_INSET, COLOUR_BROWN, WID_SM_MAP), SetMinimalSize(346, 140), SetResize(1, 1), SetPadding(2, 2, 2, 2), EndContainer(),
1775  EndContainer(),
1776 };
1777 
1780  NWidget(WWT_PANEL, COLOUR_BROWN),
1782  NWidget(WWT_EMPTY, INVALID_COLOUR, WID_SM_LEGEND), SetResize(1, 1),
1784  /* Top button row. */
1786  NWidget(WWT_PUSHIMGBTN, COLOUR_BROWN, WID_SM_ZOOM_IN),
1787  SetDataTip(SPR_IMG_ZOOMIN, STR_TOOLBAR_TOOLTIP_ZOOM_THE_VIEW_IN), SetFill(1, 1),
1788  NWidget(WWT_PUSHIMGBTN, COLOUR_BROWN, WID_SM_CENTERMAP),
1789  SetDataTip(SPR_IMG_SMALLMAP, STR_SMALLMAP_CENTER), SetFill(1, 1),
1790  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_BLANK),
1791  SetDataTip(SPR_DOT_SMALL, STR_NULL), SetFill(1, 1),
1792  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_CONTOUR),
1793  SetDataTip(SPR_IMG_SHOW_COUNTOURS, STR_SMALLMAP_TOOLTIP_SHOW_LAND_CONTOURS_ON_MAP), SetFill(1, 1),
1794  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_VEHICLES),
1795  SetDataTip(SPR_IMG_SHOW_VEHICLES, STR_SMALLMAP_TOOLTIP_SHOW_VEHICLES_ON_MAP), SetFill(1, 1),
1796  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_INDUSTRIES),
1797  SetDataTip(SPR_IMG_INDUSTRY, STR_SMALLMAP_TOOLTIP_SHOW_INDUSTRIES_ON_MAP), SetFill(1, 1),
1798  EndContainer(),
1799  /* Bottom button row. */
1801  NWidget(WWT_PUSHIMGBTN, COLOUR_BROWN, WID_SM_ZOOM_OUT),
1802  SetDataTip(SPR_IMG_ZOOMOUT, STR_TOOLBAR_TOOLTIP_ZOOM_THE_VIEW_OUT), SetFill(1, 1),
1803  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_TOGGLETOWNNAME),
1804  SetDataTip(SPR_IMG_TOWN, STR_SMALLMAP_TOOLTIP_TOGGLE_TOWN_NAMES_ON_OFF), SetFill(1, 1),
1805  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_LINKSTATS),
1806  SetDataTip(SPR_IMG_CARGOFLOW, STR_SMALLMAP_TOOLTIP_SHOW_LINK_STATS_ON_MAP), SetFill(1, 1),
1807  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_ROUTES),
1808  SetDataTip(SPR_IMG_SHOW_ROUTES, STR_SMALLMAP_TOOLTIP_SHOW_TRANSPORT_ROUTES_ON), SetFill(1, 1),
1809  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_VEGETATION),
1810  SetDataTip(SPR_IMG_PLANTTREES, STR_SMALLMAP_TOOLTIP_SHOW_VEGETATION_ON_MAP), SetFill(1, 1),
1811  NWidget(WWT_IMGBTN, COLOUR_BROWN, WID_SM_OWNERS),
1812  SetDataTip(SPR_IMG_COMPANY_GENERAL, STR_SMALLMAP_TOOLTIP_SHOW_LAND_OWNERS_ON_MAP), SetFill(1, 1),
1813  EndContainer(),
1814  NWidget(NWID_SPACER), SetResize(0, 1),
1815  EndContainer(),
1816  EndContainer(),
1817  EndContainer(),
1818 };
1819 
1820 static NWidgetBase *SmallMapDisplay(int *biggest_index)
1821 {
1822  NWidgetContainer *map_display = new NWidgetSmallmapDisplay;
1823 
1825  MakeNWidgets(_nested_smallmap_bar, lengthof(_nested_smallmap_bar), biggest_index, map_display);
1826  return map_display;
1827 }
1828 
1829 
1830 static const NWidgetPart _nested_smallmap_widgets[] = {
1832  NWidget(WWT_CLOSEBOX, COLOUR_BROWN),
1833  NWidget(WWT_CAPTION, COLOUR_BROWN, WID_SM_CAPTION), SetDataTip(STR_SMALLMAP_CAPTION, STR_TOOLTIP_WINDOW_TITLE_DRAG_THIS),
1834  NWidget(WWT_SHADEBOX, COLOUR_BROWN),
1835  NWidget(WWT_DEFSIZEBOX, COLOUR_BROWN),
1836  NWidget(WWT_STICKYBOX, COLOUR_BROWN),
1837  EndContainer(),
1838  NWidgetFunction(SmallMapDisplay), // Smallmap display and legend bar + image buttons.
1839  /* Bottom button row and resize box. */
1841  NWidget(NWID_SELECTION, INVALID_COLOUR, WID_SM_SELECT_BUTTONS),
1843  NWidget(WWT_PUSHTXTBTN, COLOUR_BROWN, WID_SM_ENABLE_ALL), SetDataTip(STR_SMALLMAP_ENABLE_ALL, STR_NULL),
1844  NWidget(WWT_PUSHTXTBTN, COLOUR_BROWN, WID_SM_DISABLE_ALL), SetDataTip(STR_SMALLMAP_DISABLE_ALL, STR_NULL),
1845  NWidget(WWT_TEXTBTN, COLOUR_BROWN, WID_SM_SHOW_HEIGHT), SetDataTip(STR_SMALLMAP_SHOW_HEIGHT, STR_SMALLMAP_TOOLTIP_SHOW_HEIGHT),
1846  NWidget(WWT_PANEL, COLOUR_BROWN), SetFill(1, 0), SetResize(1, 0),
1847  EndContainer(),
1848  EndContainer(),
1849  NWidget(WWT_PANEL, COLOUR_BROWN), SetFill(1, 0), SetResize(1, 0),
1850  EndContainer(),
1851  EndContainer(),
1852  NWidget(WWT_RESIZEBOX, COLOUR_BROWN),
1853  EndContainer(),
1854 };
1855 
1856 static WindowDesc _smallmap_desc(
1857  WDP_AUTO, "smallmap", 484, 314,
1859  0,
1860  _nested_smallmap_widgets, lengthof(_nested_smallmap_widgets)
1861 );
1862 
1867 {
1868  AllocateWindowDescFront<SmallMapWindow>(&_smallmap_desc, 0);
1869 }
1870 
1879 bool ScrollMainWindowTo(int x, int y, int z, bool instant)
1880 {
1881  bool res = ScrollWindowTo(x, y, z, FindWindowById(WC_MAIN_WINDOW, 0), instant);
1882 
1883  /* If a user scrolls to a tile (via what way what so ever) and already is on
1884  * that tile (e.g.: pressed twice), move the smallmap to that location,
1885  * so you directly see where you are on the smallmap. */
1886 
1887  if (res) return res;
1888 
1889  SmallMapWindow *w = dynamic_cast<SmallMapWindow*>(FindWindowById(WC_SMALLMAP, 0));
1890  if (w != nullptr) w->SmallMapCenterOnCurrentPos();
1891 
1892  return res;
1893 }
_sorted_industry_types
std::array< IndustryType, NUM_INDUSTRYTYPES > _sorted_industry_types
Industry types sorted by name.
Definition: industry_gui.cpp:186
PC_WHITE
static const uint8 PC_WHITE
White palette colour.
Definition: gfx_func.h:193
MP_CLEAR
@ MP_CLEAR
A tile without any structures, i.e. grass, rocks, farm fields etc.
Definition: tile_type.h:46
MP_HOUSE
@ MP_HOUSE
A house by a town.
Definition: tile_type.h:49
BuildOwnerLegend
void BuildOwnerLegend()
Completes the array for the owned property legend.
Definition: smallmap_gui.cpp:326
LegendAndColour::type
IndustryType type
Type of industry. Only valid for industry entries.
Definition: smallmap_gui.h:34
WD_FRAMERECT_TOP
@ WD_FRAMERECT_TOP
Offset at top to draw the frame rectangular area.
Definition: window_gui.h:64
TileIndex
uint32 TileIndex
The index/ID of a Tile.
Definition: tile_type.h:83
LinkGraphOverlay::LINK_COLOURS
static const uint8 LINK_COLOURS[]
Colours for the various "load" states of links.
Definition: linkgraph_gui.h:43
RoadTypeInfo
Definition: road.h:75
sound_func.h
GetSmallMapRoutesPixels
static uint32 GetSmallMapRoutesPixels(TileIndex tile, TileType t)
Return the colour a tile would be displayed with in the small map in mode "Routes".
Definition: smallmap_gui.cpp:453
NUM_INDUSTRYTYPES
static const IndustryType NUM_INDUSTRYTYPES
total number of industry types, new and old; limited to 240 because we need some special ids like INV...
Definition: industry_type.h:26
_green_map_heights
static const uint32 _green_map_heights[]
Height map colours for the green colour scheme, ordered by height.
Definition: heightmap_colours.h:13
SmallMapWindow::min_number_of_fixed_rows
uint min_number_of_fixed_rows
Minimal number of rows in the legends for the fixed layouts only (all except #SMT_INDUSTRY).
Definition: smallmap_gui.h:72
IndustrySpec::map_colour
byte map_colour
colour used for the small map
Definition: industrytype.h:126
_smallmap_show_heightmap
static bool _smallmap_show_heightmap
Show heightmap in industry and owner mode of smallmap window.
Definition: smallmap_gui.cpp:158
NWidgetFunction
static NWidgetPart NWidgetFunction(NWidgetFunctionType *func_ptr)
Obtain a nested widget (sub)tree from an external source.
Definition: widget_type.h:1239
Blitter::SetPixel
virtual void SetPixel(void *video, int x, int y, uint8 colour)=0
Draw a pixel with a given colour on the video-buffer.
WC_INDUSTRY_CARGOES
@ WC_INDUSTRY_CARGOES
Industry cargoes chain; Window numbers:
Definition: window_type.h:502
WID_SM_ROUTES
@ WID_SM_ROUTES
Button to select the routes view.
Definition: smallmap_widget.h:26
SmallMapWindow::map_type
static SmallMapType map_type
Currently displayed legends.
Definition: smallmap_gui.h:63
ScrollWindowTo
bool ScrollWindowTo(int x, int y, int z, Window *w, bool instant)
Scrolls the viewport in a window to a given location.
Definition: viewport.cpp:2399
ScaleFontTrad
static int ScaleFontTrad(int value)
Scale traditional pixel dimensions to Font zoom level.
Definition: zoom_func.h:96
NWidgetSmallmapDisplay::Draw
void Draw(const Window *w) override
Definition: smallmap_gui.cpp:1765
WID_SM_VEGETATION
@ WID_SM_VEGETATION
Button to select the vegetation view.
Definition: smallmap_widget.h:27
endian_func.hpp
WWT_STICKYBOX
@ WWT_STICKYBOX
Sticky box (at top-right of a window, after WWT_DEFSIZEBOX)
Definition: widget_type.h:64
SetPadding
static NWidgetPart SetPadding(uint8 top, uint8 right, uint8 bottom, uint8 left)
Widget part function for setting additional space around a widget.
Definition: widget_type.h:1139
PC_YELLOW
static const uint8 PC_YELLOW
Yellow palette colour.
Definition: gfx_func.h:203
PC_DARK_RED
static const uint8 PC_DARK_RED
Dark red palette colour.
Definition: gfx_func.h:196
smallmap_gui.h
GameCreationSettings::landscape
byte landscape
the landscape we're currently in
Definition: settings_type.h:320
guitimer_func.h
SmallMapColourScheme::height_colours_base
const uint32 * height_colours_base
Base table for determining the colours.
Definition: smallmap_gui.cpp:260
_sorted_cargo_specs
std::vector< const CargoSpec * > _sorted_cargo_specs
Cargo specifications sorted alphabetically by name.
Definition: cargotype.cpp:152
MOEND
#define MOEND()
Macro used for forcing a rebuild of the owner legend the first time it is used.
Definition: smallmap_gui.cpp:54
Window::ReInit
void ReInit(int rx=0, int ry=0)
Re-initialize a window, and optionally change its size.
Definition: window.cpp:1004
company_base.h
TRANSPORT_RAIL
@ TRANSPORT_RAIL
Transport by train.
Definition: transport_type.h:27
SmallMapWindow::ZLC_ZOOM_IN
@ ZLC_ZOOM_IN
Zoom in.
Definition: smallmap_gui.h:60
tunnelbridge_map.h
SmallMapWindow::OnPaint
void OnPaint() override
The window must be repainted.
Definition: smallmap_gui.cpp:1193
Blitter
How all blitters should look like.
Definition: base.hpp:28
_smallmap_cargo_count
static int _smallmap_cargo_count
Number of cargos in the link stats legend.
Definition: smallmap_gui.cpp:37
WWT_CAPTION
@ WWT_CAPTION
Window caption (window title between closebox and stickybox)
Definition: widget_type.h:59
Station
Station data structure.
Definition: station_base.h:447
SmallMapWindow::SmallMapCenterOnCurrentPos
void SmallMapCenterOnCurrentPos()
Center the small map on the current center of the viewport.
Definition: smallmap_gui.cpp:1662
WWT_IMGBTN
@ WWT_IMGBTN
(Toggle) Button with image
Definition: widget_type.h:50
INVALID_ROADTYPE
@ INVALID_ROADTYPE
flag for invalid roadtype
Definition: road_type.h:27
Window::viewport
ViewportData * viewport
Pointer to viewport data, if present.
Definition: window_gui.h:321
PC_ORANGE
static const uint8 PC_ORANGE
Orange palette colour.
Definition: gfx_func.h:201
PC_RED
static const uint8 PC_RED
Red palette colour.
Definition: gfx_func.h:197
SmallMapWindow::DrawHorizMapIndicator
static void DrawHorizMapIndicator(int x, int x2, int y)
Draws horizontal part of map indicator.
Definition: smallmap_gui.h:105
ConstructionSettings::map_height_limit
uint8 map_height_limit
the maximum allowed heightlevel
Definition: settings_type.h:333
LegendAndColour::company
CompanyID company
Company to display. Only valid for company entries of the owner legend.
Definition: smallmap_gui.h:36
WWT_DEFSIZEBOX
@ WWT_DEFSIZEBOX
Default window size box (at top-right of a window, between WWT_SHADEBOX and WWT_STICKYBOX)
Definition: widget_type.h:63
MS
#define MS(a, b)
Macro for break marker in arrays of LegendAndColour.
Definition: smallmap_gui.cpp:63
SmallMapWindow::OnRightClick
bool OnRightClick(Point pt, int widget) override
A click with the right mouse button has been made on the window.
Definition: smallmap_gui.cpp:1570
NWID_HORIZONTAL
@ NWID_HORIZONTAL
Horizontal container.
Definition: widget_type.h:73
PC_RAINFOREST
static const uint8 PC_RAINFOREST
Pale green palette colour for rainforest.
Definition: gfx_func.h:216
TROPICZONE_RAINFOREST
@ TROPICZONE_RAINFOREST
Rainforest tile.
Definition: tile_type.h:77
FindWindowById
Window * FindWindowById(WindowClass cls, WindowNumber number)
Find a window by its class and window number.
Definition: window.cpp:1146
SmallMapWindow::GetOverlayCompanyMask
uint32 GetOverlayCompanyMask() const
Get a bitmask for company links to be displayed.
Definition: smallmap_gui.h:145
CLEAR_GRASS
@ CLEAR_GRASS
0-3
Definition: clear_map.h:20
IsClearGround
static bool IsClearGround(TileIndex t, ClearGround ct)
Set the type of clear tile.
Definition: clear_map.h:71
SmallMapWindow::SetupWidgetData
void SetupWidgetData()
Function to set up widgets depending on the information being shown on the smallmap.
Definition: smallmap_gui.cpp:1033
_ctrl_pressed
bool _ctrl_pressed
Is Ctrl pressed?
Definition: gfx.cpp:35
MP_RAILWAY
@ MP_RAILWAY
A railway.
Definition: tile_type.h:47
SND_15_BEEP
@ SND_15_BEEP
19 == 0x13 GUI button click
Definition: sound_type.h:58
vehicle_base.h
SetResize
static NWidgetPart SetResize(int16 dx, int16 dy)
Widget part function for setting the resize step.
Definition: widget_type.h:993
zoom_func.h
TILE_SIZE
static const uint TILE_SIZE
Tile size in world coordinates.
Definition: tile_type.h:13
WID_SM_LEGEND
@ WID_SM_LEGEND
Bottom panel to display smallmap legends.
Definition: smallmap_widget.h:18
SmallMapWindow::GetTileColours
uint32 GetTileColours(const TileArea &ta) const
Decide which colours to show to the user for a group of tiles.
Definition: smallmap_gui.cpp:747
_settings_client
ClientSettings _settings_client
The current settings for this game.
Definition: settings.cpp:52
WID_SM_CONTOUR
@ WID_SM_CONTOUR
Button to select the contour view (height map).
Definition: smallmap_widget.h:22
DrawString
int DrawString(int left, int right, int top, const char *str, TextColour colour, StringAlignment align, bool underline, FontSize fontsize)
Draw string, possibly truncated to make it fit in its allocated space.
Definition: gfx.cpp:642
SmallMapColourScheme::default_colour
uint32 default_colour
Default colour of the land.
Definition: smallmap_gui.cpp:262
CargoSpec
Specification of a cargo type.
Definition: cargotype.h:57
VSM_VIEWPORT_RMB_FIXED
@ VSM_VIEWPORT_RMB_FIXED
Viewport moves with mouse movement on holding right mouse button, cursor position is fixed.
Definition: settings_type.h:95
WWT_EMPTY
@ WWT_EMPTY
Empty widget, place holder to reserve space in widget array.
Definition: widget_type.h:46
MP_INDUSTRY
@ MP_INDUSTRY
Part of an industry.
Definition: tile_type.h:54
town.h
TileY
static uint TileY(TileIndex tile)
Get the Y component of a tile.
Definition: map_func.h:215
_smallmap_industry_count
static int _smallmap_industry_count
Number of used industries.
Definition: smallmap_gui.cpp:35
SmallMapWindow::zoom
int zoom
Zoom level. Bigger number means more zoom-out (further away).
Definition: smallmap_gui.h:79
MAX_TILE_HEIGHT
static const uint MAX_TILE_HEIGHT
Maximum allowed tile height.
Definition: tile_type.h:22
WID_SM_SHOW_HEIGHT
@ WID_SM_SHOW_HEIGHT
Show heightmap toggle button.
Definition: smallmap_widget.h:34
TransportType
TransportType
Available types of transport.
Definition: transport_type.h:19
clear_map.h
Vehicle
Vehicle data structure.
Definition: vehicle_base.h:221
PC_GRASS_LAND
static const uint8 PC_GRASS_LAND
Dark green palette colour for grass land.
Definition: gfx_func.h:214
Window::HandleButtonClick
void HandleButtonClick(byte widget)
Do all things to make a button look clicked and mark it to be unclicked in a few ticks.
Definition: window.cpp:646
Viewport::virtual_top
int virtual_top
Virtual top coordinate.
Definition: viewport_type.h:29
SmallMapWindow::SwitchMapType
void SwitchMapType(SmallMapType map_type)
Select a new map type.
Definition: smallmap_gui.cpp:1310
Owner
Owner
Enum for all companies/owners.
Definition: company_type.h:18
NWidgetBase::smallest_y
uint smallest_y
Smallest vertical size of the widget in a filled window.
Definition: widget_type.h:184
MakeNWidgets
NWidgetContainer * MakeNWidgets(const NWidgetPart *parts, int count, int *biggest_index, NWidgetContainer *container)
Construct a nested widget tree from an array of parts.
Definition: widget.cpp:3015
NWidgetSmallmapDisplay
Custom container class for displaying smallmap with a vertically resizing legend panel.
Definition: smallmap_gui.cpp:1705
MP_ROAD
@ MP_ROAD
A tile with road (or tram tracks)
Definition: tile_type.h:48
_colour_gradient
byte _colour_gradient[COLOUR_END][8]
All 16 colour gradients 8 colours per gradient from darkest (0) to lightest (7)
Definition: gfx.cpp:52
SmallMapWindow::column_width
uint column_width
Width of a column in the WID_SM_LEGEND widget.
Definition: smallmap_gui.h:73
SmallMapWindow::OnInit
void OnInit() override
Notification that the nested widget tree gets initialized.
Definition: smallmap_gui.cpp:1140
SetDParam
static void SetDParam(uint n, uint64 v)
Set a string parameter v at index n in the global string parameter array.
Definition: strings_func.h:196
SmallMapWindow::min_number_of_columns
uint min_number_of_columns
Minimal number of columns in legends.
Definition: smallmap_gui.h:71
_dark_green_map_heights
static const uint32 _dark_green_map_heights[]
Height map colours for the dark green colour scheme, ordered by height.
Definition: heightmap_colours.h:132
NWidgetPart
Partial widget specification to allow NWidgets to be written nested.
Definition: widget_type.h:971
SmallMapWindow::scroll_x
int32 scroll_x
Horizontal world coordinate of the base tile left of the top-left corner of the smallmap display.
Definition: smallmap_gui.h:76
SetDataTip
static NWidgetPart SetDataTip(uint32 data, StringID tip)
Widget part function for setting the data and tooltip.
Definition: widget_type.h:1107
SmallMapWindow
Class managing the smallmap window.
Definition: smallmap_gui.h:43
SmallMapWindow::Close
void Close() override
Hide the window and all its child windows, and mark them for a later deletion.
Definition: smallmap_gui.cpp:1100
SmallMapWindow::show_towns
static bool show_towns
Display town names in the smallmap.
Definition: smallmap_gui.h:64
GetStringBoundingBox
Dimension GetStringBoundingBox(const char *str, FontSize start_fontsize)
Return the string dimension in pixels.
Definition: gfx.cpp:888
GetClearGround
static ClearGround GetClearGround(TileIndex t)
Get the type of clear tile.
Definition: clear_map.h:59
LinkGraphOverlay::SetCompanyMask
void SetCompanyMask(uint32 company_mask)
Set a new company mask and rebuild the cache.
Definition: linkgraph_gui.cpp:366
TileX
static uint TileX(TileIndex tile)
Get the X component of a tile.
Definition: map_func.h:205
SmallMapWindow::GetNumberColumnsLegend
uint GetNumberColumnsLegend(uint width) const
Return number of columns that can be displayed in width pixels.
Definition: smallmap_gui.h:124
SmallMapWindow::DrawSmallMap
void DrawSmallMap(DrawPixelInfo *dpi) const
Draws the small map.
Definition: smallmap_gui.cpp:969
GameSettings::game_creation
GameCreationSettings game_creation
settings used during the creation of a game (map)
Definition: settings_type.h:576
SmallMapWindow::GetStationMiddle
Point GetStationMiddle(const Station *st) const
Get the center of the given station as point on the screen in the smallmap window.
Definition: smallmap_gui.cpp:1680
IsInsideMM
static bool IsInsideMM(const T x, const size_t min, const size_t max)
Checks if a value is in an interval.
Definition: math_func.hpp:204
SmallMapWindow::SetZoomLevel
void SetZoomLevel(ZoomLevelChange change, const Point *zoom_pt)
Initialize or change the zoom level.
Definition: smallmap_gui.cpp:698
IsTileOnWater
static bool IsTileOnWater(TileIndex t)
Tests if the tile was built on water.
Definition: water_map.h:130
_smallmap_industry_highlight_state
static bool _smallmap_industry_highlight_state
State of highlight blinking.
Definition: smallmap_gui.cpp:162
WindowDesc
High level window description.
Definition: window_gui.h:168
SmallMapWindow::ComputeScroll
Point ComputeScroll(int tx, int ty, int x, int y, int *sub)
Compute base parameters of the smallmap such that tile (tx, ty) starts at pixel (x,...
Definition: smallmap_gui.cpp:670
Pool::MAX_SIZE
static constexpr size_t MAX_SIZE
Make template parameter accessible from outside.
Definition: pool_type.hpp:85
TRANSPORT_ROAD
@ TRANSPORT_ROAD
Transport by road vehicle.
Definition: transport_type.h:28
GetRailTypeInfo
static const RailtypeInfo * GetRailTypeInfo(RailType railtype)
Returns a pointer to the Railtype information for a given railtype.
Definition: rail.h:304
NC_EQUALSIZE
@ NC_EQUALSIZE
Value of the NCB_EQUALSIZE flag.
Definition: widget_type.h:463
SmallMapWindow::GetMinLegendWidth
uint GetMinLegendWidth() const
Compute minimal required width of the legends.
Definition: smallmap_gui.h:115
GUISettings::scrollwheel_scrolling
uint8 scrollwheel_scrolling
scrolling using the scroll wheel?
Definition: settings_type.h:141
WID_SM_SELECT_BUTTONS
@ WID_SM_SELECT_BUTTONS
Selection widget for the buttons present in some smallmap modes.
Definition: smallmap_widget.h:31
LinkGraphOverlay
Handles drawing of links into some window.
Definition: linkgraph_gui.h:37
VS_HIDDEN
@ VS_HIDDEN
Vehicle is not visible.
Definition: vehicle_base.h:31
CargoSpec::Index
CargoID Index() const
Determines index of this cargospec.
Definition: cargotype.h:90
Viewport
Data structure for viewport, display of a part of the world.
Definition: viewport_type.h:22
GUITimer
Definition: guitimer_func.h:13
_nested_smallmap_bar
static const NWidgetPart _nested_smallmap_bar[]
Widget parts of the smallmap legend bar + image buttons.
Definition: smallmap_gui.cpp:1779
WDP_AUTO
@ WDP_AUTO
Find a place automatically.
Definition: window_gui.h:156
SmallMapWindow::ZoomLevelChange
ZoomLevelChange
Available kinds of zoomlevel changes.
Definition: smallmap_gui.h:57
GetClearDensity
static uint GetClearDensity(TileIndex t)
Get the density of a non-field clear tile.
Definition: clear_map.h:83
SmallMapWindow::OnInvalidateData
void OnInvalidateData(int data=0, bool gui_scope=true) override
Some data on this window has become invalid.
Definition: smallmap_gui.cpp:1541
SmallMapWindow::OnClick
void OnClick(Point pt, int widget, int click_count) override
A click with the left mouse button has been made on the window.
Definition: smallmap_gui.cpp:1425
SmallMapWindow::GetNumberRowsLegend
uint GetNumberRowsLegend(uint columns) const
Get the number of rows in the legend from the number of columns.
Definition: smallmap_gui.cpp:1331
InverseRemapCoords
static Point InverseRemapCoords(int x, int y)
Map 2D viewport or smallmap coordinate to 3D world or tile coordinate.
Definition: landscape.h:112
SmallMapWindow::ZLC_ZOOM_OUT
@ ZLC_ZOOM_OUT
Zoom out.
Definition: smallmap_gui.h:59
ST_SMALLEST
@ ST_SMALLEST
Initialize nested widget tree to smallest size. Also updates current_x and current_y.
Definition: widget_type.h:112
SmallMapWindow::DrawVehicles
void DrawVehicles(const DrawPixelInfo *dpi, Blitter *blitter) const
Adds vehicles to the smallmap.
Definition: smallmap_gui.cpp:876
TileHeight
static uint TileHeight(TileIndex tile)
Returns the height of a tile.
Definition: tile_map.h:29
ClientSettings::sound
SoundSettings sound
sound effect settings
Definition: settings_type.h:596
WID_SM_LINKSTATS
@ WID_SM_LINKSTATS
Button to select the link stats view.
Definition: smallmap_widget.h:25
Window::InitNested
void InitNested(WindowNumber number=0)
Perform complete initialization of the Window with nested widgets, to allow use.
Definition: window.cpp:1789
Industry::GetByTile
static Industry * GetByTile(TileIndex tile)
Get the industry of the given tile.
Definition: industry.h:144
_vehicle_type_colours
static const byte _vehicle_type_colours[6]
Vehicle colours in #SMT_VEHICLES mode.
Definition: smallmap_gui.cpp:589
LinkGraphOverlay::SetCargoMask
void SetCargoMask(CargoTypes cargo_mask)
Set a new cargo mask and rebuild the cache.
Definition: linkgraph_gui.cpp:355
SmallMapWindow::DrawVertMapIndicator
static void DrawVertMapIndicator(int x, int y, int y2)
Draws vertical part of map indicator.
Definition: smallmap_gui.h:93
Viewport::virtual_left
int virtual_left
Virtual left coordinate.
Definition: viewport_type.h:28
Industry::type
IndustryType type
type of industry.
Definition: industry.h:83
Window::height
int height
Height of the window (number of pixels down in y direction)
Definition: window_gui.h:315
BaseStation::rect
StationRect rect
NOSAVE: Station spread out rectangle maintained by StationRect::xxx() functions.
Definition: base_station_base.h:76
LegendAndColour::col_break
bool col_break
Perform a column break and go further at the next column.
Definition: smallmap_gui.h:39
WID_SM_ZOOM_IN
@ WID_SM_ZOOM_IN
Button to zoom in one step.
Definition: smallmap_widget.h:20
WID_SM_VEHICLES
@ WID_SM_VEHICLES
Button to select the vehicles view.
Definition: smallmap_widget.h:23
Window::SetDirty
void SetDirty() const
Mark entire window as dirty (in need of re-paint)
Definition: window.cpp:993
NWidgetBase::smallest_x
uint smallest_x
Smallest horizontal size of the widget in a filled window.
Definition: widget_type.h:183
WD_FRAMERECT_LEFT
@ WD_FRAMERECT_LEFT
Offset at left to draw the frame rectangular area.
Definition: window_gui.h:62
_legend_land_contours
static LegendAndColour _legend_land_contours[]
Legend text giving the colours to look for on the minimap.
Definition: smallmap_gui.cpp:66
SmallMapWindow::DrawMapIndicators
void DrawMapIndicators() const
Adds map indicators to the smallmap.
Definition: smallmap_gui.cpp:937
heightmap_colours.h
NWidgetBase::AssignSizePosition
virtual void AssignSizePosition(SizingType sizing, uint x, uint y, uint given_width, uint given_height, bool rtl)=0
WID_SM_DISABLE_ALL
@ WID_SM_DISABLE_ALL
Button to disable display of all legend entries.
Definition: smallmap_widget.h:33
IsInsideBS
static 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.
Definition: math_func.hpp:188
MP_WATER
@ MP_WATER
Water tile.
Definition: tile_type.h:52
_smallmap_contours_andor
static const AndOr _smallmap_contours_andor[]
Colour masks for "Contour" and "Routes" modes.
Definition: smallmap_gui.cpp:360
SmallMapColourScheme
Colour scheme of the smallmap.
Definition: smallmap_gui.cpp:258
WD_FRAMERECT_RIGHT
@ WD_FRAMERECT_RIGHT
Offset at right to draw the frame rectangular area.
Definition: window_gui.h:63
GetStationType
static StationType GetStationType(TileIndex t)
Get the station type of this tile.
Definition: station_map.h:44
WWT_PUSHTXTBTN
@ WWT_PUSHTXTBTN
Normal push-button (no toggle button) with text caption.
Definition: widget_type.h:104
NWidgetBase
Baseclass for nested widgets.
Definition: widget_type.h:126
_smallmap_company_count
static int _smallmap_company_count
Number of entries in the owner legend.
Definition: smallmap_gui.cpp:36
_tiletype_importance
static const byte _tiletype_importance[]
Mapping of tile type to importance of the tile (higher number means more interesting to show).
Definition: smallmap_gui.cpp:392
_legend_from_industries
static LegendAndColour _legend_from_industries[NUM_INDUSTRYTYPES+1]
Allow room for all industries, plus a terminator entry This is required in order to have the industry...
Definition: smallmap_gui.cpp:154
_smallmap_industry_highlight
static IndustryType _smallmap_industry_highlight
Highlight a specific industry type.
Definition: smallmap_gui.cpp:160
OrthogonalTileArea
Represents the covered area of e.g.
Definition: tilearea_type.h:18
VEH_EFFECT
@ VEH_EFFECT
Effect vehicle type (smoke, explosions, sparks, bubbles)
Definition: vehicle_type.h:31
MC
#define MC(col_break)
Macro for a height legend entry with configurable colour.
Definition: smallmap_gui.cpp:48
_settings_game
GameSettings _settings_game
Game settings of a running game or the scenario editor.
Definition: settings.cpp:53
BlitterFactory::GetCurrentBlitter
static Blitter * GetCurrentBlitter()
Get the current active blitter (always set by calling SelectBlitter).
Definition: factory.hpp:141
GetTropicZone
static TropicZone GetTropicZone(TileIndex tile)
Get the tropic zone.
Definition: tile_map.h:238
SmallMapWindow::GetPositionOnLegend
int GetPositionOnLegend(Point pt)
Determines the mouse position on the legend.
Definition: smallmap_gui.cpp:1392
LegendAndColour::legend
StringID legend
String corresponding to the coloured item.
Definition: smallmap_gui.h:33
WID_SM_BLANK
@ WID_SM_BLANK
Empty button as placeholder.
Definition: smallmap_widget.h:19
Window::SetWidgetDisabledState
void SetWidgetDisabledState(byte widget_index, bool disab_stat)
Sets the enabled/disabled status of a widget.
Definition: window_gui.h:386
MAX_COMPANIES
@ MAX_COMPANIES
Maximum number of companies.
Definition: company_type.h:23
industry.h
safeguards.h
Window::left
int left
x position of left edge of the window
Definition: window_gui.h:312
ConstructionSettings::freeform_edges
bool freeform_edges
allow terraforming the tiles at the map edges
Definition: settings_type.h:345
CursorVars::fix_at
bool fix_at
mouse is moving, but cursor is not (used for scrolling)
Definition: gfx_type.h:120
_industry_to_list_pos
static uint _industry_to_list_pos[NUM_INDUSTRYTYPES]
For connecting industry type to position in industries list(small map legend)
Definition: smallmap_gui.cpp:156
_displayed_industries
std::bitset< NUM_INDUSTRYTYPES > _displayed_industries
Communication from the industry chain window to the smallmap window about what industries to display.
Definition: industry_gui.cpp:50
_smallmap_vehicles_andor
static const AndOr _smallmap_vehicles_andor[]
Colour masks for "Vehicles", "Industry", and "Vegetation" modes.
Definition: smallmap_gui.cpp:376
MP_TUNNELBRIDGE
@ MP_TUNNELBRIDGE
Tunnel entry/exit and bridge heads.
Definition: tile_type.h:55
_heightmap_schemes
static SmallMapColourScheme _heightmap_schemes[]
Available colour schemes for height maps.
Definition: smallmap_gui.cpp:266
VSM_MAP_RMB_FIXED
@ VSM_MAP_RMB_FIXED
Map moves with mouse movement on holding right mouse button, cursor position is fixed.
Definition: settings_type.h:96
Viewport::virtual_width
int virtual_width
width << zoom
Definition: viewport_type.h:30
Point
Coordinates of a point in 2D.
Definition: geometry_type.hpp:21
ScrollMainWindowTo
bool ScrollMainWindowTo(int x, int y, int z, bool instant)
Scrolls the main window to given coordinates.
Definition: smallmap_gui.cpp:1879
GetSmallMapIndustriesPixels
static uint32 GetSmallMapIndustriesPixels(TileIndex tile, TileType t)
Return the colour a tile would be displayed with in the small map in mode "Industries".
Definition: smallmap_gui.cpp:440
SmallMapWindow::legend_width
uint legend_width
Width of legend 'blob'.
Definition: smallmap_gui.h:74
SmallMapWindow::SmallMapType
SmallMapType
Types of legends in the WID_SM_LEGEND widget.
Definition: smallmap_gui.h:46
NWidgetContainer::head
NWidgetBase * head
Pointer to first widget in container.
Definition: widget_type.h:415
stdafx.h
PC_BLACK
static const uint8 PC_BLACK
Black palette colour.
Definition: gfx_func.h:190
GfxFillRect
void GfxFillRect(int left, int top, int right, int bottom, int colour, FillRectMode mode)
Applies a certain FillRectMode-operation to a rectangle [left, right] x [top, bottom] on the screen.
Definition: gfx.cpp:116
landscape.h
IndustrySpec
Defines the data structure for constructing industry.
Definition: industrytype.h:107
Window::InvalidateData
void InvalidateData(int data=0, bool gui_scope=true)
Mark this window's data as invalid (in need of re-computing)
Definition: window.cpp:3158
SmallMapWindow::DrawSmallMapColumn
void DrawSmallMapColumn(void *dst, uint xc, uint yc, int pitch, int reps, int start_pos, int end_pos, Blitter *blitter) const
Draws one column of tiles of the small map in a certain mode onto the screen buffer,...
Definition: smallmap_gui.cpp:836
viewport_func.h
Window::mouse_capture_widget
int mouse_capture_widget
Widgetindex of current mouse capture widget (e.g. dragged scrollbar). -1 if no widget has mouse captu...
Definition: window_gui.h:330
NWidgetBase::current_y
uint current_y
Current vertical size (after resizing).
Definition: widget_type.h:187
SmallMapWindow::DrawWidget
void DrawWidget(const Rect &r, int widget) const override
Draw the contents of a nested widget.
Definition: smallmap_gui.cpp:1209
PC_TREES
static const uint8 PC_TREES
Green palette colour for trees.
Definition: gfx_func.h:218
WC_NONE
@ WC_NONE
No window, redirects to WC_MAIN_WINDOW.
Definition: window_type.h:37
GetSmallMapOwnerPixels
static uint32 GetSmallMapOwnerPixels(TileIndex tile, TileType t)
Return the colour a tile would be displayed with in the small map in mode "Owner".
Definition: smallmap_gui.cpp:563
InverseRemapCoords2
Point InverseRemapCoords2(int x, int y, bool clamp_to_map, bool *clamped)
Map 2D viewport or smallmap coordinate to 3D world or tile coordinate.
Definition: landscape.cpp:104
PC_GREY
static const uint8 PC_GREY
Grey palette colour.
Definition: gfx_func.h:192
SmallMapWindow::BreakIndustryChainLink
static void BreakIndustryChainLink()
Notify the industry chain window to stop sending newly selected industries.
Definition: smallmap_gui.cpp:595
NWidgetBase::next
NWidgetBase * next
Pointer to next widget in container. Managed by parent container widget.
Definition: widget_type.h:192
NWID_VERTICAL
@ NWID_VERTICAL
Vertical container.
Definition: widget_type.h:75
GetTileOwner
static Owner GetTileOwner(TileIndex tile)
Returns the owner of a tile.
Definition: tile_map.h:178
FillDrawPixelInfo
bool FillDrawPixelInfo(DrawPixelInfo *n, int left, int top, int width, int height)
Set up a clipping area for only drawing into a certain area.
Definition: gfx.cpp:1708
FONT_HEIGHT_SMALL
#define FONT_HEIGHT_SMALL
Height of characters in the small (FS_SMALL) font.
Definition: gfx_func.h:162
SmallMapWindow::OnRealtimeTick
void OnRealtimeTick(uint delta_ms) override
Called periodically.
Definition: smallmap_gui.cpp:1591
PC_FIELDS
static const uint8 PC_FIELDS
Light brown palette colour for fields.
Definition: gfx_func.h:217
BuildIndustriesLegend
void BuildIndustriesLegend()
Fills an array for the industries legends.
Definition: smallmap_gui.cpp:169
IsTileForestIndustry
bool IsTileForestIndustry(TileIndex tile)
Check whether the tile is a forest.
Definition: industry_cmd.cpp:962
MP_TREES
@ MP_TREES
Tile got trees.
Definition: tile_type.h:50
WWT_CLOSEBOX
@ WWT_CLOSEBOX
Close box (at top-left of a window)
Definition: widget_type.h:67
WWT_RESIZEBOX
@ WWT_RESIZEBOX
Resize box (normally at bottom-right of a window)
Definition: widget_type.h:66
MK
#define MK(a, b)
Macro for ordinary entry of LegendAndColour.
Definition: smallmap_gui.cpp:45
PC_VERY_DARK_BROWN
static const uint8 PC_VERY_DARK_BROWN
Almost-black brown palette colour.
Definition: gfx_func.h:199
WID_SM_ZOOM_OUT
@ WID_SM_ZOOM_OUT
Button to zoom out one step.
Definition: smallmap_widget.h:21
IndustrySpec::enabled
bool enabled
entity still available (by default true).newgrf can disable it, though
Definition: industrytype.h:140
MKEND
#define MKEND()
Macro for end of list marker in arrays of LegendAndColour.
Definition: smallmap_gui.cpp:57
StringID
uint32 StringID
Numeric value that represents a string, independent of the selected language.
Definition: strings_type.h:16
WWT_PUSHIMGBTN
@ WWT_PUSHIMGBTN
Normal push-button (no toggle button) with image caption.
Definition: widget_type.h:105
NWidgetBase::fill_y
uint fill_y
Vertical fill stepsize (from initial size, 0 means not resizable).
Definition: widget_type.h:177
SmallMapWindow::SetStringParameters
void SetStringParameters(int widget) const override
Initialize string parameters for a widget.
Definition: smallmap_gui.cpp:1131
WID_SM_OWNERS
@ WID_SM_OWNERS
Button to select the owners view.
Definition: smallmap_widget.h:28
SmallMapWindow::subscroll
int32 subscroll
Number of pixels (0..3) between the right end of the base tile and the pixel at the top-left corner o...
Definition: smallmap_gui.h:78
SmallMapWindow::OnScroll
void OnScroll(Point delta) override
Handle the request for (viewport) scrolling.
Definition: smallmap_gui.cpp:1647
EndContainer
static NWidgetPart EndContainer()
Widget part function for denoting the end of a container (horizontal, vertical, WWT_FRAME,...
Definition: widget_type.h:1092
Clamp
static T Clamp(const T a, const T min, const T max)
Clamp a value between an interval.
Definition: math_func.hpp:77
Pool::PoolItem<&_company_pool >::Iterate
static Pool::IterateWrapper< Titem > Iterate(size_t from=0)
Returns an iterable ensemble of all valid Titem.
Definition: pool_type.hpp:386
Industry::GetIndustryTypeCount
static uint16 GetIndustryTypeCount(IndustryType type)
Get the count of industries for this type.
Definition: industry.h:179
NWidgetSmallmapDisplay::AssignSizePosition
void AssignSizePosition(SizingType sizing, uint x, uint y, uint given_width, uint given_height, bool rtl) override
Definition: smallmap_gui.cpp:1731
MapMaxY
static uint MapMaxY()
Gets the maximum Y coordinate within the map, including MP_VOID.
Definition: map_func.h:111
NWidgetBase::pos_x
int pos_x
Horizontal position of top-left corner of the widget in the window.
Definition: widget_type.h:189
GetSmallMapLinkStatsPixels
static uint32 GetSmallMapLinkStatsPixels(TileIndex tile, TileType t)
Return the colour a tile would be displayed with in the small map in mode "link stats".
Definition: smallmap_gui.cpp:509
MP_VOID
@ MP_VOID
Invisible tiles at the SW and SE border.
Definition: tile_type.h:53
SmallMapWindow::OnMouseOver
void OnMouseOver(Point pt, int widget) override
The mouse is currently moving over the window or has just moved outside of the window.
Definition: smallmap_gui.cpp:1408
ST_RESIZE
@ ST_RESIZE
Resize the nested widget tree.
Definition: widget_type.h:113
Blitter::MoveTo
virtual void * MoveTo(void *video, int x, int y)=0
Move the destination pointer the requested amount x and y, keeping in mind any pitch and bpp of the r...
TileXY
static TileIndex TileXY(uint x, uint y)
Returns the TileIndex of a coordinate.
Definition: map_func.h:163
INVALID_INDUSTRYTYPE
static const IndustryType INVALID_INDUSTRYTYPE
one above amount is considered invalid
Definition: industry_type.h:27
SmallMapWindow::SetOverlayCargoMask
void SetOverlayCargoMask()
Set the link graph overlay cargo mask from the legend.
Definition: smallmap_gui.cpp:1378
SmallMapWindow::SetNewScroll
void SetNewScroll(int sx, int sy, int sub)
Set new scroll_x, scroll_y, and subscroll values after limiting them such that the center of the smal...
Definition: smallmap_gui.cpp:1617
_violet_map_heights
static const uint32 _violet_map_heights[]
Height map colours for the violet colour scheme, ordered by height.
Definition: heightmap_colours.h:235
TileType
TileType
The different types of tiles.
Definition: tile_type.h:45
SmallMapWindow::INDUSTRY_MIN_NUMBER_OF_COLUMNS
static const uint INDUSTRY_MIN_NUMBER_OF_COLUMNS
Minimal number of columns in the WID_SM_LEGEND widget for the #SMT_INDUSTRY legend.
Definition: smallmap_gui.h:67
PC_ROUGH_LAND
static const uint8 PC_ROUGH_LAND
Dark green palette colour for rough land.
Definition: gfx_func.h:213
LegendAndColour::height
uint8 height
Height in tiles. Only valid for height legend entries.
Definition: smallmap_gui.h:35
NWidget
static NWidgetPart NWidget(WidgetType tp, Colours col, int16 idx=-1)
Widget part function for starting a new 'real' widget.
Definition: widget_type.h:1207
NWidgetBase::fill_x
uint fill_x
Horizontal fill stepsize (from initial size, 0 means not resizable).
Definition: widget_type.h:176
LegendAndColour::colour
uint8 colour
Colour of the item on the map.
Definition: smallmap_gui.h:32
LinkGraphOverlay::Draw
void Draw(const DrawPixelInfo *dpi)
Draw the linkgraph overlay or some part of it, in the area given.
Definition: linkgraph_gui.cpp:237
InvalidateWindowClassesData
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:3235
SetMinimalSize
static NWidgetPart SetMinimalSize(int16 x, int16 y)
Widget part function for setting the minimal size.
Definition: widget_type.h:1010
tree_map.h
WWT_PANEL
@ WWT_PANEL
Simple depressed panel.
Definition: widget_type.h:48
OWNER_NONE
@ OWNER_NONE
The tile has no ownership.
Definition: company_type.h:25
GetRailType
static RailType GetRailType(TileIndex t)
Gets the rail type of the given tile.
Definition: rail_map.h:115
NWidgetBase::resize_y
uint resize_y
Vertical resize step (0 means not resizable).
Definition: widget_type.h:179
ShowSmallMap
void ShowSmallMap()
Show the smallmap window.
Definition: smallmap_gui.cpp:1866
MP_STATION
@ MP_STATION
A tile of a station.
Definition: tile_type.h:51
LegendAndColour::show_on_map
bool show_on_map
For filtering industries, if true, industry is shown on the map in colour.
Definition: smallmap_gui.h:37
RoadTypeInfo::map_colour
byte map_colour
Colour on mini-map.
Definition: road.h:154
NUM_CARGO
@ NUM_CARGO
Maximal number of cargo types in a game.
Definition: cargo_type.h:65
NWidgetSmallmapDisplay::SetupSmallestSize
void SetupSmallestSize(Window *w, bool init_array) override
Definition: smallmap_gui.cpp:1713
WID_SM_INDUSTRIES
@ WID_SM_INDUSTRIES
Button to select the industries view.
Definition: smallmap_widget.h:24
SmallMapWindow::DrawTowns
void DrawTowns(const DrawPixelInfo *dpi) const
Adds town names to the smallmap.
Definition: smallmap_gui.cpp:914
GetRoadTypeInfo
static const RoadTypeInfo * GetRoadTypeInfo(RoadType roadtype)
Returns a pointer to the Roadtype information for a given roadtype.
Definition: road.h:224
_company_to_list_pos
static uint _company_to_list_pos[MAX_COMPANIES]
For connecting company ID to position in owner list (small map legend)
Definition: smallmap_gui.cpp:164
CargoSpec::name
StringID name
Name of this type of cargo.
Definition: cargotype.h:72
WC_MAIN_WINDOW
@ WC_MAIN_WINDOW
Main window; Window numbers:
Definition: window_type.h:43
NWID_SPACER
@ NWID_SPACER
Invisible widget that takes some space.
Definition: widget_type.h:77
WWT_INSET
@ WWT_INSET
Pressed (inset) panel, most commonly used as combo box text area.
Definition: widget_type.h:49
MapMaxX
static uint MapMaxX()
Gets the maximum X coordinate within the map, including MP_VOID.
Definition: map_func.h:102
PC_WATER
static const uint8 PC_WATER
Dark blue palette colour for water.
Definition: gfx_func.h:219
NWidgetContainer
Baseclass for container widgets.
Definition: widget_type.h:400
Window::top
int top
y position of top edge of the window
Definition: window_gui.h:313
GetTreeGround
static TreeGround GetTreeGround(TileIndex t)
Returns the groundtype for tree tiles.
Definition: tree_map.h:88
GUITimer::Elapsed
bool Elapsed(uint delta)
Test if a timer has elapsed.
Definition: guitimer_func.h:55
TileArea
OrthogonalTileArea TileArea
Shorthand for the much more common orthogonal tile area.
Definition: tilearea_type.h:102
SmallMapWindow::RemapTile
Point RemapTile(int tile_x, int tile_y) const
Remap tile to location on this smallmap.
Definition: smallmap_gui.cpp:614
GUISettings::smallmap_land_colour
uint8 smallmap_land_colour
colour used for land and heightmap at the smallmap
Definition: settings_type.h:116
VS_UNCLICKABLE
@ VS_UNCLICKABLE
Vehicle is not clickable by the user (shadow vehicles).
Definition: vehicle_base.h:33
WID_SM_TOGGLETOWNNAME
@ WID_SM_TOGGLETOWNNAME
Toggle button to display town names.
Definition: smallmap_widget.h:30
LinkGraphOverlay::SetDirty
void SetDirty()
Mark the linkgraph dirty to be rebuilt next time Draw() is called.
Definition: linkgraph_gui.h:62
station_map.h
window_func.h
_legend_linkstats
static LegendAndColour _legend_linkstats[NUM_CARGO+lengthof(_linkstat_colours_in_legenda)+1]
Legend entries for the link stats view.
Definition: smallmap_gui.cpp:149
SoundSettings::click_beep
bool click_beep
Beep on a random selection of buttons.
Definition: settings_type.h:209
SetBit
static T SetBit(T &x, const uint8 y)
Set a bit in a variable.
Definition: bitmath_func.hpp:121
Town
Town data structure.
Definition: town.h:50
lengthof
#define lengthof(x)
Return the length of an fixed size array.
Definition: stdafx.h:378
Window::width
int width
width of the window (number of pixels to the right in x direction)
Definition: window_gui.h:314
NWidgetBase::pos_y
int pos_y
Vertical position of top-left corner of the widget in the window.
Definition: widget_type.h:190
LinkGraphOverlay::GetCompanyMask
uint32 GetCompanyMask()
Get a bitmask of the currently shown companies.
Definition: linkgraph_gui.h:68
INVALID_TILE
static const TileIndex INVALID_TILE
The very nice invalid tile marker.
Definition: tile_type.h:88
WID_SM_MAP
@ WID_SM_MAP
Panel containing the smallmap.
Definition: smallmap_widget.h:17
INVALID_COMPANY
@ INVALID_COMPANY
An invalid company.
Definition: company_type.h:30
TILE_HEIGHT_STEP
static const int TILE_HEIGHT_STEP
One Z unit tile height difference is displayed as 50m.
Definition: viewport_func.h:19
SetFill
static NWidgetPart SetFill(uint fill_x, uint fill_y)
Widget part function for setting filling.
Definition: widget_type.h:1076
TREE_GROUND_SNOW_DESERT
@ TREE_GROUND_SNOW_DESERT
a desert or snow tile, depend on landscape
Definition: tree_map.h:55
AndOr
Definition: smallmap_gui.cpp:348
CeilDiv
static uint CeilDiv(uint a, uint b)
Computes ceil(a / b) for non-negative a and b.
Definition: math_func.hpp:254
GameSettings::construction
ConstructionSettings construction
construction of things in-game
Definition: settings_type.h:577
SmallMapWindow::refresh
GUITimer refresh
Refresh timer.
Definition: smallmap_gui.h:81
GetIndustrySpec
const IndustrySpec * GetIndustrySpec(IndustryType thistype)
Accessor for array _industry_specs.
Definition: industry_cmd.cpp:121
WID_SM_MAP_BORDER
@ WID_SM_MAP_BORDER
Border around the smallmap.
Definition: smallmap_widget.h:16
SmallMapWindow::scroll_y
int32 scroll_y
Vertical world coordinate of the base tile left of the top-left corner of the smallmap display.
Definition: smallmap_gui.h:77
Window
Data structure for an opened window.
Definition: window_gui.h:279
SizingType
SizingType
Different forms of sizing nested widgets, using NWidgetBase::AssignSizePosition()
Definition: widget_type.h:111
GetTileType
static TileType GetTileType(TileIndex tile)
Get the tiletype of a given tile.
Definition: tile_map.h:96
IndustrySpec::name
StringID name
Displayed name of the industry.
Definition: industrytype.h:127
Pool::PoolItem<&_company_pool >::IsValidID
static bool IsValidID(size_t index)
Tests whether given index can be used to get valid (non-nullptr) Titem.
Definition: pool_type.hpp:326
Window::RaiseWidget
void RaiseWidget(byte widget_index)
Marks a widget as raised.
Definition: window_gui.h:477
SmallMapWindow::SelectLegendItem
void SelectLegendItem(int click_pos, LegendAndColour *legend, int end_legend_item, int begin_legend_item=0)
Select and toggle a legend item.
Definition: smallmap_gui.cpp:1350
GUISettings::scroll_mode
uint8 scroll_mode
viewport scroll mode
Definition: settings_type.h:117
Window::DrawWidgets
void DrawWidgets() const
Paint all widgets of a window.
Definition: widget.cpp:636
SmallMapWindow::RebuildColourIndexIfNecessary
void RebuildColourIndexIfNecessary()
Rebuilds the colour indices used for fast access to the smallmap contour colours based on the heightl...
Definition: smallmap_gui.cpp:1109
PC_DARK_GREY
static const uint8 PC_DARK_GREY
Dark grey palette colour.
Definition: gfx_func.h:191
Viewport::virtual_height
int virtual_height
height << zoom
Definition: viewport_type.h:31
SmallMapWindow::map_height_limit
static int map_height_limit
Currently used/cached map height limit.
Definition: smallmap_gui.h:65
SmallMapWindow::ZLC_INITIALIZE
@ ZLC_INITIALIZE
Initialize zoom level.
Definition: smallmap_gui.h:58
SmallMapColourScheme::height_colours
uint32 * height_colours
Cached colours for each level in a map.
Definition: smallmap_gui.cpp:259
PC_LIGHT_BLUE
static const uint8 PC_LIGHT_BLUE
Light blue palette colour.
Definition: gfx_func.h:211
GetSmallMapVehiclesPixels
static uint32 GetSmallMapVehiclesPixels(TileIndex tile, TileType t)
Return the colour a tile would be displayed with in the small map in mode "Vehicles".
Definition: smallmap_gui.cpp:427
NWID_SELECTION
@ NWID_SELECTION
Stacked widgets, only one visible at a time (eg in a panel with tabs).
Definition: widget_type.h:78
OrthogonalTileArea::ClampToMap
void ClampToMap()
Clamp the tile area to map borders.
Definition: tilearea.cpp:142
MO
#define MO(a, b)
Macro for non-company owned property entry of LegendAndColour.
Definition: smallmap_gui.cpp:51
NWidgetCore
Base class for a 'real' widget.
Definition: widget_type.h:311
GetTunnelBridgeTransportType
static TransportType GetTunnelBridgeTransportType(TileIndex t)
Tunnel: Get the transport type of the tunnel (road or rail) Bridge: Get the transport type of the bri...
Definition: tunnelbridge_map.h:39
LegendAndColour
Structure for holding relevant data for legends in small map.
Definition: smallmap_gui.h:31
Rect
Specification of a rectangle with absolute coordinates of all edges.
Definition: geometry_type.hpp:47
CursorVars::pos
Point pos
logical mouse position
Definition: gfx_type.h:117
Window::LowerWidget
void LowerWidget(byte widget_index)
Marks a widget as lowered.
Definition: window_gui.h:468
Company
Definition: company_base.h:115
LegendAndColour::end
bool end
This is the end of the list.
Definition: smallmap_gui.h:38
NWidgetBase::resize_x
uint resize_x
Horizontal resize step (0 means not resizable).
Definition: widget_type.h:178
OWNER_WATER
@ OWNER_WATER
The tile/execution is done by "water".
Definition: company_type.h:26
NWidgetBase::current_x
uint current_x
Current horizontal size (after resizing).
Definition: widget_type.h:186
_linkstat_colours_in_legenda
static uint8 _linkstat_colours_in_legenda[]
Link stat colours shown in legenda.
Definition: smallmap_gui.cpp:40
WID_SM_CENTERMAP
@ WID_SM_CENTERMAP
Button to move smallmap center to main window center.
Definition: smallmap_widget.h:29
BuildLinkStatsLegend
void BuildLinkStatsLegend()
Populate legend table for the link stat view.
Definition: smallmap_gui.cpp:199
_scrolling_viewport
bool _scrolling_viewport
A viewport is being scrolled with the mouse.
Definition: window.cpp:90
WC_SMALLMAP
@ WC_SMALLMAP
Small map; Window numbers:
Definition: window_type.h:96
PC_GREEN
static const uint8 PC_GREEN
Green palette colour.
Definition: gfx_func.h:207
Window::SetWidgetLoweredState
void SetWidgetLoweredState(byte widget_index, bool lowered_stat)
Sets the lowered/raised status of a widget.
Definition: window_gui.h:447
SmallMapWindow::PixelToTile
Point PixelToTile(int px, int py, int *sub, bool add_sub=true) const
Determine the tile relative to the base tile of the smallmap, and the pixel position at that tile for...
Definition: smallmap_gui.cpp:638
NWidgetCore::GetWidgetFromPos
NWidgetCore * GetWidgetFromPos(int x, int y) override
Definition: widget.cpp:1000
TD_RTL
@ TD_RTL
Text is written right-to-left by default.
Definition: strings_type.h:24
_current_text_dir
TextDirection _current_text_dir
Text direction of the currently selected language.
Definition: strings.cpp:48
NUM_NO_COMPANY_ENTRIES
static const int NUM_NO_COMPANY_ENTRIES
Number of entries in the owner legend that are not companies.
Definition: smallmap_gui.cpp:42
SmallMapWindow::FORCE_REFRESH_PERIOD
static const uint FORCE_REFRESH_PERIOD
map is redrawn after that many milliseconds.
Definition: smallmap_gui.h:68
WID_SM_ENABLE_ALL
@ WID_SM_ENABLE_ALL
Button to enable display of all legend entries.
Definition: smallmap_widget.h:32
OWNER_TOWN
@ OWNER_TOWN
A town owns the tile, or a town is expanding.
Definition: company_type.h:24
SmallMapWindow::GetLegendHeight
uint GetLegendHeight(uint num_columns) const
Compute height given a number of columns.
Definition: smallmap_gui.h:134
SmallMapWindow::OnMouseWheel
void OnMouseWheel(int wheel) override
The mouse wheel has been turned.
Definition: smallmap_gui.cpp:1578
WWT_TEXTBTN
@ WWT_TEXTBTN
(Toggle) Button with text
Definition: widget_type.h:53
ClientSettings::gui
GUISettings gui
settings related to the GUI
Definition: settings_type.h:593
PC_BARE_LAND
static const uint8 PC_BARE_LAND
Brown palette colour for bare land.
Definition: gfx_func.h:215
BuildLandLegend
void BuildLandLegend()
(Re)build the colour tables for the legends.
Definition: smallmap_gui.cpp:275
SmallMapColourScheme::colour_count
size_t colour_count
The number of colours.
Definition: smallmap_gui.cpp:261
DrawPixelInfo
Data about how and where to blit pixels.
Definition: gfx_type.h:155
GetSmallMapVegetationPixels
static uint32 GetSmallMapVegetationPixels(TileIndex tile, TileType t)
Return the colour a tile would be displayed with in the smallmap in mode "Vegetation".
Definition: smallmap_gui.cpp:532
NWidgetSmallmapDisplay::smallmap_window
const SmallMapWindow * smallmap_window
Window manager instance.
Definition: smallmap_gui.cpp:1706
_nested_smallmap_display
static const NWidgetPart _nested_smallmap_display[]
Widget parts of the smallmap display.
Definition: smallmap_gui.cpp:1772
WID_SM_CAPTION
@ WID_SM_CAPTION
Caption of the window.
Definition: smallmap_widget.h:15
SmallMapWindow::BLINK_PERIOD
static const uint BLINK_PERIOD
highlight blinking interval in milliseconds.
Definition: smallmap_gui.h:69
GetSmallMapContoursPixels
static uint32 GetSmallMapContoursPixels(TileIndex tile, TileType t)
Return the colour a tile would be displayed with in the small map in mode "Contour".
Definition: smallmap_gui.cpp:414
NWidgetSmallmapDisplay::GetWidgetFromPos
NWidgetCore * GetWidgetFromPos(int x, int y) override
Definition: smallmap_gui.cpp:1755
NWidgetBase::SetupSmallestSize
virtual void SetupSmallestSize(Window *w, bool init_array)=0
WWT_SHADEBOX
@ WWT_SHADEBOX
Shade box (at top-right of a window, between WWT_DEBUGBOX and WWT_DEFSIZEBOX)
Definition: widget_type.h:62
Window::Close
virtual void Close()
Hide the window and all its child windows, and mark them for a later deletion.
Definition: window.cpp:1092
TREE_GROUND_ROUGH_SNOW
@ TREE_GROUND_ROUGH_SNOW
A snow tile that is rough underneath.
Definition: tree_map.h:57