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.

137 lines
4.3 KiB

5 years ago
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $Workfile: $
// $Date: $
// $NoKeywords: $
//===========================================================================//
#include "cbase.h"
#include "c_basetempentity.h"
#include "c_te_legacytempents.h"
#include "tempent.h"
#include "tier1/KeyValues.h"
#include "toolframework_client.h"
#include "tier0/vprof.h"
// memdbgon must be the last include file in a .cpp file!!!
#include "tier0/memdbgon.h"
//-----------------------------------------------------------------------------
// Purpose: Sprite TE
//-----------------------------------------------------------------------------
class C_TESprite : public C_BaseTempEntity
{
public:
DECLARE_CLASS( C_TESprite, C_BaseTempEntity );
DECLARE_CLIENTCLASS();
C_TESprite( void );
virtual ~C_TESprite( void );
virtual void PostDataUpdate( DataUpdateType_t updateType );
public:
Vector m_vecOrigin;
int m_nModelIndex;
float m_fScale;
int m_nBrightness;
};
//-----------------------------------------------------------------------------
// Networking
//-----------------------------------------------------------------------------
IMPLEMENT_CLIENTCLASS_EVENT_DT(C_TESprite, DT_TESprite, CTESprite)
RecvPropVector( RECVINFO(m_vecOrigin)),
RecvPropInt( RECVINFO(m_nModelIndex)),
RecvPropFloat( RECVINFO(m_fScale )),
RecvPropInt( RECVINFO(m_nBrightness)),
END_RECV_TABLE()
//-----------------------------------------------------------------------------
// Purpose:
//-----------------------------------------------------------------------------
C_TESprite::C_TESprite( void )
{
m_vecOrigin.Init();
m_nModelIndex = 0;
m_fScale = 0;
m_nBrightness = 0;
}
//-----------------------------------------------------------------------------
// Purpose:
//-----------------------------------------------------------------------------
C_TESprite::~C_TESprite( void )
{
}
//-----------------------------------------------------------------------------
// Recording
//-----------------------------------------------------------------------------
static inline void RecordSprite( const Vector& start, int nModelIndex,
float flScale, int nBrightness )
{
if ( !ToolsEnabled() )
return;
if ( clienttools->IsInRecordingMode() )
{
const model_t* pModel = (nModelIndex != 0) ? modelinfo->GetModel( nModelIndex ) : NULL;
const char *pModelName = pModel ? modelinfo->GetModelName( pModel ) : "";
KeyValues *msg = new KeyValues( "TempEntity" );
msg->SetInt( "te", TE_SPRITE_SINGLE );
msg->SetString( "name", "TE_Sprite" );
msg->SetFloat( "time", gpGlobals->curtime );
msg->SetFloat( "originx", start.x );
msg->SetFloat( "originy", start.y );
msg->SetFloat( "originz", start.z );
msg->SetString( "model", pModelName );
msg->SetFloat( "scale", flScale );
msg->SetInt( "brightness", nBrightness );
ToolFramework_PostToolMessage( HTOOLHANDLE_INVALID, msg );
msg->deleteThis();
}
}
//-----------------------------------------------------------------------------
// Purpose:
//-----------------------------------------------------------------------------
void C_TESprite::PostDataUpdate( DataUpdateType_t updateType )
{
VPROF( "C_TESprite::PostDataUpdate" );
float a = ( 1.0 / 255.0 ) * m_nBrightness;
tempents->TempSprite( m_vecOrigin, vec3_origin, m_fScale, m_nModelIndex, kRenderTransAdd, 0, a, 0, FTENT_SPRANIMATE );
RecordSprite( m_vecOrigin, m_nModelIndex, m_fScale, m_nBrightness );
}
void TE_Sprite( IRecipientFilter& filter, float delay,
const Vector* pos, int modelindex, float size, int brightness )
{
float a = ( 1.0 / 255.0 ) * brightness;
tempents->TempSprite( *pos, vec3_origin, size, modelindex, kRenderTransAdd, 0, a, 0, FTENT_SPRANIMATE );
RecordSprite( *pos, modelindex, size, brightness );
}
void TE_Sprite( IRecipientFilter& filter, float delay, KeyValues *pKeyValues )
{
Vector vecOrigin, vecDirection;
vecOrigin.x = pKeyValues->GetFloat( "originx" );
vecOrigin.y = pKeyValues->GetFloat( "originy" );
vecOrigin.z = pKeyValues->GetFloat( "originz" );
const char *pModelName = pKeyValues->GetString( "model" );
int nModelIndex = pModelName[0] ? modelinfo->GetModelIndex( pModelName ) : 0;
float flScale = pKeyValues->GetFloat( "scale" );
int nBrightness = pKeyValues->GetInt( "brightness" );
TE_Sprite( filter, delay, &vecOrigin, nModelIndex, flScale, nBrightness );
}