OpenTTD Source 20250524-master-gc366e6a48e
tile_cmd.h
Go to the documentation of this file.
1/*
2 * This file is part of OpenTTD.
3 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
4 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
5 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
6 */
7
10#ifndef TILE_CMD_H
11#define TILE_CMD_H
12
13#include "command_type.h"
14#include "vehicle_type.h"
15#include "cargo_type.h"
16#include "track_type.h"
17#include "tile_map.h"
19
20enum class VehicleEnterTileState : uint8_t {
24};
25
27
29struct TileInfo {
30 int x;
31 int y;
34 int z;
35};
36
38struct TileDesc {
40 uint64_t dparam = 0;
41 std::array<Owner, 4> owner{};
42 std::array<StringID, 4> owner_type{};
49 std::optional<std::string> grf = std::nullopt;
51 uint16_t rail_speed = 0;
53 uint16_t road_speed = 0;
55 uint16_t tram_speed = 0;
56 std::optional<bool> town_can_upgrade = std::nullopt;
57};
58
63typedef void DrawTileProc(TileInfo *ti);
64
76typedef int GetSlopeZProc(TileIndex tile, uint x, uint y, bool ground_vehicle);
77typedef CommandCost ClearTileProc(TileIndex tile, DoCommandFlags flags);
78
85typedef void AddAcceptedCargoProc(TileIndex tile, CargoArray &acceptance, CargoTypes &always_accepted);
86
92typedef void GetTileDescProc(TileIndex tile, TileDesc &td);
93
107typedef TrackStatus GetTileTrackStatusProc(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side);
108
114typedef void AddProducedCargoProc(TileIndex tile, CargoArray &produced);
115typedef bool ClickTileProc(TileIndex tile);
116typedef void AnimateTileProc(TileIndex tile);
117typedef void TileLoopProc(TileIndex tile);
118typedef void ChangeTileOwnerProc(TileIndex tile, Owner old_owner, Owner new_owner);
119
120typedef VehicleEnterTileStates VehicleEnterTileProc(Vehicle *v, TileIndex tile, int x, int y);
121typedef Foundation GetFoundationProc(TileIndex tile, Slope tileh);
122
138typedef CommandCost TerraformTileProc(TileIndex tile, DoCommandFlags flags, int z_new, Slope tileh_new);
139
146 GetSlopeZProc *get_slope_z_proc;
147 ClearTileProc *clear_tile_proc;
151 ClickTileProc *click_tile_proc;
152 AnimateTileProc *animate_tile_proc;
153 TileLoopProc *tile_loop_proc;
154 ChangeTileOwnerProc *change_tile_owner_proc;
156 VehicleEnterTileProc *vehicle_enter_tile_proc;
157 GetFoundationProc *get_foundation_proc;
159};
160
161extern const TileTypeProcs * const _tile_type_procs[16];
162
163TrackStatus GetTileTrackStatus(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side = INVALID_DIAGDIR);
165void ChangeTileOwner(TileIndex tile, Owner old_owner, Owner new_owner);
166void GetTileDesc(TileIndex tile, TileDesc &td);
167
168inline void AddAcceptedCargo(TileIndex tile, CargoArray &acceptance, CargoTypes *always_accepted)
169{
171 if (proc == nullptr) return;
172 CargoTypes dummy = 0; // use dummy bitmask so there don't need to be several 'always_accepted != nullptr' checks
173 proc(tile, acceptance, always_accepted == nullptr ? dummy : *always_accepted);
174}
175
176inline void AddProducedCargo(TileIndex tile, CargoArray &produced)
177{
179 if (proc == nullptr) return;
180 proc(tile, produced);
181}
182
188inline bool MayAnimateTile(TileIndex tile)
189{
190 return _tile_type_procs[GetTileType(tile)]->animate_tile_proc != nullptr;
191}
192
193inline void AnimateTile(TileIndex tile)
194{
195 AnimateTileProc *proc = _tile_type_procs[GetTileType(tile)]->animate_tile_proc;
196 assert(proc != nullptr);
197 proc(tile);
198}
199
200inline bool ClickTile(TileIndex tile)
201{
202 ClickTileProc *proc = _tile_type_procs[GetTileType(tile)]->click_tile_proc;
203 if (proc == nullptr) return false;
204 return proc(tile);
205}
206
207#endif /* TILE_CMD_H */
Types related to cargoes...
Common return value for all commands.
Enum-as-bit-set wrapper.
static constexpr TimerGame< struct Calendar >::Date INVALID_DATE
Representation of an invalid date.
Types related to commands.
DiagDirection
Enumeration for diagonal directions.
@ INVALID_DIAGDIR
Flag for an invalid DiagDirection.
Slope
Enumeration for the slope-type.
Definition slope_type.h:48
Foundation
Enumeration for Foundations.
Definition slope_type.h:93
uint32_t StringID
Numeric value that represents a string, independent of the selected language.
Class for storing amounts of cargo.
Definition cargo_type.h:113
Tile description for the 'land area information' tool.
Definition tile_cmd.h:38
uint16_t rail_speed
Speed limit of rail (bridges and track)
Definition tile_cmd.h:51
std::optional< std::string > grf
newGRF used for the tile contents
Definition tile_cmd.h:49
StringID station_name
Type of station within the class.
Definition tile_cmd.h:45
StringID str
Description of the tile.
Definition tile_cmd.h:39
TimerGameCalendar::Date build_date
Date of construction of tile contents.
Definition tile_cmd.h:43
std::array< Owner, 4 > owner
Name of the owner(s)
Definition tile_cmd.h:41
uint64_t dparam
Parameter of the str string.
Definition tile_cmd.h:40
StringID airport_class
Name of the airport class.
Definition tile_cmd.h:46
StringID airport_name
Name of the airport.
Definition tile_cmd.h:47
uint16_t tram_speed
Speed limit of tram (bridges and track)
Definition tile_cmd.h:55
StringID roadtype
Type of road on the tile.
Definition tile_cmd.h:52
StringID tramtype
Type of tram on the tile.
Definition tile_cmd.h:54
StringID railtype
Type of rail on the tile.
Definition tile_cmd.h:50
uint16_t road_speed
Speed limit of road (bridges and track)
Definition tile_cmd.h:53
std::array< StringID, 4 > owner_type
Type of each owner.
Definition tile_cmd.h:42
std::optional< bool > town_can_upgrade
Whether the town can upgrade this house during town growth.
Definition tile_cmd.h:56
StringID airport_tile_name
Name of the airport tile.
Definition tile_cmd.h:48
StringID station_class
Class of station.
Definition tile_cmd.h:44
Tile information, used while rendering the tile.
Definition tile_cmd.h:29
int z
Height.
Definition tile_cmd.h:34
int x
X position of the tile in unit coordinates.
Definition tile_cmd.h:30
Slope tileh
Slope of the tile.
Definition tile_cmd.h:32
TileIndex tile
Tile index.
Definition tile_cmd.h:33
int y
Y position of the tile in unit coordinates.
Definition tile_cmd.h:31
Set of callback functions for performing tile operations of a given tile type.
Definition tile_cmd.h:144
VehicleEnterTileProc * vehicle_enter_tile_proc
Called when a vehicle enters a tile.
Definition tile_cmd.h:156
DrawTileProc * draw_tile_proc
Called to render the tile and its contents to the screen.
Definition tile_cmd.h:145
AddAcceptedCargoProc * add_accepted_cargo_proc
Adds accepted cargo of the tile to cargo array supplied as parameter.
Definition tile_cmd.h:148
GetTileDescProc * get_tile_desc_proc
Get a description of a tile (for the 'land area information' tool)
Definition tile_cmd.h:149
TerraformTileProc * terraform_tile_proc
Called when a terraforming operation is about to take place.
Definition tile_cmd.h:158
GetTileTrackStatusProc * get_tile_track_status_proc
Get available tracks and status of a tile.
Definition tile_cmd.h:150
AddProducedCargoProc * add_produced_cargo_proc
Adds produced cargo of the tile to cargo array supplied as parameter.
Definition tile_cmd.h:155
ClickTileProc * click_tile_proc
Called when tile is clicked.
Definition tile_cmd.h:151
Vehicle data structure.
VehicleEnterTileState
Definition tile_cmd.h:20
@ EnteredStation
The vehicle entered a station.
@ CannotEnter
The vehicle cannot enter the tile.
@ EnteredWormhole
The vehicle either entered a bridge, tunnel or depot tile (this includes the last tile of the bridge/...
void AddProducedCargoProc(TileIndex tile, CargoArray &produced)
Tile callback function signature for obtaining the produced cargo of a tile.
Definition tile_cmd.h:114
void DrawTileProc(TileInfo *ti)
Tile callback function signature for drawing a tile and its contents to the screen.
Definition tile_cmd.h:63
VehicleEnterTileStates VehicleEnterTile(Vehicle *v, TileIndex tile, int x, int y)
Call the tile callback function for a vehicle entering a tile.
Definition vehicle.cpp:1808
void ChangeTileOwner(TileIndex tile, Owner old_owner, Owner new_owner)
Change the owner of a tile.
void AddAcceptedCargoProc(TileIndex tile, CargoArray &acceptance, CargoTypes &always_accepted)
Tile callback function signature for obtaining cargo acceptance of a tile.
Definition tile_cmd.h:85
int GetSlopeZProc(TileIndex tile, uint x, uint y, bool ground_vehicle)
Tile callback function signature for obtaining the world Z coordinate of a given point of a tile.
Definition tile_cmd.h:76
TrackStatus GetTileTrackStatusProc(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side)
Tile callback function signature for getting the possible tracks that can be taken on a given tile by...
Definition tile_cmd.h:107
const TileTypeProcs *const _tile_type_procs[16]
Tile callback functions for each type of tile.
Definition landscape.cpp:66
CommandCost TerraformTileProc(TileIndex tile, DoCommandFlags flags, int z_new, Slope tileh_new)
Tile callback function signature of the terraforming callback.
Definition tile_cmd.h:138
void GetTileDescProc(TileIndex tile, TileDesc &td)
Tile callback function signature for obtaining a tile description.
Definition tile_cmd.h:92
bool MayAnimateTile(TileIndex tile)
Test if a tile may be animated.
Definition tile_cmd.h:188
TrackStatus GetTileTrackStatus(TileIndex tile, TransportType mode, uint sub_mode, DiagDirection side=INVALID_DIAGDIR)
Returns information about trackdirs and signal states.
Map writing/reading functions for tiles.
static debug_inline TileType GetTileType(Tile tile)
Get the tiletype of a given tile.
Definition tile_map.h:96
Definition of the game-calendar-timer.
All types related to tracks.
TransportType
Available types of transport.
Types related to vehicles.