summaryrefslogtreecommitdiff
path: root/src/rail_cmd.cpp
diff options
context:
space:
mode:
authorfrosch <frosch@openttd.org>2010-01-14 22:56:54 +0000
committerfrosch <frosch@openttd.org>2010-01-14 22:56:54 +0000
commited83388faa6936c96cdc389a8f9d8bee30e9ad84 (patch)
tree10808808941bbd6520e93ee51460075a5d554476 /src/rail_cmd.cpp
parentf89d6bea0ef8d198027c7bcaed5c457aaa228330 (diff)
downloadopenttd-ed83388faa6936c96cdc389a8f9d8bee30e9ad84.tar.xz
(svn r18802) -Codechange: Deduplicate drawing-code for depots and stations/waypoints.
Diffstat (limited to 'src/rail_cmd.cpp')
-rw-r--r--src/rail_cmd.cpp37
1 files changed, 2 insertions, 35 deletions
diff --git a/src/rail_cmd.cpp b/src/rail_cmd.cpp
index f2f2832b8..00b2a30bf 100644
--- a/src/rail_cmd.cpp
+++ b/src/rail_cmd.cpp
@@ -1944,8 +1944,6 @@ static void DrawTile_Track(TileInfo *ti)
} else {
/* draw depot */
const DrawTileSprites *dts;
- const DrawTileSeqStruct *dtss;
- uint32 relocation;
SpriteID pal = PAL_NONE;
if (ti->tileh != SLOPE_FLAT) DrawFoundation(ti, FOUNDATION_LEVELED);
@@ -1957,8 +1955,6 @@ static void DrawTile_Track(TileInfo *ti)
dts = &_depot_gfx_table[GetRailDepotDirection(ti->tile)];
}
- relocation = rti->total_offset;
-
image = dts->ground.sprite;
if (image != SPR_FLAT_GRASS_TILE) image += rti->total_offset;
@@ -1985,37 +1981,8 @@ static void DrawTile_Track(TileInfo *ti)
if (HasCatenaryDrawn(GetRailType(ti->tile))) DrawCatenary(ti);
- foreach_draw_tile_seq(dtss, dts->seq) {
- SpriteID image = dtss->image.sprite;
- SpriteID pal = dtss->image.pal;
-
- /* Stop drawing sprite sequence once we meet a sprite that doesn't have to be opaque */
- if (IsInvisibilitySet(TO_BUILDINGS) && !HasBit(image, SPRITE_MODIFIER_OPAQUE)) return;
-
- /* Unlike stations, our default waypoint has no variation for
- * different railtype, so don't use the railtype offset if
- * no relocation is set */
- if (HasBit(image, SPRITE_MODIFIER_USE_OFFSET)) {
- image += rti->total_offset;
- } else {
- image += relocation;
- }
-
- pal = SpriteLayoutPaletteTransform(image, pal, _drawtile_track_palette);
-
- if ((byte)dtss->delta_z != 0x80) {
- AddSortableSpriteToDraw(
- image, pal,
- ti->x + dtss->delta_x, ti->y + dtss->delta_y,
- dtss->size_x, dtss->size_y,
- dtss->size_z, ti->z + dtss->delta_z,
- !HasBit(image, SPRITE_MODIFIER_OPAQUE) && IsTransparencySet(TO_BUILDINGS)
- );
- } else {
- /* For stations and original spritelayouts delta_x and delta_y are signed */
- AddChildSpriteScreen(image, pal, dtss->delta_x, dtss->delta_y, !HasBit(image, SPRITE_MODIFIER_OPAQUE) && IsTransparencySet(TO_BUILDINGS));
- }
- }
+ /* No NewGRF depots, so no relocation */
+ DrawStationTileSeq(ti, dts, TO_BUILDINGS, rti->total_offset, 0, _drawtile_track_palette);
}
DrawBridgeMiddle(ti);
}