From ad0dc6dc877d763cf1773cf6b07d523b738eb2a6 Mon Sep 17 00:00:00 2001 From: Jonathan G Rennison Date: Fri, 15 Apr 2022 11:47:57 +0100 Subject: [PATCH] Add road stops flag to disable drawing catenary --- docs/newgrf-roadstops-nml.html | 2 ++ docs/newgrf-roadstops.html | 6 ++++-- src/newgrf_extension.cpp | 2 +- src/newgrf_roadstop.h | 1 + src/road_cmd.cpp | 12 +++++++----- src/station_cmd.cpp | 10 ++++++---- 6 files changed, 21 insertions(+), 12 deletions(-) diff --git a/docs/newgrf-roadstops-nml.html b/docs/newgrf-roadstops-nml.html index 03bfc9d97e..27298adb81 100644 --- a/docs/newgrf-roadstops-nml.html +++ b/docs/newgrf-roadstops-nml.html @@ -78,6 +78,8 @@ Animation callback requires random bits in variable extra_callback_info1.

RST_GENERAL_FLAG_NO_ONE_WAY_OVERLAY
Do not show one way road overlay sprites, this should only be set if different graphics are provided for the different one-way states using the one_way_info variable.

+

RST_GENERAL_FLAG_NO_CATENARY
+ Do not show catenary graphics. (This only takes effect from road_stops version 2).

minimum_bridge_heightArray of 6 items [0..255, ...]Minimum clearances required for a bridge for each of the 6 views/rotations (or 0 to not allow any bridge). Values are given in height level units (1 level == 8px). disallowed_bridge_pillarsArray of 6 items [bitmask(RST_BRIDGE_PILLAR_FLAG_, ...), ...] diff --git a/docs/newgrf-roadstops.html b/docs/newgrf-roadstops.html index 959e50e187..3fe9d73944 100644 --- a/docs/newgrf-roadstops.html +++ b/docs/newgrf-roadstops.html @@ -19,8 +19,9 @@

A subset of the functionality listed below is also supported in a fork of NML, see the associated NML road stops and NML additions documents for more details.

NewGRFs which use this feature SHOULD use the feature testing mechanism to check whether the road stop feature and/or feature ID mapping is supported.

NewGRFs which use this feature MUST use the feature ID mapping mechanism to map the non-standard NewGRF road stop feature to a local feature ID.

-

This feature is indicated by the feature name: road_stops, version 1.
- The feature name to use for feature ID mapping is road_stops.

+

This feature is indicated by the feature name: road_stops, version 1.
+ The feature name to use for feature ID mapping is road_stops.
+ Features/properties/variables which require a higher version will indicate the required version. Unless indicated otherwise these will fall back to doing nothing on versions which do not support them.

Actions: @@ -149,6 +150,7 @@ BitValueMeaning 01Callback 141 needs random bits in variable 10 12Do not show one way road overlay sprites, this should only be set if different graphics are provided for the different one-way states using bits 0..1 of variable 50. + 24Do not catenary graphics.
This requires road_stops, version 2. The default value is 0 (no flags enabled).

diff --git a/src/newgrf_extension.cpp b/src/newgrf_extension.cpp index 74ddbb1275..43ba27d9ee 100644 --- a/src/newgrf_extension.cpp +++ b/src/newgrf_extension.cpp @@ -51,7 +51,7 @@ extern const GRFFeatureInfo _grf_feature_list[] = { GRFFeatureInfo("action0_object_edge_foundation_mode", 2), GRFFeatureInfo("action0_object_flood_resistant", 1), GRFFeatureInfo("action0_object_viewport_map_tile_type", 1), - GRFFeatureInfo("road_stops", 1), + GRFFeatureInfo("road_stops", 2), GRFFeatureInfo(), }; diff --git a/src/newgrf_roadstop.h b/src/newgrf_roadstop.h index 3763b731c2..19dfbd10a7 100644 --- a/src/newgrf_roadstop.h +++ b/src/newgrf_roadstop.h @@ -66,6 +66,7 @@ DECLARE_ENUM_AS_BIT_SET(RoadStopDrawMode) enum RoadStopSpecFlags { RSF_CB141_RANDOM_BITS, ///< Callback 141 needs random bits. RSF_NO_ONE_WAY_OVERLAY, ///< Do not show one-way road overlays. + RSF_NO_CATENARY, ///< Do not show catenary. }; enum RoadStopSpecIntlFlags { diff --git a/src/road_cmd.cpp b/src/road_cmd.cpp index 6519e6297c..d112bf259a 100644 --- a/src/road_cmd.cpp +++ b/src/road_cmd.cpp @@ -2115,7 +2115,7 @@ static SpriteID GetRoadGroundSprite(const TileInfo *ti, Roadside roadside, const * Draw ground sprite and road pieces * @param ti TileInfo */ -void DrawRoadBits(TileInfo *ti, RoadBits road, RoadBits tram, Roadside roadside, bool snow_or_desert) +void DrawRoadBits(TileInfo *ti, RoadBits road, RoadBits tram, Roadside roadside, bool snow_or_desert, bool draw_catenary) { const bool is_road_tile = IsTileType(ti->tile, MP_ROAD); @@ -2154,8 +2154,10 @@ void DrawRoadBits(TileInfo *ti, RoadBits road, RoadBits tram, Roadside roadside, return; } - /* Draw road, tram catenary */ - DrawRoadCatenary(ti); + if (draw_catenary) { + /* Draw road, tram catenary */ + DrawRoadCatenary(ti); + } /* Return if full detail is disabled, or we are zoomed fully out. */ if (!HasBit(_display_opt, DO_FULL_DETAIL) || _cur_dpi->zoom > ZOOM_LVL_DETAIL) return; @@ -2184,12 +2186,12 @@ void DrawRoadBits(TileInfo *ti, RoadBits road, RoadBits tram, Roadside roadside, void DrawRoadBitsRoad(TileInfo *ti) { - DrawRoadBits(ti, GetRoadBits(ti->tile, RTT_ROAD), GetRoadBits(ti->tile, RTT_TRAM), GetRoadside(ti->tile), IsOnSnow(ti->tile)); + DrawRoadBits(ti, GetRoadBits(ti->tile, RTT_ROAD), GetRoadBits(ti->tile, RTT_TRAM), GetRoadside(ti->tile), IsOnSnow(ti->tile), true); } void DrawRoadBitsTunnelBridge(TileInfo *ti) { - DrawRoadBits(ti, GetCustomBridgeHeadRoadBits(ti->tile, RTT_ROAD), GetCustomBridgeHeadRoadBits(ti->tile, RTT_TRAM), ROADSIDE_PAVED, false); + DrawRoadBits(ti, GetCustomBridgeHeadRoadBits(ti->tile, RTT_ROAD), GetCustomBridgeHeadRoadBits(ti->tile, RTT_TRAM), ROADSIDE_PAVED, false, true); } /** Tile callback function for rendering a road tile to the screen */ diff --git a/src/station_cmd.cpp b/src/station_cmd.cpp index 4506b0ff6e..449f2fa772 100644 --- a/src/station_cmd.cpp +++ b/src/station_cmd.cpp @@ -3450,10 +3450,10 @@ draw_default_foundation: } } else if (IsRoadWaypointTile(ti->tile)) { RoadBits bits = GetRoadStopDir(ti->tile) == DIAGDIR_NE ? ROAD_X : ROAD_Y; - extern void DrawRoadBits(TileInfo *ti, RoadBits road, RoadBits tram, Roadside roadside, bool snow_or_desert); + extern void DrawRoadBits(TileInfo *ti, RoadBits road, RoadBits tram, Roadside roadside, bool snow_or_desert, bool draw_catenary); DrawRoadBits(ti, GetRoadTypeRoad(ti->tile) != INVALID_ROADTYPE ? bits : ROAD_NONE, GetRoadTypeTram(ti->tile) != INVALID_ROADTYPE ? bits : ROAD_NONE, - GetRoadWaypointRoadside(ti->tile), IsRoadWaypointOnSnowOrDesert(ti->tile)); + GetRoadWaypointRoadside(ti->tile), IsRoadWaypointOnSnowOrDesert(ti->tile), false); } else { if (layout != nullptr) { /* Sprite layout which needs preprocessing */ @@ -3559,8 +3559,10 @@ draw_default_foundation: } } - /* Draw road, tram catenary */ - DrawRoadCatenary(ti); + if (stopspec == nullptr || !HasBit(stopspec->flags, RSF_NO_CATENARY)) { + /* Draw road, tram catenary */ + DrawRoadCatenary(ti); + } } if (IsRailWaypoint(ti->tile)) {