diff options
author | frosch <frosch@openttd.org> | 2010-10-16 15:36:51 +0000 |
---|---|---|
committer | frosch <frosch@openttd.org> | 2010-10-16 15:36:51 +0000 |
commit | 3edf041a432e2a1e02989dfe2a00a0885df6d2e0 (patch) | |
tree | eb6fdd0d92f75dd7a8c8040033af3847d0558190 | |
parent | 01be182880f0392e6890b3a8ce4da67ef67d4a14 (diff) | |
download | openttd-3edf041a432e2a1e02989dfe2a00a0885df6d2e0.tar.xz |
(svn r20946) -Codechange: Add helper function to draw pillar columns.
-rw-r--r-- | src/tunnelbridge_cmd.cpp | 34 |
1 files changed, 25 insertions, 9 deletions
diff --git a/src/tunnelbridge_cmd.cpp b/src/tunnelbridge_cmd.cpp index 190f7b91e..cf3209139 100644 --- a/src/tunnelbridge_cmd.cpp +++ b/src/tunnelbridge_cmd.cpp @@ -840,6 +840,26 @@ static inline void DrawPillar(const PalSpriteID *psid, int x, int y, int z, int } /** + * Draw two bridge pillars (north and south). + * @param z_bottom Bottom Z + * @param z_top Top Z + * @param psid Pillarsprite + * @param x Pillar X + * @param y Pillar Y + * @param w Bounding box size in X direction + * @param h Bounding box size in Y direction + * @return Reached Z at the bottom + */ +static int DrawPillarColumn(int z_bottom, int z_top, const PalSpriteID *psid, int x, int y, int w, int h) +{ + int cur_z; + for (cur_z = z_top; cur_z >= z_bottom; cur_z -= TILE_HEIGHT) { + DrawPillar(psid, x, y, cur_z, w, h); + } + return cur_z; +} + +/** * Draws the pillars under high bridges. * * @param psid Image and palette of a bridge pillar. @@ -888,16 +908,12 @@ static void DrawBridgePillars(const PalSpriteID *psid, const TileInfo *ti, Axis int x_back = x - back_pillar_offset[axis]; int y_back = y - back_pillar_offset[OtherAxis(axis)]; - for (int cur_z = z_bridge; cur_z >= front_height || cur_z >= back_height; cur_z -= TILE_HEIGHT) { - /* Draw front facing pillar */ - if (cur_z >= front_height) { - DrawPillar(psid, x, y, cur_z, w, h); - } + /* Draw front pillars */ + DrawPillarColumn(front_height, z_bridge, psid, x, y, w, h); - /* Draw back facing pillar, but not the highest part directly under the bridge-floor */ - if (drawfarpillar && cur_z >= back_height && cur_z < z_bridge - (int)TILE_HEIGHT) { - DrawPillar(psid, x_back, y_back, cur_z, w, h); - } + /* Draw back pillars, skip top two parts, which are hidden by the bridge */ + if (drawfarpillar) { + DrawPillarColumn(back_height, z_bridge - 2 * (int)TILE_HEIGHT, psid, x_back, y_back, w, h); } } |