Modified source engine (2017) developed by valve and leaked in 2020. Not for commercial purporses
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

135 lines
3.9 KiB

//========= Copyright © 1996-2005, Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $Workfile: $
// $Date: $
//
//-----------------------------------------------------------------------------
// $Log: $
//
// $NoKeywords: $
//=============================================================================//
#include "cbase.h"
#include "basetempentity.h"
#include "te_basebeam.h"
// memdbgon must be the last include file in a .cpp file!!!
#include "tier0/memdbgon.h"
extern int g_sModelIndexSmoke; // (in combatweapon.cpp) holds the index for the smoke cloud
//-----------------------------------------------------------------------------
// Purpose: Dispatches a beam ring between two entities
//-----------------------------------------------------------------------------
class CTEBeamRing : public CTEBaseBeam
{
public:
DECLARE_CLASS( CTEBeamRing, CTEBaseBeam );
DECLARE_SERVERCLASS();
CTEBeamRing( const char *name );
virtual ~CTEBeamRing( void );
virtual void Test( const Vector& current_origin, const QAngle& current_angles );
public:
CNetworkVar( int, m_nStartEntity );
CNetworkVar( int, m_nEndEntity );
};
//-----------------------------------------------------------------------------
// Purpose:
// Input : *name -
//-----------------------------------------------------------------------------
CTEBeamRing::CTEBeamRing( const char *name ) :
CTEBaseBeam( name )
{
m_nStartEntity = 0;
m_nEndEntity = 0;
}
//-----------------------------------------------------------------------------
// Purpose:
//-----------------------------------------------------------------------------
CTEBeamRing::~CTEBeamRing( void )
{
}
//-----------------------------------------------------------------------------
// Purpose:
// Input : *current_origin -
// *current_angles -
//-----------------------------------------------------------------------------
void CTEBeamRing::Test( const Vector& current_origin, const QAngle& current_angles )
{
m_nStartEntity = 1;
m_nEndEntity = 0;
m_nModelIndex = g_sModelIndexSmoke;
m_nStartFrame = 0;
m_nFrameRate = 2;
m_fLife = 10.0;
m_fWidth = 2.0;
m_fAmplitude = 1;
r = 255;
g = 255;
b = 0;
a = 127;
m_nSpeed = 5;
CBroadcastRecipientFilter filter;
Create( filter, 0.0 );
}
IMPLEMENT_SERVERCLASS_ST( CTEBeamRing, DT_TEBeamRing)
SendPropInt( SENDINFO(m_nStartEntity), MAX_EDICT_BITS, SPROP_UNSIGNED ),
SendPropInt( SENDINFO(m_nEndEntity), MAX_EDICT_BITS, SPROP_UNSIGNED ),
END_SEND_TABLE()
// Singleton to fire TEBeamRing objects
static CTEBeamRing g_TEBeamRing( "BeamRing" );
//-----------------------------------------------------------------------------
// Purpose:
// Input : msg_dest -
// delay -
// *origin -
// *recipient -
// int start -
// end -
// modelindex -
// startframe -
// framerate -
// msg_dest -
// delay -
// origin -
// recipient -
//-----------------------------------------------------------------------------
void TE_BeamRing( IRecipientFilter& filter, float delay,
int start, int end, int modelindex, int haloindex, int startframe, int framerate,
float life, float width, int spread, float amplitude, int r, int g, int b, int a, int speed, int flags )
{
g_TEBeamRing.m_nStartEntity = (start & 0x0FFF) | ((1 & 0xF)<<12);
g_TEBeamRing.m_nEndEntity = (end & 0x0FFF) | ((1 & 0xF)<<12);
g_TEBeamRing.m_nModelIndex = modelindex;
g_TEBeamRing.m_nHaloIndex = haloindex;
g_TEBeamRing.m_nStartFrame = startframe;
g_TEBeamRing.m_nFrameRate = framerate;
g_TEBeamRing.m_fLife = life;
g_TEBeamRing.m_fWidth = width;
g_TEBeamRing.m_fEndWidth = width;
g_TEBeamRing.m_nFadeLength = 0;
g_TEBeamRing.m_fAmplitude = amplitude;
g_TEBeamRing.m_nSpeed = speed;
g_TEBeamRing.r = r;
g_TEBeamRing.g = g;
g_TEBeamRing.b = b;
g_TEBeamRing.a = a;
g_TEBeamRing.m_nFlags = flags;
// Send it over the wire
g_TEBeamRing.Create( filter, delay );
}