2010-02-22 14:15:28 +00:00
|
|
|
/*
|
|
|
|
* This file is part of OpenTTD.
|
|
|
|
* OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
|
|
|
|
* OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
* See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file newgrf_airporttiles.h NewGRF handling of airport tiles. */
|
|
|
|
|
|
|
|
#ifndef NEWGRF_AIRPORTTILES_H
|
|
|
|
#define NEWGRF_AIRPORTTILES_H
|
|
|
|
|
2010-02-22 14:16:19 +00:00
|
|
|
#include "airport.h"
|
2010-02-22 14:15:28 +00:00
|
|
|
#include "station_map.h"
|
2010-08-26 15:31:40 +00:00
|
|
|
#include "newgrf_animation_type.h"
|
2010-02-22 14:15:48 +00:00
|
|
|
#include "newgrf_commons.h"
|
2012-11-10 20:42:19 +00:00
|
|
|
#include "newgrf_spritegroup.h"
|
2018-03-11 13:19:41 +00:00
|
|
|
#include "station_base.h"
|
2012-11-10 20:42:19 +00:00
|
|
|
|
2012-11-10 20:46:39 +00:00
|
|
|
/** Scope resolver for handling the tiles of an airport. */
|
2012-11-10 20:42:19 +00:00
|
|
|
struct AirportTileScopeResolver : public ScopeResolver {
|
2019-04-10 21:07:06 +00:00
|
|
|
struct Station *st; ///< %Station of the airport for which the callback is run, or \c nullptr for build gui.
|
2012-11-10 20:42:19 +00:00
|
|
|
byte airport_id; ///< Type of airport for which the callback is run.
|
|
|
|
TileIndex tile; ///< Tile for the callback, only valid for airporttile callbacks.
|
2020-01-26 12:45:51 +00:00
|
|
|
const AirportTileSpec *ats;
|
2012-11-10 20:42:19 +00:00
|
|
|
|
2018-03-11 13:19:41 +00:00
|
|
|
/**
|
|
|
|
* Constructor of the scope resolver specific for airport tiles.
|
|
|
|
* @param ats Specification of the airport tiles.
|
|
|
|
* @param tile %Tile for the callback, only valid for airporttile callbacks.
|
2019-04-10 21:07:06 +00:00
|
|
|
* @param st Station of the airport for which the callback is run, or \c nullptr for build gui.
|
2018-03-11 13:19:41 +00:00
|
|
|
*/
|
|
|
|
AirportTileScopeResolver(ResolverObject &ro, const AirportTileSpec *ats, TileIndex tile, Station *st)
|
2020-01-26 12:45:51 +00:00
|
|
|
: ScopeResolver(ro), st(st), tile(tile), ats(ats)
|
2018-03-11 13:19:41 +00:00
|
|
|
{
|
2019-04-10 21:07:06 +00:00
|
|
|
assert(st != nullptr);
|
2018-03-11 13:19:41 +00:00
|
|
|
this->airport_id = st->airport.type;
|
|
|
|
}
|
2012-11-10 20:42:19 +00:00
|
|
|
|
2019-03-03 22:25:13 +00:00
|
|
|
uint32 GetRandomBits() const override;
|
|
|
|
uint32 GetVariable(byte variable, uint32 parameter, bool *available) const override;
|
2012-11-10 20:42:19 +00:00
|
|
|
};
|
|
|
|
|
2012-11-10 20:46:39 +00:00
|
|
|
/** Resolver for tiles of an airport. */
|
2012-11-10 20:42:19 +00:00
|
|
|
struct AirportTileResolverObject : public ResolverObject {
|
2012-11-10 20:46:39 +00:00
|
|
|
AirportTileScopeResolver tiles_scope; ///< Scope resolver for the tiles.
|
2012-11-10 20:42:19 +00:00
|
|
|
|
|
|
|
AirportTileResolverObject(const AirportTileSpec *ats, TileIndex tile, Station *st,
|
|
|
|
CallbackID callback = CBID_NO_CALLBACK, uint32 callback_param1 = 0, uint32 callback_param2 = 0);
|
|
|
|
|
2019-03-03 22:25:13 +00:00
|
|
|
ScopeResolver *GetScope(VarSpriteGroupScope scope = VSG_SCOPE_SELF, byte relative = 0) override
|
2012-11-10 20:42:19 +00:00
|
|
|
{
|
|
|
|
switch (scope) {
|
|
|
|
case VSG_SCOPE_SELF: return &tiles_scope;
|
2012-11-10 20:45:59 +00:00
|
|
|
default: return ResolverObject::GetScope(scope, relative);
|
2012-11-10 20:42:19 +00:00
|
|
|
}
|
|
|
|
}
|
2020-01-26 12:45:51 +00:00
|
|
|
|
|
|
|
GrfSpecFeature GetFeature() const override;
|
|
|
|
uint32 GetDebugID() const override;
|
2012-11-10 20:42:19 +00:00
|
|
|
};
|
2010-02-22 14:15:28 +00:00
|
|
|
|
|
|
|
/**
|
2013-01-08 22:46:42 +00:00
|
|
|
* Defines the data structure of each individual tile of an airport.
|
2010-02-22 14:15:28 +00:00
|
|
|
*/
|
|
|
|
struct AirportTileSpec {
|
2010-08-26 15:31:40 +00:00
|
|
|
AnimationInfo animation; ///< Information about the animation.
|
2010-02-22 14:17:17 +00:00
|
|
|
StringID name; ///< Tile Subname string, land information on this tile will give you "AirportName (TileSubname)"
|
2010-08-26 11:18:32 +00:00
|
|
|
uint8 callback_mask; ///< Bitmask telling which grf callback is set
|
2010-02-22 14:16:19 +00:00
|
|
|
uint8 animation_special_flags; ///< Extra flags to influence the animation
|
2010-02-22 14:15:48 +00:00
|
|
|
bool enabled; ///< entity still available (by default true). newgrf can disable it, though
|
|
|
|
GRFFileProps grf_prop; ///< properties related the the grf file
|
|
|
|
|
2010-02-22 14:15:28 +00:00
|
|
|
static const AirportTileSpec *Get(StationGfx gfx);
|
2010-08-26 16:53:06 +00:00
|
|
|
static const AirportTileSpec *GetByTile(TileIndex tile);
|
2010-02-22 14:15:48 +00:00
|
|
|
|
|
|
|
static void ResetAirportTiles();
|
|
|
|
|
|
|
|
private:
|
|
|
|
static AirportTileSpec tiles[NUM_AIRPORTTILES];
|
|
|
|
|
|
|
|
friend void AirportTileOverrideManager::SetEntitySpec(const AirportTileSpec *airpts);
|
2010-02-22 14:15:28 +00:00
|
|
|
};
|
|
|
|
|
2010-02-22 14:16:57 +00:00
|
|
|
StationGfx GetTranslatedAirportTileID(StationGfx gfx);
|
|
|
|
void AnimateAirportTile(TileIndex tile);
|
|
|
|
void AirportTileAnimationTrigger(Station *st, TileIndex tile, AirpAnimationTrigger trigger, CargoID cargo_type = CT_INVALID);
|
|
|
|
void AirportAnimationTrigger(Station *st, AirpAnimationTrigger trigger, CargoID cargo_type = CT_INVALID);
|
2010-02-22 14:16:41 +00:00
|
|
|
bool DrawNewAirportTile(TileInfo *ti, Station *st, StationGfx gfx, const AirportTileSpec *airts);
|
|
|
|
|
2010-02-22 14:15:28 +00:00
|
|
|
#endif /* NEWGRF_AIRPORTTILES_H */
|