author | Celestar |
Wed, 08 Dec 2004 15:46:13 +0000 | |
changeset 568 | 6eb7d394fb35 |
parent 543 | e3b43338096b |
child 606 | 0e507bb0f63a |
permissions | -rw-r--r-- |
0 | 1 |
#include "stdafx.h" |
2 |
#include "ttd.h" |
|
507
8aa8100b0b22
(svn r815) Include strings.h only in the files which need it.
tron
parents:
337
diff
changeset
|
3 |
#include "table/strings.h" |
0 | 4 |
#include "window.h" |
568
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
5 |
#include "station.h" |
0 | 6 |
#include "gui.h" |
7 |
#include "viewport.h" |
|
8 |
#include "gfx.h" |
|
337
66647f97e7c0
(svn r513) Merge revisions 402, 416, 417, 478, 479, 511, 512 from map to trunk
tron
parents:
193
diff
changeset
|
9 |
#include "sound.h" |
0 | 10 |
#include "command.h" |
11 |
||
12 |
static void ShowBuildDockStationPicker(); |
|
13 |
static void ShowBuildDocksDepotPicker(); |
|
14 |
||
15 |
static byte _ship_depot_direction; |
|
16 |
||
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
541
diff
changeset
|
17 |
void CcBuildDocks(bool success, uint tile, uint32 p1, uint32 p2) |
0 | 18 |
{ |
19 |
if (success) { |
|
541 | 20 |
SndPlayTileFx(SND_02_SPLAT, tile); |
0 | 21 |
ResetObjectToPlace(); |
22 |
} |
|
23 |
} |
|
24 |
||
543
e3b43338096b
(svn r942) -Merged branch/network back into the trunk
truelight
parents:
541
diff
changeset
|
25 |
void CcBuildCanal(bool success, uint tile, uint32 p1, uint32 p2) |
0 | 26 |
{ |
541 | 27 |
if (success) SndPlayTileFx(SND_02_SPLAT, tile); |
0 | 28 |
} |
29 |
||
30 |
||
31 |
static void PlaceDocks_Dock(uint tile) |
|
32 |
{ |
|
33 |
DoCommandP(tile, 0, 0, CcBuildDocks, CMD_BUILD_DOCK | CMD_AUTO | CMD_MSG(STR_9802_CAN_T_BUILD_DOCK_HERE)); |
|
34 |
} |
|
35 |
||
36 |
static void PlaceDocks_Depot(uint tile) |
|
37 |
{ |
|
38 |
DoCommandP(tile, _ship_depot_direction, 0, CcBuildDocks, CMD_BUILD_SHIP_DEPOT | CMD_AUTO | CMD_MSG(STR_3802_CAN_T_BUILD_SHIP_DEPOT)); |
|
39 |
} |
|
40 |
||
41 |
static void PlaceDocks_Buoy(uint tile) |
|
42 |
{ |
|
43 |
DoCommandP(tile, 0, 0, CcBuildDocks, CMD_BUILD_BUOY | CMD_AUTO | CMD_MSG(STR_9835_CAN_T_POSITION_BUOY_HERE)); |
|
44 |
} |
|
45 |
||
46 |
static void PlaceDocks_DemolishArea(uint tile) |
|
47 |
{ |
|
48 |
VpStartPlaceSizing(tile, VPM_X_AND_Y); |
|
49 |
} |
|
50 |
||
51 |
static void PlaceDocks_BuildCanal(uint tile) |
|
52 |
{ |
|
53 |
VpStartPlaceSizing(tile, VPM_X_OR_Y); |
|
54 |
} |
|
55 |
||
56 |
static void PlaceDocks_BuildLock(uint tile) |
|
57 |
{ |
|
58 |
DoCommandP(tile, 0, 0, CcBuildDocks, CMD_BUILD_LOCK | CMD_AUTO | CMD_MSG(STR_CANT_BUILD_LOCKS)); |
|
59 |
} |
|
60 |
||
61 |
||
62 |
static void BuildDocksClick_Dock(Window *w) |
|
63 |
{ |
|
64 |
||
65 |
if (HandlePlacePushButton(w, 2, 0xE54, 3, PlaceDocks_Dock)) ShowBuildDockStationPicker(); |
|
66 |
} |
|
67 |
||
68 |
static void BuildDocksClick_Depot(Window *w) |
|
69 |
{ |
|
70 |
if (HandlePlacePushButton(w, 3, 0x2D1, 1, PlaceDocks_Depot)) ShowBuildDocksDepotPicker(); |
|
71 |
} |
|
72 |
||
73 |
static void BuildDocksClick_Buoy(Window *w) |
|
74 |
{ |
|
75 |
HandlePlacePushButton(w, 4, 0x2BE, 1, PlaceDocks_Buoy); |
|
76 |
} |
|
77 |
||
78 |
static void BuildDocksClick_Demolish(Window *w) |
|
79 |
{ |
|
80 |
HandlePlacePushButton(w, 5, ANIMCURSOR_DEMOLISH, 1, PlaceDocks_DemolishArea); |
|
81 |
} |
|
82 |
||
83 |
static void BuildDocksClick_Lower(Window *w) |
|
84 |
{ |
|
85 |
HandlePlacePushButton(w, 6, ANIMCURSOR_LOWERLAND, 2, PlaceProc_LowerLand); |
|
86 |
} |
|
87 |
||
88 |
static void BuildDocksClick_Raise(Window *w) |
|
89 |
{ |
|
90 |
HandlePlacePushButton(w, 7, ANIMCURSOR_RAISELAND, 2, PlaceProc_RaiseLand); |
|
91 |
} |
|
92 |
||
93 |
static void BuildDocksClick_Purchase(Window *w) |
|
94 |
{ |
|
95 |
HandlePlacePushButton(w, 8, 0x12B8, 1, PlaceProc_BuyLand); |
|
96 |
} |
|
97 |
||
98 |
static void BuildDocksClick_Canal(Window *w) |
|
99 |
{ |
|
100 |
HandlePlacePushButton(w, 9, SPR_OPENTTD_BASE + 11, 1, PlaceDocks_BuildCanal); |
|
101 |
} |
|
102 |
||
103 |
static void BuildDocksClick_Lock(Window *w) |
|
104 |
{ |
|
105 |
HandlePlacePushButton(w, 10, SPR_OPENTTD_BASE + 64, 1, PlaceDocks_BuildLock); |
|
106 |
} |
|
107 |
||
108 |
typedef void OnButtonClick(Window *w); |
|
109 |
static OnButtonClick * const _build_docks_button_proc[] = { |
|
110 |
BuildDocksClick_Dock, |
|
111 |
BuildDocksClick_Depot, |
|
112 |
BuildDocksClick_Buoy, |
|
113 |
BuildDocksClick_Demolish, |
|
114 |
BuildDocksClick_Lower, |
|
115 |
BuildDocksClick_Raise, |
|
116 |
BuildDocksClick_Purchase, |
|
117 |
BuildDocksClick_Canal, |
|
118 |
BuildDocksClick_Lock, |
|
119 |
}; |
|
120 |
||
121 |
static void BuildDocksToolbWndProc(Window *w, WindowEvent *e) |
|
122 |
{ |
|
123 |
switch(e->event) { |
|
124 |
case WE_PAINT: |
|
125 |
DrawWindowWidgets(w); |
|
126 |
break; |
|
127 |
||
128 |
case WE_CLICK: { |
|
129 |
if (e->click.widget - 2 >= 0) _build_docks_button_proc[e->click.widget - 2](w); |
|
130 |
} break; |
|
131 |
||
132 |
case WE_PLACE_OBJ: |
|
133 |
_place_proc(e->place.tile); |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
134 |
break; |
0 | 135 |
|
136 |
case WE_PLACE_DRAG: { |
|
137 |
VpSelectTilesWithMethod(e->place.pt.x, e->place.pt.y, e->place.userdata); |
|
138 |
return; |
|
139 |
} |
|
140 |
||
141 |
case WE_PLACE_MOUSEUP: |
|
142 |
if (e->click.pt.x != -1) { |
|
143 |
if (e->place.userdata == VPM_X_AND_Y) |
|
144 |
DoCommandP(e->place.tile, e->place.starttile, 0, CcPlaySound10, CMD_CLEAR_AREA | CMD_MSG(STR_00B5_CAN_T_CLEAR_THIS_AREA)); |
|
145 |
else if(e->place.userdata == VPM_X_OR_Y) |
|
146 |
DoCommandP(e->place.tile, e->place.starttile, 0, CcBuildCanal, CMD_BUILD_CANAL | CMD_AUTO | CMD_MSG(STR_CANT_BUILD_CANALS)); |
|
147 |
} |
|
148 |
break; |
|
149 |
||
150 |
case WE_ABORT_PLACE_OBJ: |
|
151 |
w->click_state = 0; |
|
152 |
SetWindowDirty(w); |
|
153 |
||
154 |
w = FindWindowById(WC_BUILD_STATION, 0); |
|
155 |
if (w != NULL) WP(w,def_d).close=true; |
|
156 |
||
157 |
w = FindWindowById(WC_BUILD_DEPOT, 0); |
|
158 |
if (w != NULL) WP(w,def_d).close=true; |
|
159 |
break; |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
160 |
|
0 | 161 |
case WE_PLACE_PRESIZE: { |
162 |
uint tile_from, tile_to; |
|
163 |
||
164 |
tile_from = tile_to = e->place.tile; |
|
165 |
switch(GetTileSlope(tile_from, NULL)) { |
|
166 |
case 3: tile_to += TILE_XY(-1,0); break; |
|
167 |
case 6: tile_to += TILE_XY(0,-1); break; |
|
168 |
case 9: tile_to += TILE_XY(0,1); break; |
|
169 |
case 12:tile_to += TILE_XY(1,0); break; |
|
170 |
} |
|
171 |
VpSetPresizeRange(tile_from, tile_to); |
|
172 |
} break; |
|
173 |
} |
|
174 |
} |
|
175 |
||
176 |
static const Widget _build_docks_toolb_widgets[] = { |
|
177 |
{ WWT_CLOSEBOX, 7, 0, 10, 0, 13, STR_00C5, STR_018B_CLOSE_WINDOW}, |
|
178 |
{ WWT_CAPTION, 7, 11, 197, 0, 13, STR_9801_DOCK_CONSTRUCTION, STR_018C_WINDOW_TITLE_DRAG_THIS}, |
|
179 |
{ WWT_PANEL, 7, 0, 21, 14, 35, 746, STR_981D_BUILD_SHIP_DOCK}, |
|
180 |
{ WWT_PANEL, 7, 22, 43, 14, 35, 748, STR_981E_BUILD_SHIP_DEPOT_FOR_BUILDING}, |
|
181 |
{ WWT_PANEL, 7, 44, 65, 14, 35, 693, STR_9834_POSITION_BUOY_WHICH_CAN}, |
|
182 |
{ WWT_PANEL, 7, 66, 87, 14, 35, 703, STR_018D_DEMOLISH_BUILDINGS_ETC}, |
|
183 |
{ WWT_PANEL, 7, 88, 109, 14, 35, 695, STR_018E_LOWER_A_CORNER_OF_LAND}, |
|
184 |
{ WWT_PANEL, 7, 110, 131, 14, 35, 694, STR_018F_RAISE_A_CORNER_OF_LAND}, |
|
185 |
{ WWT_PANEL, 7, 132, 153, 14, 35, 4791, STR_0329_PURCHASE_LAND_FOR_FUTURE}, |
|
186 |
{ WWT_PANEL, 7, 154, 175, 14, 35, SPR_OPENTTD_BASE+65, STR_BUILD_CANALS_TIP}, |
|
187 |
{ WWT_PANEL, 7, 176, 197, 14, 35, SPR_CANALS_BASE+69, STR_BUILD_LOCKS_TIP}, |
|
176
84990c4b9212
(svn r177) -Fix: padded out Widget code to solve warnings on C99 compiler (Tron)
darkvater
parents:
0
diff
changeset
|
188 |
{ WIDGETS_END}, |
0 | 189 |
}; |
190 |
||
191 |
static const WindowDesc _build_docks_toolbar_desc = { |
|
192 |
640-197, 22, 198, 36, |
|
193 |
WC_BUILD_TOOLBAR,0, |
|
194 |
WDF_STD_TOOLTIPS | WDF_STD_BTN | WDF_DEF_WIDGET, |
|
195 |
_build_docks_toolb_widgets, |
|
196 |
BuildDocksToolbWndProc |
|
197 |
}; |
|
198 |
||
199 |
void ShowBuildDocksToolbar() |
|
200 |
{ |
|
201 |
DeleteWindowById(WC_BUILD_TOOLBAR, 0); |
|
202 |
AllocateWindowDesc(&_build_docks_toolbar_desc); |
|
203 |
} |
|
204 |
||
205 |
static void BuildDockStationWndProc(Window *w, WindowEvent *e) |
|
206 |
{ |
|
568
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
207 |
int rad; |
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
208 |
|
0 | 209 |
switch(e->event) { |
210 |
case WE_PAINT: { |
|
211 |
if (WP(w,def_d).close) |
|
212 |
return; |
|
213 |
DrawWindowWidgets(w); |
|
568
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
214 |
//Add some code for the coverage area eariler or later!! |
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
215 |
if (_patches.modified_catchment) { |
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
216 |
rad = CA_DOCK; |
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
217 |
} else { |
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
218 |
rad = 4; |
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
219 |
} |
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
220 |
|
6eb7d394fb35
(svn r979) Allow more realistically sized catchment areas
Celestar
parents:
543
diff
changeset
|
221 |
DrawStationCoverageAreaText(2, 15, (uint)-1, rad); |
0 | 222 |
} break; |
223 |
||
224 |
case WE_CLICK: { |
|
225 |
if (e->click.widget == 0) { |
|
226 |
ResetObjectToPlace(); |
|
227 |
} |
|
228 |
} break; |
|
229 |
||
230 |
case WE_MOUSELOOP: { |
|
231 |
if (WP(w,def_d).close) { |
|
232 |
DeleteWindow(w); |
|
233 |
return; |
|
234 |
} |
|
235 |
||
236 |
CheckRedrawStationCoverage(w); |
|
237 |
break; |
|
238 |
} |
|
193
0a7025304867
(svn r194) -Codechange: stripping trailing-spaces. Please keep this that way!
truelight
parents:
176
diff
changeset
|
239 |
} |
0 | 240 |
} |
241 |
||
242 |
static const Widget _build_dock_station_widgets[] = { |
|
243 |
{ WWT_CLOSEBOX, 7, 0, 10, 0, 13, STR_00C5, STR_018B_CLOSE_WINDOW}, |
|
244 |
{ WWT_CAPTION, 7, 11, 147, 0, 13, STR_3068_DOCK, STR_018C_WINDOW_TITLE_DRAG_THIS}, |
|
176
84990c4b9212
(svn r177) -Fix: padded out Widget code to solve warnings on C99 compiler (Tron)
darkvater
parents:
0
diff
changeset
|
245 |
{ WWT_PANEL, 7, 0, 147, 14, 45, 0x0, STR_NULL}, |
84990c4b9212
(svn r177) -Fix: padded out Widget code to solve warnings on C99 compiler (Tron)
darkvater
parents:
0
diff
changeset
|
246 |
{ WIDGETS_END}, |
0 | 247 |
}; |
248 |
||
249 |
static const WindowDesc _build_dock_station_desc = { |
|
250 |
-1, -1, 148, 46, |
|
251 |
WC_BUILD_STATION,WC_BUILD_TOOLBAR, |
|
252 |
WDF_STD_TOOLTIPS | WDF_STD_BTN | WDF_DEF_WIDGET, |
|
253 |
_build_dock_station_widgets, |
|
254 |
BuildDockStationWndProc |
|
255 |
}; |
|
256 |
||
257 |
static void ShowBuildDockStationPicker() |
|
258 |
{ |
|
259 |
AllocateWindowDesc(&_build_dock_station_desc); |
|
260 |
} |
|
261 |
||
262 |
static void UpdateDocksDirection() |
|
263 |
{ |
|
264 |
if (_ship_depot_direction != 0) { |
|
265 |
SetTileSelectSize(1, 2); |
|
266 |
} else { |
|
267 |
SetTileSelectSize(2, 1); |
|
268 |
} |
|
269 |
} |
|
270 |
||
271 |
static void BuildDocksDepotWndProc(Window *w, WindowEvent *e) |
|
272 |
{ |
|
273 |
switch(e->event) { |
|
274 |
case WE_PAINT: |
|
275 |
w->click_state = (1<<3) << _ship_depot_direction; |
|
276 |
DrawWindowWidgets(w); |
|
277 |
||
278 |
DrawShipDepotSprite(67, 35, 0); |
|
279 |
DrawShipDepotSprite(35, 51, 1); |
|
280 |
DrawShipDepotSprite(135, 35, 2); |
|
281 |
DrawShipDepotSprite(167, 51, 3); |
|
282 |
return; |
|
283 |
||
284 |
case WE_CLICK: { |
|
285 |
switch(e->click.widget) { |
|
286 |
case 0: |
|
287 |
ResetObjectToPlace(); |
|
288 |
break; |
|
289 |
case 3: |
|
290 |
case 4: |
|
291 |
_ship_depot_direction = e->click.widget - 3; |
|
541 | 292 |
SndPlayFx(SND_15_BEEP); |
0 | 293 |
UpdateDocksDirection(); |
294 |
SetWindowDirty(w); |
|
295 |
break; |
|
296 |
} |
|
297 |
} break; |
|
298 |
||
299 |
case WE_MOUSELOOP: |
|
300 |
if (WP(w,def_d).close) |
|
301 |
DeleteWindow(w); |
|
302 |
break; |
|
303 |
} |
|
304 |
} |
|
305 |
||
306 |
static const Widget _build_docks_depot_widgets[] = { |
|
307 |
{ WWT_CLOSEBOX, 7, 0, 10, 0, 13, STR_00C5, STR_018B_CLOSE_WINDOW}, |
|
308 |
{ WWT_CAPTION, 7, 11, 203, 0, 13, STR_3800_SHIP_DEPOT_ORIENTATION, STR_018C_WINDOW_TITLE_DRAG_THIS}, |
|
176
84990c4b9212
(svn r177) -Fix: padded out Widget code to solve warnings on C99 compiler (Tron)
darkvater
parents:
0
diff
changeset
|
309 |
{ WWT_PANEL, 7, 0, 203, 14, 85, 0x0, STR_NULL}, |
0 | 310 |
{ WWT_PANEL, 14, 3, 100, 17, 82, 0x0, STR_3803_SELECT_SHIP_DEPOT_ORIENTATION}, |
311 |
{ WWT_PANEL, 14, 103, 200, 17, 82, 0x0, STR_3803_SELECT_SHIP_DEPOT_ORIENTATION}, |
|
176
84990c4b9212
(svn r177) -Fix: padded out Widget code to solve warnings on C99 compiler (Tron)
darkvater
parents:
0
diff
changeset
|
312 |
{ WIDGETS_END}, |
0 | 313 |
}; |
314 |
||
315 |
static const WindowDesc _build_docks_depot_desc = { |
|
316 |
-1, -1, 204, 86, |
|
317 |
WC_BUILD_DEPOT,WC_BUILD_TOOLBAR, |
|
318 |
WDF_STD_TOOLTIPS | WDF_STD_BTN | WDF_DEF_WIDGET, |
|
319 |
_build_docks_depot_widgets, |
|
320 |
BuildDocksDepotWndProc |
|
321 |
}; |
|
322 |
||
323 |
||
324 |
static void ShowBuildDocksDepotPicker() |
|
325 |
{ |
|
326 |
AllocateWindowDesc(&_build_docks_depot_desc); |
|
327 |
UpdateDocksDirection(); |
|
328 |
} |
|
329 |
||
330 |
||
331 |
void InitializeDockGui() |
|
332 |
{ |
|
333 |
_ship_depot_direction = 0; |
|
334 |
} |