//========= Copyright Valve Corporation, All rights reserved. ============// // // Purpose: // // $NoKeywords: $ //=============================================================================// #ifndef ENV_HEADCRABCANISTER_SHARED_H #define ENV_HEADCRABCANISTER_SHARED_H #ifdef _WIN32 #pragma once #endif #include "vstdlib/random.h" #include "mathlib/vector.h" #include "utlvector.h" #include "networkvar.h" //============================================================================= // // Shared HeadcrabCanister Class // class CEnvHeadcrabCanisterShared { DECLARE_CLASS_NOBASE( CEnvHeadcrabCanisterShared ); DECLARE_EMBEDDED_NETWORKVAR(); DECLARE_SIMPLE_DATADESC(); public: CEnvHeadcrabCanisterShared(); // Initialization. void InitInWorld( float flLaunchTime, const Vector &vecStartPosition, const QAngle &vecStartAngles, const Vector &vecDirection, const Vector &vecImpactPosition, bool bLaunchedFromWithinWorld = false ); void InitInSkybox( float flLaunchTime, const Vector &vecStartPosition, const QAngle &vecStartAngles, const Vector &vecDirection, const Vector &vecImpactPosition, const Vector &vecSkyboxOrigin, float flSkyboxScale ); // Returns the position of the object at a given time. void GetPositionAtTime( float flTime, Vector &vecPosition, QAngle &vecAngles ); // Returns whether or not the object is the the skybox bool IsInSkybox( ); // Returns the time at which it enters the world float GetEnterWorldTime() const; // Convert from skybox to world void ConvertFromSkyboxToWorld(); // Did we impact? bool DidImpact( float flTime ) const; public: // The objects initial parametric conditions. CNetworkVector( m_vecStartPosition ); CNetworkVector( m_vecEnterWorldPosition ); CNetworkVector( m_vecDirection ); CNetworkQAngle( m_vecStartAngles ); CNetworkVar( float, m_flFlightTime ); CNetworkVar( float, m_flFlightSpeed ); CNetworkVar( float, m_flLaunchTime ); CNetworkVar( float, m_flInitialZSpeed ); CNetworkVar( float, m_flZAcceleration ); CNetworkVar( float, m_flHorizSpeed ); CNetworkVar( bool, m_bLaunchedFromWithinWorld ); CNetworkVector( m_vecParabolaDirection ); // The time at which the canister enters the skybox CNetworkVar( float, m_flWorldEnterTime ); // Skybox data CNetworkVector( m_vecSkyboxOrigin ); CNetworkVar( float, m_flSkyboxScale ); CNetworkVar( bool, m_bInSkybox ); private: float m_flLaunchHeight; // Calculate the enter time. (called from Init) void CalcEnterTime( const Vector &vecTriggerMins, const Vector &vecTriggerMaxs ); friend class CEnvHeadcrabCanister; friend class C_EnvHeadcrabCanister; }; /* //============================================================================= // // HeadcrabCanister Factory Interface // abstract_class IHeadcrabCanisterFactory { public: virtual void CreateHeadcrabCanister( int nID, int iType, const Vector &vecPosition, const Vector &vecDirection, float flSpeed, float flStartTime, float flDamageRadius, const Vector &vecTriggerMins, const Vector &vecTriggerMaxs ) = 0; }; //============================================================================= // // Shared HeadcrabCanister Spawner Class // class CEnvHeadcrabCanisterSpawnerShared { public: DECLARE_CLASS_NOBASE( CEnvHeadcrabCanisterSpawnerShared ); DECLARE_EMBEDDED_NETWORKVAR(); //------------------------------------------------------------------------- // Initialization. //------------------------------------------------------------------------- CEnvHeadcrabCanisterSpawnerShared(); void Init( IHeadcrabCanisterFactory *pFactory, int nRandomSeed, float flTime, const Vector &vecMinBounds, const Vector &vecMaxBounds, const Vector &vecTriggerMins, const Vector &vecTriggerMaxs ); //------------------------------------------------------------------------- // Method to generate HeadcrabCanisters. // Time passed in here is global time, not delta time. // The function returns the time at which it must be called again. //------------------------------------------------------------------------- float HeadcrabCanisterThink( float flTime ); //------------------------------------------------------------------------- // Add HeadcrabCanister target data, used to determine HeadcrabCanister travel direction. //------------------------------------------------------------------------- void AddToTargetList( const Vector &vecPosition, float flRadius ); // Debugging! int GetRandomInt( int nMin, int nMax ); float GetRandomFloat( float flMin, float flMax ); public: // Factory. IHeadcrabCanisterFactory *m_pFactory; // HeadcrabCanister creation factory. int m_nHeadcrabCanisterCount; // Number of HeadcrabCanisters created - used as IDs // Initial spawner data. CNetworkVar( float, m_flStartTime ); // Start time. CNetworkVar( int, m_nRandomSeed ); // The random number stream seed. CNetworkVar( int, m_iHeadcrabCanisterType ); // Type of HeadcrabCanister. float m_flHeadcrabCanisterDamageRadius; // HeadcrabCanister damage radius. CNetworkVar( bool, m_bSkybox ); // Is the spawner in the skybox? CNetworkVar( float, m_flMinSpawnTime ); // Spawn time - Min CNetworkVar( float, m_flMaxSpawnTime ); // Max CNetworkVar( int, m_nMinSpawnCount ); // Number of HeadcrabCanisters to spawn - Min CNetworkVar( int, m_nMaxSpawnCount ); // Max CNetworkVector( m_vecMinBounds ); // Spawner volume (space) - Min CNetworkVector( m_vecMaxBounds ); // Max CNetworkVar( float, m_flMinSpeed ); // HeadcrabCanister speed - Min CNetworkVar( float, m_flMaxSpeed ); // Max CNetworkVector( m_vecTriggerMins ); // World Bounds (Trigger) in 3D Skybox - Min CNetworkVector( m_vecTriggerMaxs ); // Max Vector m_vecTriggerCenter; // Generated data. int m_nRandomCallCount; // Debug! Keep track of number steam calls. float m_flNextSpawnTime; // Next HeadcrabCanister spawn time (random). CUniformRandomStream m_NumberStream; // Used to generate random numbers. // Use "Targets" to determine HeadcrabCanister direction(s). struct HeadcrabCanistertarget_t { Vector m_vecPosition; float m_flRadius; }; CUtlVector<HeadcrabCanistertarget_t> m_aTargets; }; */ #endif // ENV_HEADCRAB_CANISTER_SHARED_H