diff options
author | glx <glx@openttd.org> | 2007-12-21 22:11:55 +0000 |
---|---|---|
committer | glx <glx@openttd.org> | 2007-12-21 22:11:55 +0000 |
commit | 1b53dbf9cc91f99db84a81c1f7cfa4ed8a6a7779 (patch) | |
tree | 7feb58eb84790d15316c0e21f6240bf81baeabb7 | |
parent | 18e96ab49f854c395b2192cc32cab7d45b8aaeaa (diff) | |
download | openttd-1b53dbf9cc91f99db84a81c1f7cfa4ed8a6a7779.tar.xz |
(svn r11679) -Add: [newgrf] support for station vars 67 and 68
-rw-r--r-- | src/newgrf_commons.cpp | 4 | ||||
-rw-r--r-- | src/newgrf_station.cpp | 28 |
2 files changed, 32 insertions, 0 deletions
diff --git a/src/newgrf_commons.cpp b/src/newgrf_commons.cpp index af7cbda9f..227b9fe9d 100644 --- a/src/newgrf_commons.cpp +++ b/src/newgrf_commons.cpp @@ -13,6 +13,7 @@ #include "newgrf.h" #include "newgrf_commons.h" #include "tile_map.h" +#include "station_map.h" /** Constructor of generic class * @param offset end of original data for this entity. i.e: houses = 110 @@ -277,6 +278,9 @@ TileIndex GetNearbyTile(byte parameter, TileIndex tile) if (x >= 8) x -= 16; if (y >= 8) y -= 16; + /* Swap width and height depending on axis for railway stations */ + if (IsRailwayStationTile(tile) && GetRailStationAxis(tile) == AXIS_X) Swap(x, y); + /* Make sure we never roam outside of the map */ return TILE_MASK(tile + TileDiffXY(x, y)); } diff --git a/src/newgrf_station.cpp b/src/newgrf_station.cpp index 07502a139..876a28139 100644 --- a/src/newgrf_station.cpp +++ b/src/newgrf_station.cpp @@ -439,6 +439,34 @@ static uint32 StationGetVariable(const ResolverObject *object, byte variable, by /* Variables which use the parameter */ /* Variables 0x60 to 0x65 are handled separately below */ + case 0x67: { // Land info of nearby tiles + Axis axis = GetRailStationAxis(tile); + + if (parameter != 0) tile = GetNearbyTile(parameter, tile); // only perform if it is required + byte tile_type = GetTerrainType(tile) << 2 | (IsTileType(tile, MP_WATER) ? 1 : 0) << 1; + + uint z; + Slope tileh = GetTileSlope(tile, &z); + bool swap = (axis == AXIS_Y && HasBit(tileh, 0) != HasBit(tileh, 2)); + return GetTileType(tile) << 24 | z << 16 | tile_type << 8 | (tileh ^ (swap ? 5 : 0)); + } + + case 0x68: { // Station info of nearby tiles + TileIndex nearby_tile = GetNearbyTile(parameter, tile); + + if (!IsRailwayStationTile(nearby_tile)) return 0xFFFFFFFF; + + uint32 grfid = st->speclist[GetCustomStationSpecIndex(tile)].grfid; + bool perpendicular = GetRailStationAxis(tile) != GetRailStationAxis(nearby_tile); + bool same_station = st->TileBelongsToRailStation(nearby_tile); + uint32 res = GB(GetStationGfx(nearby_tile), 1, 2) << 12 | !!perpendicular << 11 | !!same_station << 10; + + if (IsCustomStationSpecIndex(nearby_tile)) { + const StationSpecList ssl = GetStationByTile(nearby_tile)->speclist[GetCustomStationSpecIndex(nearby_tile)]; + res |= 1 << (ssl.grfid != grfid ? 9 : 8) | ssl.localidx; + } + return res; + } /* General station properties */ case 0x82: return 50; |