OpenTTD Source
20241121-master-g67a0fccfad
|
Handling of water tiles. More...
#include "stdafx.h"
#include "landscape.h"
#include "viewport_func.h"
#include "command_func.h"
#include "town.h"
#include "news_func.h"
#include "depot_base.h"
#include "depot_func.h"
#include "water.h"
#include "industry_map.h"
#include "newgrf_canal.h"
#include "strings_func.h"
#include "vehicle_func.h"
#include "sound_func.h"
#include "company_func.h"
#include "clear_map.h"
#include "tree_map.h"
#include "aircraft.h"
#include "effectvehicle_func.h"
#include "tunnelbridge_map.h"
#include "station_base.h"
#include "ai/ai.hpp"
#include "game/game.hpp"
#include "core/random_func.hpp"
#include "core/backup_type.hpp"
#include "timer/timer_game_calendar.h"
#include "company_base.h"
#include "company_gui.h"
#include "newgrf_generic.h"
#include "industry.h"
#include "water_cmd.h"
#include "landscape_cmd.h"
#include "pathfinder/water_regions.h"
#include "table/strings.h"
#include "safeguards.h"
#include "table/water_land.h"
Go to the source code of this file.
Functions | |
static void | MarkTileDirtyIfCanalOrRiver (TileIndex tile) |
Marks tile dirty if it is a canal or river tile. More... | |
static void | MarkCanalsAndRiversAroundDirty (TileIndex tile) |
Marks the tiles around a tile as dirty, if they are canals or rivers. More... | |
void | ClearNeighbourNonFloodingStates (TileIndex tile) |
Clear non-flooding state of the tiles around a tile. More... | |
CommandCost | CmdBuildShipDepot (DoCommandFlag flags, TileIndex tile, Axis axis) |
Build a ship depot. More... | |
bool | IsPossibleDockingTile (Tile t) |
void | CheckForDockingTile (TileIndex t) |
Mark the supplied tile as a docking tile if it is suitable for docking. More... | |
void | MakeWaterKeepingClass (TileIndex tile, Owner o) |
static CommandCost | RemoveShipDepot (TileIndex tile, DoCommandFlag flags) |
static CommandCost | DoBuildLock (TileIndex tile, DiagDirection dir, DoCommandFlag flags) |
Builds a lock. More... | |
static CommandCost | RemoveLock (TileIndex tile, DoCommandFlag flags) |
Remove a lock. More... | |
CommandCost | CmdBuildLock (DoCommandFlag flags, TileIndex tile) |
Builds a lock. More... | |
static bool | RiverModifyDesertZone (TileIndex tile, void *) |
Callback to create non-desert around a river tile. | |
void | MakeRiverAndModifyDesertZoneAround (TileIndex tile) |
Make a river tile and remove desert directly around it. More... | |
CommandCost | CmdBuildCanal (DoCommandFlag flags, TileIndex tile, TileIndex start_tile, WaterClass wc, bool diagonal) |
Build a piece of canal. More... | |
static CommandCost | ClearTile_Water (TileIndex tile, DoCommandFlag flags) |
bool | IsWateredTile (TileIndex tile, Direction from) |
return true if a tile is a water tile wrt. More... | |
static void | DrawWaterSprite (SpriteID base, uint offset, CanalFeature feature, TileIndex tile) |
Draw a water sprite, potentially with a NewGRF-modified sprite offset. More... | |
static void | DrawWaterEdges (bool canal, uint offset, TileIndex tile) |
Draw canal or river edges. More... | |
static void | DrawSeaWater (TileIndex) |
Draw a plain sea water tile with no edges. | |
static void | DrawCanalWater (TileIndex tile) |
draw a canal styled water tile with dikes around | |
static void | DrawWaterTileStruct (const TileInfo *ti, const DrawTileSeqStruct *dtss, SpriteID base, uint offset, PaletteID palette, CanalFeature feature) |
Draw a build sprite sequence for water tiles. More... | |
static void | DrawWaterLock (const TileInfo *ti) |
Draw a lock tile. | |
static void | DrawWaterDepot (const TileInfo *ti) |
Draw a ship depot tile. | |
static void | DrawRiverWater (const TileInfo *ti) |
void | DrawShoreTile (Slope tileh) |
void | DrawWaterClassGround (const TileInfo *ti) |
static void | DrawTile_Water (TileInfo *ti) |
void | DrawShipDepotSprite (int x, int y, Axis axis, DepotPart part) |
static int | GetSlopePixelZ_Water (TileIndex tile, uint x, uint y, bool) |
static Foundation | GetFoundation_Water (TileIndex, Slope) |
static void | GetTileDesc_Water (TileIndex tile, TileDesc *td) |
static void | FloodVehicle (Vehicle *v) |
Handle the flooding of a vehicle. More... | |
static Vehicle * | FloodVehicleProc (Vehicle *v, void *data) |
Flood a vehicle if we are allowed to flood it, i.e. More... | |
static void | FloodVehicles (TileIndex tile) |
Finds a vehicle to flood. More... | |
FloodingBehaviour | GetFloodingBehaviour (TileIndex tile) |
Returns the behaviour of a tile during flooding. More... | |
static void | DoFloodTile (TileIndex target) |
Floods a tile. | |
static void | DoDryUp (TileIndex tile) |
Drys a tile up. | |
void | TileLoop_Water (TileIndex tile) |
Let a water tile floods its diagonal adjoining tiles called from tunnelbridge_cmd, and by TileLoop_Industry() and TileLoop_Track() More... | |
void | ConvertGroundTilesIntoWaterTiles () |
static TrackStatus | GetTileTrackStatus_Water (TileIndex tile, TransportType mode, uint, DiagDirection) |
static bool | ClickTile_Water (TileIndex tile) |
static void | ChangeTileOwner_Water (TileIndex tile, Owner old_owner, Owner new_owner) |
static VehicleEnterTileStatus | VehicleEnter_Water (Vehicle *, TileIndex, int, int) |
static CommandCost | TerraformTile_Water (TileIndex tile, DoCommandFlag flags, int, Slope) |
Variables | |
static const uint8_t | _flood_from_dirs [] |
Describes from which directions a specific slope can be flooded (if the tile is floodable at all). More... | |
const TileTypeProcs | _tile_type_water_procs |
Handling of water tiles.
Definition in file water_cmd.cpp.
void CheckForDockingTile | ( | TileIndex | t | ) |
Mark the supplied tile as a docking tile if it is suitable for docking.
Tiles surrounding the tile are tested to be docks with correct orientation.
t | Tile to test. |
Definition at line 195 of file water_cmd.cpp.
References OrthogonalTileArea::Add(), DIAGDIR_BEGIN, DIAGDIR_END, Station::docking_station, SpecializedStation< Station, false >::GetByTile(), Industry::GetByTile(), IsDockTile(), IsDockWaterPart(), IsOilRig(), IsTileType(), IsValidTile(), MP_INDUSTRY, MP_STATION, Industry::neutral_station, SetDockingTile(), and TileOffsByDiagDir().
void ClearNeighbourNonFloodingStates | ( | TileIndex | tile | ) |
Clear non-flooding state of the tiles around a tile.
tile | The centre of the tile where other tiles' non-flooding state is cleared. |
Definition at line 97 of file water_cmd.cpp.
References DIR_BEGIN, DIR_END, IsTileType(), IsValidTile(), MP_WATER, SetNonFloodingWaterTile(), and TileOffsByDir().
Referenced by PlantTreesOnTile().
CommandCost CmdBuildCanal | ( | DoCommandFlag | flags, |
TileIndex | tile, | ||
TileIndex | start_tile, | ||
WaterClass | wc, | ||
bool | diagonal | ||
) |
Build a piece of canal.
flags | type of operation |
tile | end tile of stretch-dragging |
start_tile | start tile of stretch-dragging |
wc | waterclass to build. sea and river can only be built in scenario editor |
diagonal | Whether to use the Orthogonal (0) or Diagonal (1) iterator. |
Definition at line 472 of file water_cmd.cpp.
References CMD_ERROR, IsValidWaterClass(), Map::Size(), and WATER_CLASS_CANAL.
CommandCost CmdBuildLock | ( | DoCommandFlag | flags, |
TileIndex | tile | ||
) |
Builds a lock.
flags | type of operation |
tile | tile where to place the lock |
Definition at line 435 of file water_cmd.cpp.
References DoBuildLock(), GetInclinedSlopeDirection(), GetTileSlope(), INVALID_DIAGDIR, and return_cmd_error.
CommandCost CmdBuildShipDepot | ( | DoCommandFlag | flags, |
TileIndex | tile, | ||
Axis | axis | ||
) |
Build a ship depot.
flags | type of operation |
tile | tile where ship depot is built |
axis | depot orientation (Axis) |
Definition at line 112 of file water_cmd.cpp.
References Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_depot_pool >::CanAllocateItem(), CMD_ERROR, EXPENSES_CONSTRUCTION, GetWaterClass(), HasTileWaterGround(), IsBridgeAbove(), IsTileFlat(), IsValidAxis(), return_cmd_error, and TileOffsByAxis().
|
static |
Builds a lock.
tile | Central tile of the lock. |
dir | Uphill direction. |
flags | Operation to perform. |
Definition at line 312 of file water_cmd.cpp.
References CommandCost::AddCost(), EnsureNoVehicleOnGround(), EXPENSES_CONSTRUCTION, CommandCost::Failed(), GetWaterClass(), HasTileWaterGround(), IsWaterTile(), CommandCost::Succeeded(), TileOffsByDiagDir(), and WATER_CLASS_CANAL.
Referenced by CmdBuildLock().
|
static |
Draw canal or river edges.
canal | True if canal edges should be drawn, false for river edges. |
offset | Sprite offset. |
tile | Tile to draw. |
Definition at line 722 of file water_cmd.cpp.
|
static |
Draw a water sprite, potentially with a NewGRF-modified sprite offset.
base | Sprite base. |
offset | Sprite offset. |
feature | The type of sprite that is drawn. |
tile | Tile index to draw. |
Definition at line 707 of file water_cmd.cpp.
|
static |
Draw a build sprite sequence for water tiles.
If buildings are invisible, nothing will be drawn.
ti | Tile info. |
dtss | Sprite sequence to draw. |
base | Base sprite. |
offset | Additional sprite offset. |
palette | Palette to use. |
Definition at line 805 of file water_cmd.cpp.
References IsInvisibilitySet(), DrawTileSeqStruct::IsTerminator(), PalSpriteID::sprite, and TO_BUILDINGS.
|
static |
Handle the flooding of a vehicle.
This sets the vehicle state to crashed, creates a newsitem and dirties the necessary windows.
v | The vehicle to flood. |
Definition at line 1005 of file water_cmd.cpp.
References Vehicle::Crash(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Game::NewEvent(), AI::NewEvent(), Vehicle::owner, SetDParam(), and Vehicle::tile.
Referenced by FloodVehicleProc().
Flood a vehicle if we are allowed to flood it, i.e.
when it is on the ground.
v | The vehicle to test for flooding. |
data | The z of level to flood. |
Definition at line 1023 of file water_cmd.cpp.
References AIR_SHADOW, Station::airport, AirportFTAClass::delta_z, Vehicle::First(), FloodVehicle(), SpecializedStation< Station, false >::GetByTile(), Airport::GetFTA(), GetTileMaxZ(), IsAirportTile(), Vehicle::subtype, Vehicle::tile, BaseVehicle::type, VEH_AIRCRAFT, VEH_ROAD, VEH_TRAIN, Vehicle::vehstatus, VS_CRASHED, and Vehicle::z_pos.
Referenced by FloodVehicles().
|
static |
Finds a vehicle to flood.
It does not find vehicles that are already crashed on bridges, i.e. flooded.
tile | the tile where to find a vehicle to flood |
Definition at line 1061 of file water_cmd.cpp.
References Station::airport, FindVehicleOnPos(), FloodVehicleProc(), GetBridgePixelHeight(), SpecializedStation< Station, false >::GetByTile(), GetOtherBridgeEnd(), IsAirportTile(), and IsBridgeTile().
Referenced by DoFloodTile().
FloodingBehaviour GetFloodingBehaviour | ( | TileIndex | tile | ) |
Returns the behaviour of a tile during flooding.
Definition at line 1092 of file water_cmd.cpp.
References FLOOD_ACTIVE, FLOOD_DRYUP, FLOOD_NONE, GetTileSlope(), GetTileType(), GetWaterClass(), IsCoast(), IsSlopeWithOneCornerRaised(), MP_INDUSTRY, MP_OBJECT, MP_RAILWAY, MP_STATION, MP_WATER, and WATER_CLASS_SEA.
Referenced by CheckRailSlope(), and TileLoop_Water().
return true if a tile is a water tile wrt.
a certain direction.
tile | The tile of interest. |
from | The direction of interest. |
Definition at line 636 of file water_cmd.cpp.
References GetTileType(), GetWaterTileType(), and MP_WATER.
Referenced by CanalScopeResolver::GetVariable().
void MakeRiverAndModifyDesertZoneAround | ( | TileIndex | tile | ) |
Make a river tile and remove desert directly around it.
tile | The tile to change into river and create non-desert around |
Definition at line 454 of file water_cmd.cpp.
References MakeRiver().
Referenced by RiverMakeWider().
|
inlinestatic |
Marks tile dirty if it is a canal or river tile.
Called to avoid glitches when flooding tiles next to canal tile.
tile | tile to check |
Definition at line 75 of file water_cmd.cpp.
References IsCanal(), IsRiver(), IsTileType(), IsValidTile(), MarkTileDirtyByTile(), and MP_WATER.
Referenced by MarkCanalsAndRiversAroundDirty().
|
static |
Remove a lock.
tile | Central tile of the lock. |
flags | Operation to perform. |
Definition at line 390 of file water_cmd.cpp.
References CheckTileOwnership(), DC_EXEC, DirtyCompanyInfrastructureWindows(), EnsureNoVehicleOnGround(), CommandCost::Failed(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem<&_company_pool >::GetIfValid(), GetLockDirection(), GetTileOwner(), GetWaterClass(), Pool< Titem, Tindex, Tgrowth_step, Tmax_size, Tpool_type, Tcache, Tzero >::PoolItem< Tpool >::index, Company::infrastructure, LOCK_DEPOT_TILE_FACTOR, MakeRiver(), OWNER_NONE, CommandCost::Succeeded(), TileOffsByDiagDir(), CompanyInfrastructure::water, and WATER_CLASS_RIVER.
void TileLoop_Water | ( | TileIndex | tile | ) |
Let a water tile floods its diagonal adjoining tiles called from tunnelbridge_cmd, and by TileLoop_Industry() and TileLoop_Track()
tile | the water/shore tile that floods |
Definition at line 1245 of file water_cmd.cpp.
References _flood_from_dirs, AddTileIndexDiffCWrap(), AmbientSoundEffect(), DIR_BEGIN, DIR_END, DoDryUp(), DoFloodTile(), FLOOD_ACTIVE, FLOOD_DRYUP, FLOOD_PASSIVE, GetFloodingBehaviour(), GetFoundationSlope(), GetTreeGround(), HasBit(), INVALID_TILE, IsBuoy(), IsDock(), IsNonFloodingWaterTile(), IsTileType(), IsValidTile(), MP_STATION, MP_TREES, MP_WATER, ReverseDir(), SetNonFloodingWaterTile(), SLOPE_HALFTILE_MASK, SLOPE_STEEP, TileIndexDiffCByDir(), and TREE_GROUND_SHORE.
|
static |
Describes from which directions a specific slope can be flooded (if the tile is floodable at all).
Definition at line 51 of file water_cmd.cpp.
Referenced by TileLoop_Water().
|
extern |
Definition at line 54 of file landscape.cpp.