author | tron |
Sun, 26 Mar 2006 19:20:15 +0000 | |
changeset 3338 | 2c60ed0dcce3 |
parent 3326 | b5ce3e805425 |
child 3391 | c3747f4b259b |
permissions | -rw-r--r-- |
2186 | 1 |
/* $Id$ */ |
2 |
||
0 | 3 |
#include "stdafx.h" |
1891
92a3b0aa0946
(svn r2397) - CodeChange: rename all "ttd" files to "openttd" files.
Darkvater
parents:
1815
diff
changeset
|
4 |
#include "openttd.h" |
3234
986c30171e92
(svn r3907) Replace many bridge related direct map accesses with calls to shiny new functions and mark some strange constructs with XXX
tron
parents:
3184
diff
changeset
|
5 |
#include "bridge_map.h" |
3144
426b825578f9
(svn r3763) Adapt to the new 'map accessors go in foo_map.h'-scheme
tron
parents:
2989
diff
changeset
|
6 |
#include "clear_map.h" |
2163
637ec3c361f5
(svn r2673) Include functions.h directly, not globally via openttd.h
tron
parents:
2159
diff
changeset
|
7 |
#include "functions.h" |
1349
07514c2cc6d1
(svn r1853) Move spritecache function declarations into a header of their own and use SpriteID as parameter type where appropriate
tron
parents:
1214
diff
changeset
|
8 |
#include "spritecache.h" |
3338
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
9 |
#include "station_map.h" |
507
8aa8100b0b22
(svn r815) Include strings.h only in the files which need it.
tron
parents:
500
diff
changeset
|
10 |
#include "table/strings.h" |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
11 |
#include "table/sprites.h" |
679
e959706a3e4d
(svn r1117) Move map arrays and some related macros into their own files map.c and map.h
tron
parents:
541
diff
changeset
|
12 |
#include "map.h" |
1209
a1ac96655b79
(svn r1713) Split off several functions which query/set information about a single tile from map.h and put them into a seperate file tile.h
tron
parents:
1093
diff
changeset
|
13 |
#include "tile.h" |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
14 |
#include "gui.h" |
3144
426b825578f9
(svn r3763) Adapt to the new 'map accessors go in foo_map.h'-scheme
tron
parents:
2989
diff
changeset
|
15 |
#include "tree_map.h" |
3180
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
16 |
#include "tunnel_map.h" |
0 | 17 |
#include "window.h" |
18 |
#include "gfx.h" |
|
19 |
#include "viewport.h" |
|
20 |
#include "player.h" |
|
21 |
#include "vehicle.h" |
|
22 |
#include "town.h" |
|
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
23 |
#include "sound.h" |
2159
3b634157c3b2
(svn r2669) Shuffle some more stuff around to reduce dependencies
tron
parents:
2062
diff
changeset
|
24 |
#include "variables.h" |
0 | 25 |
|
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
26 |
static const Widget _smallmap_widgets[] = { |
2725
5c632bc5be28
(svn r3270) Correct all (mis)uses of WWT_CLOSEBOX / WWT_TEXTBTN to reflect their actual use, and add "Close Window" tooltip where missing.
peter1138
parents:
2635
diff
changeset
|
27 |
{ WWT_CLOSEBOX, RESIZE_NONE, 13, 0, 10, 0, 13, STR_00C5, STR_018B_CLOSE_WINDOW}, |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
28 |
{ WWT_CAPTION, RESIZE_RIGHT, 13, 11, 433, 0, 13, STR_00B0_MAP, STR_018C_WINDOW_TITLE_DRAG_THIS}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
29 |
{ WWT_STICKYBOX, RESIZE_LR, 13, 434, 445, 0, 13, 0x0, STR_STICKY_BUTTON}, |
2907
65c92989a1f3
(svn r3462) - Fix: a one-off pixel alignment in the minimap window that "overflowed" its panel in the tropical climate (qball should be satisfied now)
Darkvater
parents:
2725
diff
changeset
|
30 |
{ WWT_PANEL, RESIZE_RB, 13, 0, 445, 14, 257, 0x0, STR_NULL}, |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
31 |
{ WWT_6, RESIZE_RB, 13, 2, 443, 16, 255, 0x0, STR_NULL}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
32 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 380, 401, 258, 279, SPR_IMG_SHOW_COUNTOURS, STR_0191_SHOW_LAND_CONTOURS_ON_MAP}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
33 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 402, 423, 258, 279, SPR_IMG_SHOW_VEHICLES, STR_0192_SHOW_VEHICLES_ON_MAP}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
34 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 424, 445, 258, 279, SPR_IMG_INDUSTRY, STR_0193_SHOW_INDUSTRIES_ON_MAP}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
35 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 380, 401, 280, 301, SPR_IMG_SHOW_ROUTES, STR_0194_SHOW_TRANSPORT_ROUTES_ON}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
36 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 402, 423, 280, 301, SPR_IMG_PLANTTREES, STR_0195_SHOW_VEGETATION_ON_MAP}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
37 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 424, 445, 280, 301, SPR_IMG_COMPANY_GENERAL, STR_0196_SHOW_LAND_OWNERS_ON_MAP}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
38 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 358, 379, 258, 279, 0x0, STR_NULL}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
39 |
{ WWT_IMGBTN, RESIZE_LRTB, 13, 358, 379, 280, 301, SPR_IMG_TOWN, STR_0197_TOGGLE_TOWN_NAMES_ON_OFF}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
40 |
{ WWT_IMGBTN, RESIZE_RTB, 13, 0, 357, 258, 301, 0x0, STR_NULL}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
41 |
{ WWT_PANEL, RESIZE_RTB, 13, 0, 433, 302, 313, 0x0, STR_NULL}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
42 |
{ WWT_RESIZEBOX, RESIZE_LRTB, 13, 434, 445, 302, 313, 0x0, STR_RESIZE_BUTTON}, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
43 |
{ WIDGETS_END}, |
0 | 44 |
}; |
45 |
||
46 |
static int _smallmap_type; |
|
47 |
static bool _smallmap_show_towns = true; |
|
48 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
49 |
#define MK(a,b) a, b |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
50 |
#define MKEND() 0xFFFF |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
51 |
#define MS(a,b) (a | 0x100), b |
0 | 52 |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
53 |
/* Legend text giving the colours to look for on the minimap */ |
0 | 54 |
static const uint16 _legend_land_contours[] = { |
55 |
MK(0x5A,STR_00F0_100M), |
|
56 |
MK(0x5C,STR_00F1_200M), |
|
57 |
MK(0x5E,STR_00F2_300M), |
|
58 |
MK(0x1F,STR_00F3_400M), |
|
59 |
MK(0x27,STR_00F4_500M), |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
60 |
|
0 | 61 |
MS(0xD7,STR_00EB_ROADS), |
62 |
MK(0x0A,STR_00EC_RAILROADS), |
|
63 |
MK(0x98,STR_00ED_STATIONS_AIRPORTS_DOCKS), |
|
64 |
MK(0xB5,STR_00EE_BUILDINGS_INDUSTRIES), |
|
65 |
MK(0x0F,STR_00EF_VEHICLES), |
|
66 |
MKEND() |
|
67 |
}; |
|
68 |
||
69 |
static const uint16 _legend_vehicles[] = { |
|
70 |
MK(0xB8,STR_00F5_TRAINS), |
|
71 |
MK(0xBF,STR_00F6_ROAD_VEHICLES), |
|
72 |
MK(0x98,STR_00F7_SHIPS), |
|
73 |
MK(0x0F,STR_00F8_AIRCRAFT), |
|
74 |
MS(0xD7,STR_00F9_TRANSPORT_ROUTES), |
|
75 |
MK(0xB5,STR_00EE_BUILDINGS_INDUSTRIES), |
|
76 |
MKEND() |
|
77 |
}; |
|
78 |
||
79 |
static const uint16 _legend_industries_normal[] = { |
|
80 |
MK(0xD7,STR_00FA_COAL_MINE), |
|
81 |
MK(0xB8,STR_00FB_POWER_STATION), |
|
82 |
MK(0x56,STR_00FC_FOREST), |
|
83 |
MK(0xC2,STR_00FD_SAWMILL), |
|
84 |
MK(0xBF,STR_00FE_OIL_REFINERY), |
|
85 |
MK(0x0F,STR_0105_BANK), |
|
86 |
||
87 |
MS(0x30,STR_00FF_FARM), |
|
88 |
MK(0xAE,STR_0100_FACTORY), |
|
89 |
MK(0x98,STR_0102_OIL_WELLS), |
|
90 |
MK(0x37,STR_0103_IRON_ORE_MINE), |
|
91 |
MK(0x0A,STR_0104_STEEL_MILL), |
|
92 |
MKEND() |
|
93 |
}; |
|
94 |
||
95 |
static const uint16 _legend_industries_hilly[] = { |
|
96 |
MK(0xD7,STR_00FA_COAL_MINE), |
|
97 |
MK(0xB8,STR_00FB_POWER_STATION), |
|
98 |
MK(0x56,STR_00FC_FOREST), |
|
99 |
MK(0x0A,STR_0106_PAPER_MILL), |
|
100 |
MK(0xBF,STR_00FE_OIL_REFINERY), |
|
101 |
MK(0x37,STR_0108_FOOD_PROCESSING_PLANT), |
|
102 |
MS(0x30,STR_00FF_FARM), |
|
103 |
||
104 |
MK(0xAE,STR_0101_PRINTING_WORKS), |
|
105 |
MK(0x98,STR_0102_OIL_WELLS), |
|
106 |
MK(0xC2,STR_0107_GOLD_MINE), |
|
107 |
MK(0x0F,STR_0105_BANK), |
|
108 |
MKEND() |
|
109 |
}; |
|
110 |
||
111 |
static const uint16 _legend_industries_desert[] = { |
|
112 |
MK(0xBF,STR_00FE_OIL_REFINERY), |
|
113 |
MK(0x98,STR_0102_OIL_WELLS), |
|
114 |
MK(0x0F,STR_0105_BANK), |
|
115 |
MK(0xB8,STR_0109_DIAMOND_MINE), |
|
116 |
MK(0x37,STR_0108_FOOD_PROCESSING_PLANT), |
|
117 |
MK(0x0A,STR_010A_COPPER_ORE_MINE), |
|
118 |
MK(0x30,STR_00FF_FARM), |
|
119 |
MS(0x56,STR_010B_FRUIT_PLANTATION), |
|
120 |
||
121 |
MK(0x27,STR_010C_RUBBER_PLANTATION), |
|
122 |
MK(0x25,STR_010D_WATER_SUPPLY), |
|
123 |
MK(0xD0,STR_010E_WATER_TOWER), |
|
124 |
MK(0xAE,STR_0100_FACTORY), |
|
125 |
MK(0xC2,STR_010F_LUMBER_MILL), |
|
126 |
MKEND() |
|
127 |
}; |
|
128 |
||
129 |
static const uint16 _legend_industries_candy[] = { |
|
130 |
MK(0x30,STR_0110_COTTON_CANDY_FOREST), |
|
131 |
MK(0xAE,STR_0111_CANDY_FACTORY), |
|
132 |
MK(0x27,STR_0112_BATTERY_FARM), |
|
133 |
MK(0x37,STR_0113_COLA_WELLS), |
|
134 |
MK(0xD0,STR_0114_TOY_SHOP), |
|
135 |
MK(0x0A,STR_0115_TOY_FACTORY), |
|
136 |
MS(0x25,STR_0116_PLASTIC_FOUNTAINS), |
|
137 |
||
138 |
MK(0xB8,STR_0117_FIZZY_DRINK_FACTORY), |
|
139 |
MK(0x98,STR_0118_BUBBLE_GENERATOR), |
|
140 |
MK(0xC2,STR_0119_TOFFEE_QUARRY), |
|
141 |
MK(0x0F,STR_011A_SUGAR_MINE), |
|
142 |
MKEND() |
|
143 |
}; |
|
144 |
||
145 |
static const uint16 _legend_routes[] = { |
|
146 |
MK(0xD7,STR_00EB_ROADS), |
|
147 |
MK(0x0A,STR_00EC_RAILROADS), |
|
148 |
MK(0xB5,STR_00EE_BUILDINGS_INDUSTRIES), |
|
149 |
MS(0x56,STR_011B_RAILROAD_STATION), |
|
150 |
||
151 |
MK(0xC2,STR_011C_TRUCK_LOADING_BAY), |
|
152 |
MK(0xBF,STR_011D_BUS_STATION), |
|
153 |
MK(0xB8,STR_011E_AIRPORT_HELIPORT), |
|
154 |
MK(0x98,STR_011F_DOCK), |
|
155 |
MKEND() |
|
156 |
}; |
|
157 |
||
158 |
static const uint16 _legend_vegetation[] = { |
|
159 |
MK(0x52,STR_0120_ROUGH_LAND), |
|
160 |
MK(0x54,STR_0121_GRASS_LAND), |
|
161 |
MK(0x37,STR_0122_BARE_LAND), |
|
162 |
MK(0x25,STR_0123_FIELDS), |
|
163 |
MK(0x57,STR_0124_TREES), |
|
164 |
MK(0xD0,STR_00FC_FOREST), |
|
165 |
MS(0x0A,STR_0125_ROCKS), |
|
166 |
||
167 |
MK(0xC2,STR_012A_DESERT), |
|
168 |
MK(0x98,STR_012B_SNOW), |
|
169 |
MK(0xD7,STR_00F9_TRANSPORT_ROUTES), |
|
170 |
MK(0xB5,STR_00EE_BUILDINGS_INDUSTRIES), |
|
171 |
MKEND() |
|
172 |
}; |
|
173 |
||
174 |
static const uint16 _legend_land_owners[] = { |
|
175 |
MK(0xCA,STR_0126_WATER), |
|
176 |
MK(0x54,STR_0127_NO_OWNER), |
|
177 |
MK(0xB4,STR_0128_TOWNS), |
|
178 |
MK(0x20,STR_0129_INDUSTRIES), |
|
179 |
MKEND() |
|
180 |
}; |
|
181 |
#undef MK |
|
182 |
#undef MS |
|
183 |
#undef MKEND |
|
184 |
||
185 |
||
186 |
enum { IND_OFFS = 6 }; |
|
187 |
static const uint16 * const _legend_table[] = { |
|
188 |
_legend_land_contours, |
|
189 |
_legend_vehicles, |
|
190 |
NULL, |
|
191 |
_legend_routes, |
|
192 |
_legend_vegetation, |
|
193 |
_legend_land_owners, |
|
194 |
||
195 |
_legend_industries_normal, |
|
196 |
_legend_industries_hilly, |
|
197 |
_legend_industries_desert, |
|
198 |
_legend_industries_candy, |
|
199 |
}; |
|
200 |
||
2966
7f382cfeb93d
(svn r3529) - Fix: [ 1415782 ] crash in string code with openbsd/zaurus; alignment issues (thanks Tron for the help)
Darkvater
parents:
2955
diff
changeset
|
201 |
#if defined(OTTD_ALIGNMENT) |
2062 | 202 |
static inline void WRITE_PIXELS(Pixel* d, uint32 val) |
0 | 203 |
{ |
204 |
# if defined(TTD_BIG_ENDIAN) |
|
2635 | 205 |
d[0] = GB(val, 24, 8); |
206 |
d[1] = GB(val, 16, 8); |
|
207 |
d[2] = GB(val, 8, 8); |
|
208 |
d[3] = GB(val, 0, 8); |
|
0 | 209 |
# elif defined(TTD_LITTLE_ENDIAN) |
2635 | 210 |
d[0] = GB(val, 0, 8); |
211 |
d[1] = GB(val, 8, 8); |
|
212 |
d[2] = GB(val, 16, 8); |
|
213 |
d[3] = GB(val, 24, 8); |
|
0 | 214 |
# endif |
215 |
} |
|
216 |
||
217 |
/* need to use OR, otherwise we will overwrite the wrong pixels at the edges :( */ |
|
2062 | 218 |
static inline void WRITE_PIXELS_OR(Pixel* d, uint32 val) |
0 | 219 |
{ |
220 |
# if defined(TTD_BIG_ENDIAN) |
|
2635 | 221 |
d[0] |= GB(val, 24, 8); |
222 |
d[1] |= GB(val, 16, 8); |
|
223 |
d[2] |= GB(val, 8, 8); |
|
224 |
d[3] |= GB(val, 0, 8); |
|
0 | 225 |
# elif defined(TTD_LITTLE_ENDIAN) |
2635 | 226 |
d[0] |= GB(val, 0, 8); |
227 |
d[1] |= GB(val, 8, 8); |
|
228 |
d[2] |= GB(val, 16, 8); |
|
229 |
d[3] |= GB(val, 24, 8); |
|
0 | 230 |
# endif |
231 |
} |
|
232 |
#else |
|
233 |
# define WRITE_PIXELS(dst, val) *(uint32*)(dst) = (val); |
|
234 |
# define WRITE_PIXELS_OR(dst,val) *(uint32*)(dst) |= (val); |
|
235 |
#endif |
|
236 |
||
2984
225bffc79071
(svn r3559) - CodeChange: simplify MKCOLOR(x) macro for smallmap_gui.c by adding a TO_LE32X() macro next to TO_BE32X(). The 'X' signifies them as macros and not-inline functions so they can be used in variable declarations.
Darkvater
parents:
2981
diff
changeset
|
237 |
#define MKCOLOR(x) TO_LE32X(x) |
0 | 238 |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
239 |
/* Height encodings; 16 levels XXX - needs updating for more/finer heights! */ |
0 | 240 |
static const uint32 _map_height_bits[16] = { |
241 |
MKCOLOR(0x5A5A5A5A), |
|
242 |
MKCOLOR(0x5A5B5A5B), |
|
243 |
MKCOLOR(0x5B5B5B5B), |
|
244 |
MKCOLOR(0x5B5C5B5C), |
|
245 |
MKCOLOR(0x5C5C5C5C), |
|
246 |
MKCOLOR(0x5C5D5C5D), |
|
247 |
MKCOLOR(0x5D5D5D5D), |
|
248 |
MKCOLOR(0x5D5E5D5E), |
|
249 |
MKCOLOR(0x5E5E5E5E), |
|
250 |
MKCOLOR(0x5E5F5E5F), |
|
251 |
MKCOLOR(0x5F5F5F5F), |
|
252 |
MKCOLOR(0x5F1F5F1F), |
|
253 |
MKCOLOR(0x1F1F1F1F), |
|
254 |
MKCOLOR(0x1F271F27), |
|
255 |
MKCOLOR(0x27272727), |
|
256 |
MKCOLOR(0x27272727), |
|
257 |
}; |
|
258 |
||
1511
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
259 |
typedef struct AndOr { |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
260 |
uint32 mor; |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
261 |
uint32 mand; |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
262 |
} AndOr; |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
263 |
|
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
264 |
static inline uint32 ApplyMask(uint32 colour, const AndOr* mask) |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
265 |
{ |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
266 |
return (colour & mask->mand) | mask->mor; |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
267 |
} |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
268 |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
269 |
|
1511
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
270 |
static const AndOr _smallmap_contours_andor[] = { |
0 | 271 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
272 |
{MKCOLOR(0x000A0A00),MKCOLOR(0xFF0000FF)}, |
|
273 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
274 |
{MKCOLOR(0x00B5B500),MKCOLOR(0xFF0000FF)}, |
|
275 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
276 |
{MKCOLOR(0x98989898),MKCOLOR(0x00000000)}, |
|
277 |
{MKCOLOR(0xCACACACA),MKCOLOR(0x00000000)}, |
|
278 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
279 |
{MKCOLOR(0xB5B5B5B5),MKCOLOR(0x00000000)}, |
|
280 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
281 |
{MKCOLOR(0x00B5B500),MKCOLOR(0xFF0000FF)}, |
|
282 |
{MKCOLOR(0x000A0A00),MKCOLOR(0xFF0000FF)}, |
|
283 |
}; |
|
284 |
||
1511
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
285 |
static const AndOr _smallmap_vehicles_andor[] = { |
0 | 286 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
287 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
288 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
289 |
{MKCOLOR(0x00B5B500),MKCOLOR(0xFF0000FF)}, |
|
290 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
291 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
292 |
{MKCOLOR(0xCACACACA),MKCOLOR(0x00000000)}, |
|
293 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
294 |
{MKCOLOR(0xB5B5B5B5),MKCOLOR(0x00000000)}, |
|
295 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
296 |
{MKCOLOR(0x00B5B500),MKCOLOR(0xFF0000FF)}, |
|
297 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
298 |
}; |
|
299 |
||
1511
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
300 |
static const AndOr _smallmap_vegetation_andor[] = { |
0 | 301 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
302 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
303 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
304 |
{MKCOLOR(0x00B5B500),MKCOLOR(0xFF0000FF)}, |
|
305 |
{MKCOLOR(0x00575700),MKCOLOR(0xFF0000FF)}, |
|
306 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
307 |
{MKCOLOR(0xCACACACA),MKCOLOR(0x00000000)}, |
|
308 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
309 |
{MKCOLOR(0xB5B5B5B5),MKCOLOR(0x00000000)}, |
|
310 |
{MKCOLOR(0x00000000),MKCOLOR(0xFFFFFFFF)}, |
|
311 |
{MKCOLOR(0x00B5B500),MKCOLOR(0xFF0000FF)}, |
|
312 |
{MKCOLOR(0x00D7D700),MKCOLOR(0xFF0000FF)}, |
|
313 |
}; |
|
314 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
315 |
typedef uint32 GetSmallMapPixels(TileIndex tile); // typedef callthrough function |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
316 |
|
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
317 |
/** |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
318 |
* Draws one column of the small map in a certain mode onto the screen buffer. This |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
319 |
* function looks exactly the same for all types |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
320 |
* |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
321 |
* @param dst Pointer to a part of the screen buffer to write to. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
322 |
* @param xc The X coordinate of the first tile in the column. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
323 |
* @param yc The Y coordinate of the first tile in the column |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
324 |
* @param pitch Number of pixels to advance in the screen buffer each time a pixel is written. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
325 |
* @param reps Number of lines to draw |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
326 |
* @param mask ? |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
327 |
* @param proc Pointer to the colour function |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
328 |
* @see GetSmallMapPixels(TileIndex) |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
329 |
*/ |
2062 | 330 |
static void DrawSmallMapStuff(Pixel *dst, uint xc, uint yc, int pitch, int reps, uint32 mask, GetSmallMapPixels *proc) |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
331 |
{ |
2062 | 332 |
Pixel *dst_ptr_end = _screen.dst_ptr + _screen.width * _screen.height - _screen.width; |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
333 |
|
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
334 |
do { |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
335 |
// check if the tile (xc,yc) is within the map range |
1919
0ad642b26ff2
(svn r2425) - Fix (regression): wrong sprite for level-land cursor (thx Tron)
Darkvater
parents:
1918
diff
changeset
|
336 |
if (xc < MapMaxX() && yc < MapMaxY()) { |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
337 |
// check if the dst pointer points to a pixel inside the screen buffer |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
338 |
if (dst > _screen.dst_ptr && dst < dst_ptr_end) |
1981 | 339 |
WRITE_PIXELS_OR(dst, proc(TileXY(xc, yc)) & mask); |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
340 |
} |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
341 |
// switch to next tile in the column |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
342 |
} while (xc++, yc++, dst += pitch, --reps != 0); |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
343 |
} |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
344 |
|
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
345 |
|
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
346 |
static inline TileType GetEffectiveTileType(TileIndex tile) |
0 | 347 |
{ |
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
348 |
TileType t = GetTileType(tile); |
0 | 349 |
|
350 |
if (t == MP_TUNNELBRIDGE) { |
|
3180
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
351 |
TransportType tt; |
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
352 |
|
3184
7405329343ce
(svn r3830) Move IsTunnelTile() from tile.h to tunnel_map.h and add IsTunnel(), which just checks for a tunnel, but not the tile type as IsTunnelTile() does
tron
parents:
3180
diff
changeset
|
353 |
if (IsTunnel(tile)) { |
7405329343ce
(svn r3830) Move IsTunnelTile() from tile.h to tunnel_map.h and add IsTunnel(), which just checks for a tunnel, but not the tile type as IsTunnelTile() does
tron
parents:
3180
diff
changeset
|
354 |
tt = GetTunnelTransportType(tile); |
7405329343ce
(svn r3830) Move IsTunnelTile() from tile.h to tunnel_map.h and add IsTunnel(), which just checks for a tunnel, but not the tile type as IsTunnelTile() does
tron
parents:
3180
diff
changeset
|
355 |
} else { |
3234
986c30171e92
(svn r3907) Replace many bridge related direct map accesses with calls to shiny new functions and mark some strange constructs with XXX
tron
parents:
3184
diff
changeset
|
356 |
tt = GetBridgeTransportType(tile); |
3180
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
357 |
} |
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
358 |
switch (tt) { |
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
359 |
case TRANSPORT_RAIL: t = MP_RAILWAY; break; |
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
360 |
case TRANSPORT_ROAD: t = MP_STREET; break; |
2123f8062a2d
(svn r3820) Be a bit more strict with types: use special types instead of generic byte and don't fill arbitrary data into inappropriate types
tron
parents:
3144
diff
changeset
|
361 |
default: t = MP_WATER; break; |
0 | 362 |
} |
363 |
} |
|
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
364 |
return t; |
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
365 |
} |
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
366 |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
367 |
/** |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
368 |
* Return the color a tile would be displayed with in the small map in mode "Contour". |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
369 |
* @param tile The tile of which we would like to get the color. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
370 |
* @return The color of tile in the small map in mode "Contour" |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
371 |
*/ |
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
372 |
static inline uint32 GetSmallMapContoursPixels(TileIndex tile) |
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
373 |
{ |
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
374 |
TileType t = GetEffectiveTileType(tile); |
0 | 375 |
|
1511
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
376 |
return |
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
377 |
ApplyMask(_map_height_bits[TileHeight(tile)], &_smallmap_contours_andor[t]); |
0 | 378 |
} |
379 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
380 |
/** |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
381 |
* Return the color a tile would be displayed with in the small map in mode "Vehicles". |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
382 |
* |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
383 |
* @param t The tile of which we would like to get the color. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
384 |
* @return The color of tile in the small map in mode "Vehicles" |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
385 |
*/ |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
386 |
static inline uint32 GetSmallMapVehiclesPixels(TileIndex tile) |
0 | 387 |
{ |
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
388 |
TileType t = GetEffectiveTileType(tile); |
0 | 389 |
|
1511
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
390 |
return ApplyMask(MKCOLOR(0x54545454), &_smallmap_vehicles_andor[t]); |
0 | 391 |
} |
392 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
393 |
/* Industry colours... a total of 175 gfx - XXX - increase if more industries */ |
0 | 394 |
static const byte _industry_smallmap_colors[175] = { |
395 |
215,215,215,215,215,215,215,184, |
|
396 |
184,184,184,194,194,194,194,194, |
|
397 |
86, 86,191,191,191,191,191,191, |
|
398 |
152,152,152,152,152,152,152,152, |
|
399 |
152, 48, 48, 48, 48, 48, 48,174, |
|
400 |
174,174,174,174,174,174,174, 10, |
|
401 |
10, 10, 10, 10, 10, 10, 10, 10, |
|
402 |
10, 10, 15, 15, 55, 55, 55, 55, |
|
403 |
10, 10, 10, 10, 10, 10, 10, 10, |
|
404 |
194,194,194,194,194,194,194,194, |
|
405 |
194,194,194,194,194,194,194,194, |
|
406 |
194, 15, 15,184,184,184,184,184, |
|
407 |
184,184,184,184, 55, 55, 55, 55, |
|
408 |
55, 55, 55, 55, 55, 55, 55, 55, |
|
409 |
55, 55, 55, 55, 86, 39, 37, 37, |
|
410 |
208,174,174,174,174,194,194,194, |
|
411 |
194, 48, 48,174,174,174,174, 39, |
|
412 |
39, 55,208,208,208,208, 10, 10, |
|
413 |
10, 10, 10, 10, 37, 37, 37, 37, |
|
414 |
37, 37, 37, 37,184,184,184,184, |
|
415 |
152,152,152,152,194,194,194, 15, |
|
416 |
15, 15, 15, 15, 15, 15, 15, |
|
417 |
}; |
|
418 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
419 |
/** |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
420 |
* Return the color a tile would be displayed with in the small map in mode "Industries". |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
421 |
* |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
422 |
* @param tile The tile of which we would like to get the color. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
423 |
* @return The color of tile in the small map in mode "Industries" |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
424 |
*/ |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
425 |
static inline uint32 GetSmallMapIndustriesPixels(TileIndex tile) |
0 | 426 |
{ |
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
427 |
TileType t = GetEffectiveTileType(tile); |
0 | 428 |
|
429 |
if (t == MP_INDUSTRY) { |
|
2049
ad0d49c916d4
(svn r2558) Change the internal map format from 7 arrays to one array of structs, this doesn't change the saved format for now. It's a stepping stone for further changes.
tron
parents:
1981
diff
changeset
|
430 |
byte color = _industry_smallmap_colors[_m[tile].m5]; |
0 | 431 |
return color + (color << 8) + (color << 16) + (color << 24); |
432 |
} |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
433 |
|
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
434 |
return ApplyMask(MKCOLOR(0x54545454), &_smallmap_vehicles_andor[t]); |
0 | 435 |
} |
436 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
437 |
/** |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
438 |
* Return the color a tile would be displayed with in the small map in mode "Routes". |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
439 |
* |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
440 |
* @param t The tile of which we would like to get the color. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
441 |
* @return The color of tile in the small map in mode "Routes" |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
442 |
*/ |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
443 |
static inline uint32 GetSmallMapRoutesPixels(TileIndex tile) |
0 | 444 |
{ |
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
445 |
TileType t = GetEffectiveTileType(tile); |
0 | 446 |
uint32 bits; |
447 |
||
448 |
if (t == MP_STATION) { |
|
3338
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
449 |
switch (GetStationType(tile)) { |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
450 |
case STATION_RAIL: bits = MKCOLOR(0x56565656); break; |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
451 |
case STATION_HANGAR: |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
452 |
case STATION_AIRPORT: bits = MKCOLOR(0xB8B8B8B8); break; |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
453 |
case STATION_TRUCK: bits = MKCOLOR(0xC2C2C2C2); break; |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
454 |
case STATION_BUS: bits = MKCOLOR(0xBFBFBFBF); break; |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
455 |
case STATION_DOCK: bits = MKCOLOR(0x98989898); break; |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
456 |
default: bits = MKCOLOR(0xFFFFFFFF); break; |
2c60ed0dcce3
(svn r4120) Use the new station functions where appropriate
tron
parents:
3326
diff
changeset
|
457 |
} |
0 | 458 |
} else { |
459 |
// ground color |
|
1511
32b095e3da76
(svn r2015) Use a struct and an inline function for colour masking on the mini-map - this should improve readability a bit
tron
parents:
1350
diff
changeset
|
460 |
bits = ApplyMask(MKCOLOR(0x54545454), &_smallmap_contours_andor[t]); |
0 | 461 |
} |
462 |
return bits; |
|
463 |
} |
|
464 |
||
465 |
||
2955
27221592ebbc
(svn r3514) -Codechange: Replace direct fiddling of bits for the ground type and density of clear tiles with symbolic names and accessors.
tron
parents:
2952
diff
changeset
|
466 |
static const uint32 _vegetation_clear_bits[] = { |
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
467 |
MKCOLOR(0x54545454), ///< full grass |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
468 |
MKCOLOR(0x52525252), ///< rough land |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
469 |
MKCOLOR(0x0A0A0A0A), ///< rocks |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
470 |
MKCOLOR(0x25252525), ///< fields |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
471 |
MKCOLOR(0x98989898), ///< snow |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
472 |
MKCOLOR(0xC2C2C2C2), ///< desert |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
473 |
MKCOLOR(0x54545454), ///< unused |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
474 |
MKCOLOR(0x54545454), ///< unused |
0 | 475 |
}; |
476 |
||
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
477 |
static inline uint32 GetSmallMapVegetationPixels(TileIndex tile) |
0 | 478 |
{ |
1516
997a23b8b16c
(svn r2020) Reduce code duplication in the minimap code a bit
tron
parents:
1515
diff
changeset
|
479 |
TileType t = GetEffectiveTileType(tile); |
0 | 480 |
uint32 bits; |
481 |
||
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
482 |
switch (t) { |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
483 |
case MP_CLEAR: |
2955
27221592ebbc
(svn r3514) -Codechange: Replace direct fiddling of bits for the ground type and density of clear tiles with symbolic names and accessors.
tron
parents:
2952
diff
changeset
|
484 |
if (IsClearGround(tile, CL_GRASS) && GetClearDensity(tile) < 3) { |
27221592ebbc
(svn r3514) -Codechange: Replace direct fiddling of bits for the ground type and density of clear tiles with symbolic names and accessors.
tron
parents:
2952
diff
changeset
|
485 |
bits = MKCOLOR(0x37373737); |
27221592ebbc
(svn r3514) -Codechange: Replace direct fiddling of bits for the ground type and density of clear tiles with symbolic names and accessors.
tron
parents:
2952
diff
changeset
|
486 |
} else { |
27221592ebbc
(svn r3514) -Codechange: Replace direct fiddling of bits for the ground type and density of clear tiles with symbolic names and accessors.
tron
parents:
2952
diff
changeset
|
487 |
bits = _vegetation_clear_bits[GetClearGround(tile)]; |
27221592ebbc
(svn r3514) -Codechange: Replace direct fiddling of bits for the ground type and density of clear tiles with symbolic names and accessors.
tron
parents:
2952
diff
changeset
|
488 |
} |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
489 |
break; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
490 |
|
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
491 |
case MP_INDUSTRY: |
2049
ad0d49c916d4
(svn r2558) Change the internal map format from 7 arrays to one array of structs, this doesn't change the saved format for now. It's a stepping stone for further changes.
tron
parents:
1981
diff
changeset
|
492 |
bits = IS_BYTE_INSIDE(_m[tile].m5, 0x10, 0x12) ? MKCOLOR(0xD0D0D0D0) : MKCOLOR(0xB5B5B5B5); |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
493 |
break; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
494 |
|
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
495 |
case MP_TREES: |
2981 | 496 |
if (GetTreeGround(tile) == TR_SNOW_DESERT) { |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
497 |
bits = (_opt.landscape == LT_HILLY) ? MKCOLOR(0x98575798) : MKCOLOR(0xC25757C2); |
2951 | 498 |
} else { |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
499 |
bits = MKCOLOR(0x54575754); |
2951 | 500 |
} |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
501 |
break; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
502 |
|
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
503 |
default: |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
504 |
bits = ApplyMask(MKCOLOR(0x54545454), &_smallmap_vehicles_andor[t]); |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
505 |
break; |
0 | 506 |
} |
507 |
||
508 |
return bits; |
|
509 |
} |
|
510 |
||
511 |
||
1092 | 512 |
static uint32 _owner_colors[256]; |
0 | 513 |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
514 |
/** |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
515 |
* Return the color a tile would be displayed with in the small map in mode "Owner". |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
516 |
* |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
517 |
* @param t The tile of which we would like to get the color. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
518 |
* @return The color of tile in the small map in mode "Owner" |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
519 |
*/ |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
520 |
static inline uint32 GetSmallMapOwnerPixels(TileIndex tile) |
0 | 521 |
{ |
2368
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
522 |
Owner o; |
0 | 523 |
|
2368
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
524 |
switch (GetTileType(tile)) { |
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
525 |
case MP_INDUSTRY: o = OWNER_SPECTATOR; break; |
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
526 |
case MP_HOUSE: o = OWNER_TOWN; break; |
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
527 |
default: o = GetTileOwner(tile); break; |
0 | 528 |
} |
529 |
||
2368
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
530 |
return _owner_colors[o]; |
0 | 531 |
} |
532 |
||
533 |
||
534 |
static const uint32 _smallmap_mask_left[3] = { |
|
535 |
MKCOLOR(0xFF000000), |
|
536 |
MKCOLOR(0xFFFF0000), |
|
537 |
MKCOLOR(0xFFFFFF00), |
|
538 |
}; |
|
539 |
||
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
540 |
static const uint32 _smallmap_mask_right[] = { |
0 | 541 |
MKCOLOR(0x000000FF), |
542 |
MKCOLOR(0x0000FFFF), |
|
543 |
MKCOLOR(0x00FFFFFF), |
|
544 |
}; |
|
545 |
||
546 |
/* each tile has 4 x pixels and 1 y pixel */ |
|
547 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
548 |
static GetSmallMapPixels *_smallmap_draw_procs[] = { |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
549 |
GetSmallMapContoursPixels, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
550 |
GetSmallMapVehiclesPixels, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
551 |
GetSmallMapIndustriesPixels, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
552 |
GetSmallMapRoutesPixels, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
553 |
GetSmallMapVegetationPixels, |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
554 |
GetSmallMapOwnerPixels, |
0 | 555 |
}; |
556 |
||
557 |
static const byte _vehicle_type_colors[6] = { |
|
558 |
184, 191, 152, 15, 215, 184 |
|
559 |
}; |
|
560 |
||
500
ef288590e096
(svn r793) Merge INLINE -> inline replacement (revision 376)
tron
parents:
337
diff
changeset
|
561 |
static inline uint32 dup_byte32(byte b) { |
0 | 562 |
return b + (b << 8) + (b << 16) + (b << 24); |
563 |
} |
|
564 |
||
565 |
static void DrawVertMapIndicator(int x, int y, int x2, int y2) |
|
566 |
{ |
|
2951 | 567 |
GfxFillRect(x, y, x2, y + 3, 69); |
568 |
GfxFillRect(x, y2 - 3, x2, y2, 69); |
|
0 | 569 |
} |
570 |
||
571 |
static void DrawHorizMapIndicator(int x, int y, int x2, int y2) |
|
572 |
{ |
|
2951 | 573 |
GfxFillRect(x, y, x + 3, y2, 69); |
574 |
GfxFillRect(x2 - 3, y, x2, y2, 69); |
|
0 | 575 |
} |
576 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
577 |
/** |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
578 |
* Draws the small map. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
579 |
* |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
580 |
* Basically, the small map is draw column of pixels by column of pixels. The pixels |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
581 |
* are drawn directly into the screen buffer. The final map is drawn in multiple passes. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
582 |
* The passes are: |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
583 |
* <ol><li>The colors of tiles in the different modes.</li> |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
584 |
* <li>Town names (optional)</li> |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
585 |
* |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
586 |
* @param dpi pointer to pixel to write onto |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
587 |
* @param w pointer to Window struct |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
588 |
* @param type type of map requested (vegetation, owners, routes, etc) |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
589 |
* @param show_towns true if the town names should be displayed, false if not. |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
590 |
*/ |
0 | 591 |
static void DrawSmallMap(DrawPixelInfo *dpi, Window *w, int type, bool show_towns) |
592 |
{ |
|
593 |
DrawPixelInfo *old_dpi; |
|
594 |
int dx,dy, x, y, x2, y2; |
|
2062 | 595 |
Pixel *ptr; |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
596 |
int tile_x; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
597 |
int tile_y; |
0 | 598 |
ViewPort *vp; |
599 |
||
600 |
old_dpi = _cur_dpi; |
|
601 |
_cur_dpi = dpi; |
|
602 |
||
603 |
/* clear it */ |
|
604 |
GfxFillRect(dpi->left, dpi->top, dpi->left + dpi->width - 1, dpi->top + dpi->height - 1, 0); |
|
605 |
||
606 |
/* setup owner table */ |
|
607 |
if (type == 5) { |
|
2368
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
608 |
const Player* p; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
609 |
|
0 | 610 |
/* fill with some special colors */ |
2368
d5a31a409219
(svn r2894) Simplify colouring in owner-mode in the minimap regarding towns and get rid of some magic numbers
tron
parents:
2332
diff
changeset
|
611 |
_owner_colors[OWNER_TOWN] = MKCOLOR(0xB4B4B4B4); |
2332
fa9dc1350e22
(svn r2858) -Codechange: resolved some magic numbers (_Luca_)
truelight
parents:
2186
diff
changeset
|
612 |
_owner_colors[OWNER_NONE] = MKCOLOR(0x54545454); |
fa9dc1350e22
(svn r2858) -Codechange: resolved some magic numbers (_Luca_)
truelight
parents:
2186
diff
changeset
|
613 |
_owner_colors[OWNER_WATER] = MKCOLOR(0xCACACACA); |
fa9dc1350e22
(svn r2858) -Codechange: resolved some magic numbers (_Luca_)
truelight
parents:
2186
diff
changeset
|
614 |
_owner_colors[OWNER_SPECTATOR] = MKCOLOR(0x20202020); /* industry */ |
0 | 615 |
|
616 |
/* now fill with the player colors */ |
|
617 |
FOR_ALL_PLAYERS(p) { |
|
2951 | 618 |
if (p->is_active) { |
1092 | 619 |
_owner_colors[p->index] = |
3326
b5ce3e805425
(svn r4092) CodeChange : Named sprites instead of magic numbers plus create/use helper macro/enum for recoloring scheme
belugas
parents:
3234
diff
changeset
|
620 |
dup_byte32(GetNonSprite(PALETTE_RECOLOR_START + p->player_color)[0xCB]); // XXX - magic pixel |
2951 | 621 |
} |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
622 |
} |
0 | 623 |
} |
624 |
||
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
625 |
tile_x = WP(w,smallmap_d).scroll_x / 16; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
626 |
tile_y = WP(w,smallmap_d).scroll_y / 16; |
0 | 627 |
|
628 |
dx = dpi->left + WP(w,smallmap_d).subscroll; |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
629 |
tile_x -= dx / 4; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
630 |
tile_y += dx / 4; |
0 | 631 |
dx &= 3; |
632 |
||
633 |
dy = dpi->top; |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
634 |
tile_x += dy / 2; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
635 |
tile_y += dy / 2; |
0 | 636 |
|
637 |
if (dy & 1) { |
|
638 |
tile_x++; |
|
639 |
dx += 2; |
|
640 |
if (dx > 3) { |
|
641 |
dx -= 4; |
|
642 |
tile_x--; |
|
643 |
tile_y++; |
|
644 |
} |
|
645 |
} |
|
646 |
||
647 |
ptr = dpi->dst_ptr - dx - 4; |
|
648 |
x = - dx - 4; |
|
649 |
y = 0; |
|
650 |
||
2952 | 651 |
for (;;) { |
2989 | 652 |
uint32 mask = 0xFFFFFFFF; |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
653 |
int reps; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
654 |
int t; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
655 |
|
0 | 656 |
/* distance from left edge */ |
657 |
if (x < 0) { |
|
658 |
if (x < -3) goto skip_column; |
|
659 |
/* mask to use at the left edge */ |
|
660 |
mask = _smallmap_mask_left[x + 3]; |
|
661 |
} |
|
662 |
||
663 |
/* distance from right edge */ |
|
664 |
t = dpi->width - x; |
|
665 |
if (t < 4) { |
|
2951 | 666 |
if (t <= 0) break; /* exit loop */ |
0 | 667 |
/* mask to use at the right edge */ |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
668 |
mask &= _smallmap_mask_right[t - 1]; |
0 | 669 |
} |
670 |
||
671 |
/* number of lines */ |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
672 |
reps = (dpi->height - y + 1) / 2; |
0 | 673 |
if (reps > 0) { |
674 |
// assert(ptr >= dpi->dst_ptr); |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
675 |
DrawSmallMapStuff(ptr, tile_x, tile_y, dpi->pitch*2, reps, mask, _smallmap_draw_procs[type]); |
0 | 676 |
} |
677 |
||
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
678 |
skip_column: |
0 | 679 |
if (y == 0) { |
680 |
tile_y++; |
|
681 |
y++; |
|
682 |
ptr += dpi->pitch; |
|
683 |
} else { |
|
684 |
tile_x--; |
|
685 |
y--; |
|
686 |
ptr -= dpi->pitch; |
|
687 |
} |
|
688 |
ptr += 2; |
|
689 |
x += 2; |
|
690 |
} |
|
691 |
||
692 |
/* draw vehicles? */ |
|
693 |
if (type == 0 || type == 1) { |
|
694 |
Vehicle *v; |
|
695 |
bool skip; |
|
696 |
byte color; |
|
697 |
||
698 |
FOR_ALL_VEHICLES(v) { |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
699 |
if (v->type != 0 && v->type != VEH_Special && |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
700 |
(v->vehstatus & (VS_HIDDEN | VS_UNCLICKABLE)) == 0) { |
0 | 701 |
// Remap into flat coordinates. |
702 |
Point pt = RemapCoords( |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
703 |
(v->x_pos - WP(w,smallmap_d).scroll_x) / 16, |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
704 |
(v->y_pos - WP(w,smallmap_d).scroll_y) / 16, |
0 | 705 |
0); |
706 |
x = pt.x; |
|
707 |
y = pt.y; |
|
708 |
||
709 |
// Check if y is out of bounds? |
|
710 |
y -= dpi->top; |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
711 |
if (!IS_INT_INSIDE(y, 0, dpi->height)) continue; |
0 | 712 |
|
713 |
// Default is to draw both pixels. |
|
714 |
skip = false; |
|
715 |
||
716 |
// Offset X coordinate |
|
717 |
x -= WP(w,smallmap_d).subscroll + 3 + dpi->left; |
|
718 |
||
719 |
if (x < 0) { |
|
720 |
// if x+1 is 0, that means we're on the very left edge, |
|
721 |
// and should thus only draw a single pixel |
|
2951 | 722 |
if (++x != 0) continue; |
0 | 723 |
skip = true; |
724 |
} else if (x >= dpi->width - 1) { |
|
725 |
// Check if we're at the very right edge, and if so draw only a single pixel |
|
2951 | 726 |
if (x != dpi->width - 1) continue; |
0 | 727 |
skip = true; |
728 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
729 |
|
0 | 730 |
// Calculate pointer to pixel and the color |
731 |
ptr = dpi->dst_ptr + y * dpi->pitch + x; |
|
732 |
color = (type == 1) ? _vehicle_type_colors[v->type-0x10] : 0xF; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
733 |
|
0 | 734 |
// And draw either one or two pixels depending on clipping |
735 |
ptr[0] = color; |
|
2951 | 736 |
if (!skip) ptr[1] = color; |
0 | 737 |
} |
738 |
} |
|
739 |
} |
|
740 |
||
741 |
if (show_towns) { |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
742 |
const Town *t; |
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
743 |
|
0 | 744 |
FOR_ALL_TOWNS(t) { |
745 |
if (t->xy != 0) { |
|
746 |
// Remap the town coordinate |
|
747 |
Point pt = RemapCoords( |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
748 |
(int)(TileX(t->xy) * 16 - WP(w, smallmap_d).scroll_x) / 16, |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
749 |
(int)(TileY(t->xy) * 16 - WP(w, smallmap_d).scroll_y) / 16, |
0 | 750 |
0); |
751 |
x = pt.x - WP(w,smallmap_d).subscroll + 3 - (t->sign.width_2 >> 1); |
|
752 |
y = pt.y; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
753 |
|
0 | 754 |
// Check if the town sign is within bounds |
755 |
if (x + t->sign.width_2 > dpi->left && |
|
756 |
x < dpi->left + dpi->width && |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
757 |
y + 6 > dpi->top && |
0 | 758 |
y < dpi->top + dpi->height) { |
759 |
// And draw it. |
|
534
17ab2f22ff74
(svn r901) Small step in the process to clean up the DPARAM mess:
tron
parents:
507
diff
changeset
|
760 |
SetDParam(0, t->index); |
0 | 761 |
DrawString(x, y, STR_2056, 12); |
762 |
} |
|
763 |
} |
|
764 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
765 |
} |
0 | 766 |
|
767 |
// Draw map indicators |
|
768 |
{ |
|
769 |
Point pt; |
|
770 |
||
771 |
// Find main viewport. |
|
772 |
vp = FindWindowById(WC_MAIN_WINDOW,0)->viewport; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
773 |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
774 |
pt = RemapCoords(WP(w, smallmap_d).scroll_x, WP(w, smallmap_d).scroll_y, 0); |
0 | 775 |
|
776 |
x = vp->virtual_left - pt.x; |
|
777 |
y = vp->virtual_top - pt.y; |
|
1515
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
778 |
x2 = (x + vp->virtual_width) / 16; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
779 |
y2 = (y + vp->virtual_height) / 16; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
780 |
x /= 16; |
f466d02bd936
(svn r2019) Miscellaneous cleanups, like uint -> TileIndex, >> -> /, if cascade -> switch
tron
parents:
1511
diff
changeset
|
781 |
y /= 16; |
0 | 782 |
|
783 |
x -= WP(w,smallmap_d).subscroll; |
|
784 |
x2 -= WP(w,smallmap_d).subscroll; |
|
785 |
||
786 |
DrawVertMapIndicator(x, y, x, y2); |
|
787 |
DrawVertMapIndicator(x2, y, x2, y2); |
|
788 |
||
789 |
DrawHorizMapIndicator(x, y, x2, y); |
|
790 |
DrawHorizMapIndicator(x, y2, x2, y2); |
|
791 |
} |
|
792 |
_cur_dpi = old_dpi; |
|
793 |
} |
|
794 |
||
795 |
static void SmallMapWindowProc(Window *w, WindowEvent *e) |
|
796 |
{ |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
797 |
switch (e->event) { |
0 | 798 |
case WE_PAINT: { |
799 |
const uint16 *tbl; |
|
800 |
int x,y,y_org; |
|
801 |
DrawPixelInfo new_dpi; |
|
802 |
||
803 |
/* draw the window */ |
|
534
17ab2f22ff74
(svn r901) Small step in the process to clean up the DPARAM mess:
tron
parents:
507
diff
changeset
|
804 |
SetDParam(0, STR_00E5_CONTOURS + _smallmap_type); |
0 | 805 |
DrawWindowWidgets(w); |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
806 |
|
0 | 807 |
/* draw the legend */ |
808 |
tbl = _legend_table[(_smallmap_type != 2) ? _smallmap_type : (_opt.landscape + IND_OFFS)]; |
|
809 |
x = 4; |
|
2907
65c92989a1f3
(svn r3462) - Fix: a one-off pixel alignment in the minimap window that "overflowed" its panel in the tropical climate (qball should be satisfied now)
Darkvater
parents:
2725
diff
changeset
|
810 |
y_org = w->height - 44 - 11; |
0 | 811 |
y = y_org; |
2951 | 812 |
for (;;) { |
813 |
GfxFillRect(x, y + 1, x + 8, y + 5, 0); |
|
814 |
GfxFillRect(x + 1, y + 2, x + 7, y + 4, (byte)tbl[0]); |
|
815 |
DrawString(x + 11, y, tbl[1], 0); |
|
0 | 816 |
|
817 |
tbl += 2; |
|
818 |
y += 6; |
|
819 |
||
820 |
if (tbl[0] == 0xFFFF) { |
|
821 |
break; |
|
822 |
} else if (tbl[0] & 0x100) { |
|
823 |
x += 123; |
|
824 |
y = y_org; |
|
825 |
} |
|
826 |
} |
|
827 |
||
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
828 |
if (!FillDrawPixelInfo(&new_dpi, NULL, 3, 17, w->width - 28 + 22, w->height - 64 - 11)) |
0 | 829 |
return; |
830 |
||
831 |
DrawSmallMap(&new_dpi, w, _smallmap_type, _smallmap_show_towns); |
|
832 |
} break; |
|
833 |
||
834 |
case WE_CLICK: |
|
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
835 |
switch (e->click.widget) { |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
836 |
case 4: {/* Main wnd */ |
0 | 837 |
Window *w2; |
838 |
Point pt; |
|
839 |
||
840 |
_left_button_clicked = false; |
|
841 |
||
842 |
w2 = FindWindowById(WC_MAIN_WINDOW, 0); |
|
843 |
||
844 |
pt = RemapCoords(WP(w,smallmap_d).scroll_x, WP(w,smallmap_d).scroll_y, 0); |
|
845 |
WP(w2,vp_d).scrollpos_x = pt.x + ((_cursor.pos.x - w->left + 2) << 4) - (w2->viewport->virtual_width >> 1); |
|
846 |
WP(w2,vp_d).scrollpos_y = pt.y + ((_cursor.pos.y - w->top - 16) << 4) - (w2->viewport->virtual_height >> 1); |
|
847 |
} break; |
|
848 |
||
1918
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
849 |
case 5: /* Show land contours */ |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
850 |
case 6: /* Show vehicles */ |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
851 |
case 7: /* Show industries */ |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
852 |
case 8: /* Show transport routes */ |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
853 |
case 9: /* Show vegetation */ |
68d78ef6833d
(svn r2424) - Fix: backport the smallmap_gui.c changes from the map/ branch into trunk. This also implicitely fixes the bug where the game would crash in certain resolutions with certain minimap masks when dragged partly outside the game-area.
Darkvater
parents:
1901
diff
changeset
|
854 |
case 10: /* Show land owners */ |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
855 |
w->click_state &= ~(1<<5|1<<6|1<<7|1<<8|1<<9|1<<10); |
0 | 856 |
w->click_state |= 1 << e->click.widget; |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
857 |
_smallmap_type = e->click.widget - 5; |
0 | 858 |
|
859 |
SetWindowDirty(w); |
|
541 | 860 |
SndPlayFx(SND_15_BEEP); |
0 | 861 |
break; |
862 |
||
758
bd9e868b9fae
(svn r1214) -Feature: Stickified Industries (list & window), Smallmaps (all three), Stations (list & window) and Towns (list & window). I hope I didn't forget to update a widget somewhere :O
darkvater
parents:
682
diff
changeset
|
863 |
case 12: /* toggle town names */ |
bd9e868b9fae
(svn r1214) -Feature: Stickified Industries (list & window), Smallmaps (all three), Stations (list & window) and Towns (list & window). I hope I didn't forget to update a widget somewhere :O
darkvater
parents:
682
diff
changeset
|
864 |
w->click_state ^= (1 << 12); |
bd9e868b9fae
(svn r1214) -Feature: Stickified Industries (list & window), Smallmaps (all three), Stations (list & window) and Towns (list & window). I hope I didn't forget to update a widget somewhere :O
darkvater
parents:
682
diff
changeset
|
865 |
_smallmap_show_towns = (w->click_state >> 12) & 1; |
0 | 866 |
SetWindowDirty(w); |
541 | 867 |
SndPlayFx(SND_15_BEEP); |
0 | 868 |
break; |
869 |
} |
|
870 |
break; |
|
871 |
||
872 |
case WE_RCLICK: |
|
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
873 |
if (e->click.widget == 4) { |
2951 | 874 |
if (_scrolling_viewport) return; |
0 | 875 |
_scrolling_viewport = true; |
876 |
_cursor.delta.x = 0; |
|
877 |
_cursor.delta.y = 0; |
|
878 |
} |
|
879 |
break; |
|
880 |
||
881 |
case WE_MOUSELOOP: |
|
882 |
/* update the window every now and then */ |
|
2951 | 883 |
if ((++w->vscroll.pos & 0x1F) == 0) SetWindowDirty(w); |
0 | 884 |
break; |
885 |
} |
|
886 |
} |
|
887 |
||
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
888 |
static const WindowDesc _smallmap_desc = { |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
889 |
-1,-1, 446, 314, |
0 | 890 |
WC_SMALLMAP,0, |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
891 |
WDF_STD_TOOLTIPS | WDF_STD_BTN | WDF_DEF_WIDGET | WDF_STICKY_BUTTON | WDF_RESIZABLE, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
892 |
_smallmap_widgets, |
0 | 893 |
SmallMapWindowProc |
894 |
}; |
|
895 |
||
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1092
diff
changeset
|
896 |
void ShowSmallMap(void) |
0 | 897 |
{ |
898 |
Window *w; |
|
899 |
ViewPort *vp; |
|
900 |
int x,y; |
|
901 |
||
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
902 |
w = AllocateWindowDescFront(&_smallmap_desc, 0); |
2989 | 903 |
if (w != NULL) { |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
904 |
w->click_state = ((1<<5) << _smallmap_type) | (_smallmap_show_towns << 12); |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
905 |
w->resize.width = 350; |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
906 |
w->resize.height = 250; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
907 |
|
0 | 908 |
vp = FindWindowById(WC_MAIN_WINDOW, 0)->viewport; |
909 |
||
2951 | 910 |
x = ((vp->virtual_width - 220 * 32) / 2 + vp->virtual_left) / 4; |
911 |
y = ((vp->virtual_height - 120 * 32) / 2 + vp->virtual_top ) / 2 - 32; |
|
912 |
WP(w,smallmap_d).scroll_x = (y - x) & ~0xF; |
|
913 |
WP(w,smallmap_d).scroll_y = (x + y) & ~0xF; |
|
0 | 914 |
WP(w,smallmap_d).subscroll = 0; |
915 |
} |
|
916 |
} |
|
917 |
||
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
918 |
/* Extra ViewPort Window Stuff */ |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
919 |
static const Widget _extra_view_port_widgets[] = { |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
920 |
{ WWT_CLOSEBOX, RESIZE_NONE, 14, 0, 10, 0, 13, STR_00C5, STR_018B_CLOSE_WINDOW}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
921 |
{ WWT_CAPTION, RESIZE_RIGHT, 14, 11, 287, 0, 13, STR_EXTRA_VIEW_PORT_TITLE, STR_018C_WINDOW_TITLE_DRAG_THIS}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
922 |
{ WWT_STICKYBOX, RESIZE_LR, 14, 288, 299, 0, 13, 0x0, STR_STICKY_BUTTON}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
923 |
{ WWT_PANEL, RESIZE_RB, 14, 0, 299, 14, 233, 0x0, STR_NULL}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
924 |
{ WWT_6, RESIZE_RB, 14, 2, 297, 16, 231, 0x0, STR_NULL}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
925 |
{ WWT_PANEL, RESIZE_TB, 14, 0, 21, 234, 255, 0x2DF, STR_017F_ZOOM_THE_VIEW_IN}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
926 |
{ WWT_PANEL, RESIZE_TB, 14, 22, 43, 234, 255, 0x2E0, STR_0180_ZOOM_THE_VIEW_OUT}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
927 |
{ WWT_PUSHTXTBTN, RESIZE_TB, 14, 44, 171, 234, 255, STR_EXTRA_VIEW_MOVE_MAIN_TO_VIEW,STR_EXTRA_VIEW_MOVE_MAIN_TO_VIEW_TT}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
928 |
{ WWT_PUSHTXTBTN, RESIZE_TB, 14, 172, 298, 234, 255, STR_EXTRA_VIEW_MOVE_VIEW_TO_MAIN,STR_EXTRA_VIEW_MOVE_VIEW_TO_MAIN_TT}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
929 |
{ WWT_PANEL, RESIZE_RTB, 14, 299, 299, 234, 255, 0x0, STR_NULL}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
930 |
{ WWT_PANEL, RESIZE_RTB, 14, 0, 287, 256, 267, 0x0, STR_NULL}, |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
931 |
{ WWT_RESIZEBOX, RESIZE_LRTB, 14, 288, 299, 256, 267, 0x0, STR_RESIZE_BUTTON}, |
176
84990c4b9212
(svn r177) -Fix: padded out Widget code to solve warnings on C99 compiler (Tron)
darkvater
parents:
154
diff
changeset
|
932 |
{ WIDGETS_END}, |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
933 |
}; |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
934 |
|
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
935 |
static void ExtraViewPortWndProc(Window *w, WindowEvent *e) |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
936 |
{ |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
937 |
switch (e->event) { |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
938 |
case WE_CREATE: /* Disable zoom in button */ |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
939 |
w->disabled_state = (1 << 5); |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
940 |
break; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
941 |
case WE_PAINT: |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
942 |
// set the number in the title bar |
534
17ab2f22ff74
(svn r901) Small step in the process to clean up the DPARAM mess:
tron
parents:
507
diff
changeset
|
943 |
SetDParam(0, (w->window_number+1)); |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
944 |
|
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
945 |
DrawWindowWidgets(w); |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
946 |
DrawWindowViewport(w); |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
947 |
break; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
948 |
|
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
949 |
case WE_CLICK: { |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
950 |
switch (e->click.widget) { |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
951 |
case 5: /* zoom in */ |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
952 |
DoZoomInOutWindow(ZOOM_IN, w); |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
953 |
break; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
954 |
case 6: /* zoom out */ |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
955 |
DoZoomInOutWindow(ZOOM_OUT, w); |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
956 |
break; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
957 |
case 7: { /* location button (move main view to same spot as this view) 'Paste Location' */ |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
958 |
Window *w2 = FindWindowById(WC_MAIN_WINDOW, 0); |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
959 |
int x = WP(w, vp_d).scrollpos_x; // Where is the main looking at |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
960 |
int y = WP(w, vp_d).scrollpos_y; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
961 |
|
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
962 |
// set this view to same location. Based on the center, adjusting for zoom |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
963 |
WP(w2, vp_d).scrollpos_x = x - (w2->viewport->virtual_width - w->viewport->virtual_width) / 2; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
964 |
WP(w2, vp_d).scrollpos_y = y - (w2->viewport->virtual_height - w->viewport->virtual_height) / 2; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
965 |
} break; |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
966 |
case 8: { /* inverse location button (move this view to same spot as main view) 'Copy Location' */ |
2548
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2368
diff
changeset
|
967 |
const Window* w2 = FindWindowById(WC_MAIN_WINDOW, 0); |
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2368
diff
changeset
|
968 |
int x = WP(w2, const vp_d).scrollpos_x; |
97ada3bd2702
(svn r3077) static, const, bracing, indentation, 0 -> '\0'/NULL, typos in comments, excess empty lines, minor other changes
tron
parents:
2368
diff
changeset
|
969 |
int y = WP(w2, const vp_d).scrollpos_y; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
970 |
|
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
971 |
WP(w, vp_d).scrollpos_x = x + (w2->viewport->virtual_width - w->viewport->virtual_width) / 2; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
972 |
WP(w, vp_d).scrollpos_y = y + (w2->viewport->virtual_height - w->viewport->virtual_height) / 2; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
973 |
} break; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
974 |
} |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
975 |
} break; |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
976 |
|
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
977 |
case WE_RESIZE: |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
978 |
w->viewport->width += e->sizing.diff.x; |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
979 |
w->viewport->height += e->sizing.diff.y; |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
980 |
|
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
981 |
w->viewport->virtual_width += e->sizing.diff.x; |
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
982 |
w->viewport->virtual_height += e->sizing.diff.y; |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
983 |
break; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
984 |
} |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
985 |
} |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
986 |
|
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
987 |
static const WindowDesc _extra_view_port_desc = { |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
988 |
-1,-1, 300, 268, |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
989 |
WC_EXTRA_VIEW_PORT,0, |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
990 |
WDF_STD_TOOLTIPS | WDF_STD_BTN | WDF_DEF_WIDGET | WDF_UNCLICK_BUTTONS | WDF_STICKY_BUTTON | WDF_RESIZABLE, |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
991 |
_extra_view_port_widgets, |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
992 |
ExtraViewPortWndProc |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
993 |
}; |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
994 |
|
1093
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
tron
parents:
1092
diff
changeset
|
995 |
void ShowExtraViewPortWindow(void) |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
996 |
{ |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
997 |
Window *w, *v; |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
998 |
int i = 0; |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
999 |
|
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1000 |
// find next free window number for extra viewport |
2989 | 1001 |
while (FindWindowById(WC_EXTRA_VIEW_PORT, i) != NULL) i++; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1002 |
|
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
1003 |
w = AllocateWindowDescFront(&_extra_view_port_desc, i); |
2989 | 1004 |
if (w != NULL) { |
867
581154a08a78
(svn r1348) -Feature: resizable windows. Read the comment in window.h to find out
truelight
parents:
856
diff
changeset
|
1005 |
int x, y; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1006 |
// the main window with the main view |
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
1007 |
v = FindWindowById(WC_MAIN_WINDOW, 0); |
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
1008 |
// New viewport start ats (zero,zero) |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1009 |
AssignWindowViewport(w, 3, 17, 294, 214, 0 , 0); |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1010 |
|
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1011 |
// center on same place as main window (zoom is maximum, no adjustment needed) |
1815
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
1012 |
x = WP(v, vp_d).scrollpos_x; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
1013 |
y = WP(v, vp_d).scrollpos_y; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
1014 |
WP(w, vp_d).scrollpos_x = x + (v->viewport->virtual_width - (294)) / 2; |
cfc1399ea8c9
(svn r2319) - Fix: copying/pasting from the extra viewport did not center on what you wanted to see if one of the windows (viewport or main) was zoomed out. Also fix the undisabled-zoom-in button upon creation.
Darkvater
parents:
1516
diff
changeset
|
1015 |
WP(w, vp_d).scrollpos_y = y + (v->viewport->virtual_height - (214)) / 2; |
152
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1016 |
} |
c3964b43943e
(svn r153) -Feature: [1009710] Extra Viewport. In the minimap dropdown menu, open a new viewport to have a quick look at your favorite map-positions. Independent zoom and quick jump to/from viewport (Dribbel)
darkvater
parents:
12
diff
changeset
|
1017 |
} |