summaryrefslogtreecommitdiff
path: root/game/client/tf2/c_grenade_rocket.cpp
diff options
context:
space:
mode:
authorFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
committerFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
commit3bf9df6b2785fa6d951086978a3e66f49427166a (patch)
tree2c0f1f0c63c4832882bc93814ebd2c2b1c6224e5 /game/client/tf2/c_grenade_rocket.cpp
downloadarchived-source-engine-2018-hl2-src-master.tar.xz
archived-source-engine-2018-hl2-src-master.zip
Diffstat (limited to 'game/client/tf2/c_grenade_rocket.cpp')
-rw-r--r--game/client/tf2/c_grenade_rocket.cpp83
1 files changed, 83 insertions, 0 deletions
diff --git a/game/client/tf2/c_grenade_rocket.cpp b/game/client/tf2/c_grenade_rocket.cpp
new file mode 100644
index 0000000..3db4497
--- /dev/null
+++ b/game/client/tf2/c_grenade_rocket.cpp
@@ -0,0 +1,83 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+// $NoKeywords: $
+//=============================================================================//
+#include "cbase.h"
+#include "hud.h"
+#include "particles_simple.h"
+
+//-----------------------------------------------------------------------------
+// Purpose: Client side entity for the antipersonnel grenades
+//-----------------------------------------------------------------------------
+class C_GrenadeRocket : public C_BaseAnimating
+{
+ DECLARE_CLASS( C_GrenadeRocket, C_BaseAnimating );
+public:
+ DECLARE_CLIENTCLASS();
+
+ C_GrenadeRocket();
+
+ virtual void OnDataChanged( DataUpdateType_t updateType );
+ virtual void ClientThink( void );
+
+public:
+ C_GrenadeRocket( const C_GrenadeRocket & );
+};
+
+IMPLEMENT_CLIENTCLASS_DT(C_GrenadeRocket, DT_GrenadeRocket, CGrenadeRocket)
+END_RECV_TABLE()
+
+//-----------------------------------------------------------------------------
+// Purpose:
+//-----------------------------------------------------------------------------
+C_GrenadeRocket::C_GrenadeRocket( void )
+{
+}
+
+//-----------------------------------------------------------------------------
+// Purpose:
+//-----------------------------------------------------------------------------
+void C_GrenadeRocket::OnDataChanged( DataUpdateType_t updateType )
+{
+ BaseClass::OnDataChanged( updateType );
+
+ // Only think when sapping
+ SetNextClientThink( CLIENT_THINK_ALWAYS );
+}
+
+//-----------------------------------------------------------------------------
+// Purpose: Spawn effects if I'm sapping
+//-----------------------------------------------------------------------------
+void C_GrenadeRocket::ClientThink( void )
+{
+ // Fire smoke puffs out the side
+ CSmartPtr<CSimpleEmitter> pSmokeEmitter = CSimpleEmitter::Create( "C_GrenadeRocket::Effect" );
+ pSmokeEmitter->SetSortOrigin( GetAbsOrigin() );
+ int iSmokeClouds = random->RandomInt(1,2);
+ for ( int i = 0; i < iSmokeClouds; i++ )
+ {
+ SimpleParticle *pParticle = (SimpleParticle *) pSmokeEmitter->AddParticle( sizeof(SimpleParticle), g_Mat_DustPuff[1], GetAbsOrigin() );
+ if ( pParticle == NULL )
+ return;
+
+ pParticle->m_flLifetime = 0.0f;
+ pParticle->m_flDieTime = random->RandomFloat( 0.1f, 0.3f );
+
+ pParticle->m_uchStartSize = 10;
+ pParticle->m_uchEndSize = pParticle->m_uchStartSize + 2;
+
+ pParticle->m_vecVelocity = GetAbsVelocity();
+ pParticle->m_uchStartAlpha = 255;
+ pParticle->m_uchEndAlpha = 64;
+ pParticle->m_flRoll = random->RandomFloat( 180, 360 );
+ pParticle->m_flRollDelta = random->RandomFloat( -1, 1 );
+
+ pParticle->m_uchColor[0] = 50;
+ pParticle->m_uchColor[1] = 250;
+ pParticle->m_uchColor[2] = 50;
+ }
+}
+
+