hlsdk-portable/dlls/poke646/firetrail.cpp

113 lines
2.9 KiB
C++
Raw Normal View History

2016-08-28 00:39:01 +05:00
/***
*
* Copyright (c) 1996-2002, Valve LLC. All rights reserved.
*
* This product contains software technology licensed from Id
* Software, Inc. ("Id Technology"). Id Technology (c) 1996 Id Software, Inc.
* All Rights Reserved.
*
* Use, distribution, and modification of this source code and/or resulting
* object code is restricted to non-commercial enhancements to products from
* Valve LLC. All other use, distribution, or modification is prohibited
* without written permission from Valve LLC.
*
****/
#include "extdll.h"
#include "util.h"
#include "cbase.h"
#include "decals.h"
#include "explode.h"
#include "effects.h"
// Fire Trail
class CFireTrail : public CBaseEntity
{
public:
2020-04-09 02:07:42 +05:00
void Spawn( void );
void Think( void );
void Touch( CBaseEntity *pOther );
2016-08-28 00:39:01 +05:00
int ObjectCaps(void) { return FCAP_DONT_SAVE; }
int Save( CSave &save );
int Restore( CRestore &restore );
static TYPEDESCRIPTION m_SaveData[];
private:
int m_spriteScale; // what's the exact fireball sprite scale?
};
2020-04-09 02:07:42 +05:00
LINK_ENTITY_TO_CLASS( fire_trail, CFireTrail )
TYPEDESCRIPTION CFireTrail::m_SaveData[] =
{
DEFINE_FIELD( CFireTrail, m_spriteScale, FIELD_INTEGER ),
2016-08-28 00:39:01 +05:00
};
IMPLEMENT_SAVERESTORE( CFireTrail, CBaseEntity )
2016-08-28 00:39:01 +05:00
void CFireTrail::Spawn( void )
2016-08-28 00:39:01 +05:00
{
2020-04-09 02:07:42 +05:00
pev->velocity = RANDOM_FLOAT( 100.0f, 150.0f ) * pev->angles;
if( RANDOM_LONG( 0, 1 ) )
2020-04-09 02:07:42 +05:00
pev->velocity.x += RANDOM_FLOAT(-300.0f, -100.0f);
else
2020-04-09 02:07:42 +05:00
pev->velocity.x += RANDOM_FLOAT(100.0f, 300.0f);
if( RANDOM_LONG( 0, 1 ) )
2020-04-09 02:07:42 +05:00
pev->velocity.y += RANDOM_FLOAT(-300.0f, -100.0f);
else
2020-04-09 02:07:42 +05:00
pev->velocity.y += RANDOM_FLOAT(100.0f, 300.0f);
if( pev->velocity.z >= 0 )
2020-04-09 02:07:42 +05:00
pev->velocity.z += 200.0f;
2016-08-28 00:39:01 +05:00
else
2020-04-09 02:07:42 +05:00
pev->velocity.z -= 200.0f;
m_spriteScale = RANDOM_LONG( 7, 13 );
2016-08-28 00:39:01 +05:00
pev->movetype = MOVETYPE_BOUNCE;
2020-04-09 02:07:42 +05:00
pev->gravity = 0.5f;
pev->nextthink = gpGlobals->time + 0.1f;
2016-08-28 00:39:01 +05:00
pev->solid = SOLID_NOT;
2020-04-09 02:07:42 +05:00
SET_MODEL( edict(), "models/grenade.mdl" ); // Need a model, just use the grenade, we don't draw it anyway
UTIL_SetSize( pev, g_vecZero, g_vecZero );
2016-08-28 00:39:01 +05:00
pev->effects |= EF_NODRAW;
2020-04-09 02:07:42 +05:00
pev->speed = RANDOM_FLOAT( 0.5f, 1.5f );
2016-08-28 00:39:01 +05:00
pev->maxspeed = pev->speed;
pev->angles = g_vecZero;
}
2020-04-09 02:07:42 +05:00
void CFireTrail::Think( void )
2016-08-28 00:39:01 +05:00
{
MESSAGE_BEGIN( MSG_PAS, SVC_TEMPENTITY, pev->origin );
WRITE_BYTE( TE_EXPLOSION);
WRITE_COORD( pev->origin.x );
WRITE_COORD( pev->origin.y );
WRITE_COORD( pev->origin.z );
WRITE_SHORT( g_sModelIndexFireball );
WRITE_BYTE( (BYTE)( m_spriteScale * pev->speed ) ); // scale * 10
WRITE_BYTE( 15 ); // framerate
WRITE_BYTE( TE_EXPLFLAG_NOSOUND );
MESSAGE_END();
2016-08-28 00:39:01 +05:00
2020-04-09 02:07:42 +05:00
pev->speed -= 0.1f;
if( pev->speed > 0 )
pev->nextthink = gpGlobals->time + 0.1f;
2016-08-28 00:39:01 +05:00
else
2020-04-09 02:07:42 +05:00
UTIL_Remove( this );
2016-08-28 00:39:01 +05:00
pev->flags &= ~FL_ONGROUND;
}
2020-04-09 02:07:42 +05:00
void CFireTrail::Touch( CBaseEntity *pOther )
2016-08-28 00:39:01 +05:00
{
2020-04-09 02:07:42 +05:00
if( pev->flags & FL_ONGROUND )
pev->velocity = pev->velocity * 0.1f;
2016-08-28 00:39:01 +05:00
else
2020-04-09 02:07:42 +05:00
pev->velocity = pev->velocity * 0.6f;
2016-08-28 00:39:01 +05:00
2020-04-09 02:07:42 +05:00
if( ( pev->velocity.x * pev->velocity.x + pev->velocity.y * pev->velocity.y ) < 10.0f )
2016-08-28 00:39:01 +05:00
pev->speed = 0;
2017-12-25 01:25:40 +05:00
}