diff options
| author | FluorescentCIAAfricanAmerican <[email protected]> | 2020-04-22 12:56:21 -0400 |
|---|---|---|
| committer | FluorescentCIAAfricanAmerican <[email protected]> | 2020-04-22 12:56:21 -0400 |
| commit | 3bf9df6b2785fa6d951086978a3e66f49427166a (patch) | |
| tree | 2c0f1f0c63c4832882bc93814ebd2c2b1c6224e5 /game/server/tf/tf_extra_map_entity.h | |
| download | archived-source-engine-2018-hl2-src-master.tar.xz archived-source-engine-2018-hl2-src-master.zip | |
Diffstat (limited to 'game/server/tf/tf_extra_map_entity.h')
| -rw-r--r-- | game/server/tf/tf_extra_map_entity.h | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/game/server/tf/tf_extra_map_entity.h b/game/server/tf/tf_extra_map_entity.h new file mode 100644 index 0000000..ac2ccc8 --- /dev/null +++ b/game/server/tf/tf_extra_map_entity.h @@ -0,0 +1,82 @@ +//========= Copyright Valve Corporation, All rights reserved. ============// +// +// Purpose: +// +//=============================================================================// +#ifndef EXTRA_MAP_ENTITY_H +#define EXTRA_MAP_ENTITY_H + +#ifdef _WIN32 +#pragma once +#endif + +#include "baseanimating.h" + +#define ENTITYROCKET_DEFAULT_MODEL "models/props_skybox/grocket_001.mdl" +#define ENTITYCARRIER_DEFAULT_MODEL "models/props_skybox/skybox_carrier.mdl" +#define ENTITYSIGN_DEFAULT_MODEL "models/props_teaser/update_billboard001.mdl" +#define ENTITYSAUCER_DEFAULT_MODEL "models/props_teaser/saucer.mdl" + +DECLARE_AUTO_LIST( IExtraMapEntityAutoList ); +class CExtraMapEntity : public CBaseAnimating, public IExtraMapEntityAutoList +{ + DECLARE_CLASS( CExtraMapEntity, CBaseAnimating ); +public: + DECLARE_DATADESC(); + + virtual void Spawn( void ) OVERRIDE; + virtual void Precache( void ) OVERRIDE; + virtual const char *GetDefaultModel( void ) = 0; + virtual void PrepareModelName( const char *szModelName ); + + static void SpawnExtraModel( void ); + + virtual bool ShouldAnimate( void ){ return false; } + void AnimThink( void ); + +protected: + virtual void Precache_Internal( void ); + +private: + static const char *ValidateKeyName( const char *pszEntName ); +}; + +class CExtraMapEntity_Rocket : public CExtraMapEntity +{ + DECLARE_CLASS( CExtraMapEntity_Rocket, CExtraMapEntity ); +public: + virtual void Spawn( void ) OVERRIDE; + virtual const char *GetDefaultModel( void ) OVERRIDE { return ENTITYROCKET_DEFAULT_MODEL; } + +protected: + virtual void Precache_Internal( void ) OVERRIDE; +}; + +class CExtraMapEntity_Carrier : public CExtraMapEntity +{ + DECLARE_CLASS( CExtraMapEntity_Carrier, CExtraMapEntity ); +public: + virtual void Spawn( void ) OVERRIDE; + virtual const char *GetDefaultModel( void ) OVERRIDE { return ENTITYCARRIER_DEFAULT_MODEL; } +}; + +class CExtraMapEntity_Sign : public CExtraMapEntity +{ + DECLARE_CLASS( CExtraMapEntity_Sign, CExtraMapEntity ); +public: + virtual void Spawn( void ) OVERRIDE; + virtual const char *GetDefaultModel( void ) OVERRIDE { return ENTITYSIGN_DEFAULT_MODEL; } +}; + +class CExtraMapEntity_Saucer : public CExtraMapEntity +{ + DECLARE_CLASS( CExtraMapEntity_Saucer, CExtraMapEntity ); +public: + virtual void Spawn( void ) OVERRIDE; + virtual const char *GetDefaultModel( void ) OVERRIDE{ return ENTITYSAUCER_DEFAULT_MODEL; } + virtual bool ShouldAnimate( void ){ return true; } +}; + +#endif // EXTRA_MAP_ENTITY_H + + |