hl2_src-leak-2017/src/game/client/movehelper_client.cpp

281 lines
8.3 KiB
C++

//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//=============================================================================//
#include "cbase.h"
#include <stdarg.h>
#include "engine/IEngineSound.h"
#include "filesystem.h"
#include "igamemovement.h"
#include "engine/IEngineTrace.h"
#include "engine/ivmodelinfo.h"
// memdbgon must be the last include file in a .cpp file!!!
#include "tier0/memdbgon.h"
extern CMoveData *g_pMoveData;
class CMoveHelperClient : public IMoveHelper
{
public:
CMoveHelperClient( void );
virtual ~CMoveHelperClient( void );
char const* GetName( EntityHandle_t handle ) const;
// touch lists
virtual void ResetTouchList( void );
virtual bool AddToTouched( const trace_t& tr, const Vector& impactvelocity );
virtual void ProcessImpacts( void );
// Numbered line printf
virtual void Con_NPrintf( int idx, char const* fmt, ... );
virtual bool PlayerFallingDamage(void);
virtual void PlayerSetAnimation( PLAYER_ANIM eAnim );
// These have separate server vs client impementations
virtual void StartSound( const Vector& origin, int channel, char const* sample, float volume, soundlevel_t soundlevel, int fFlags, int pitch );
virtual void StartSound( const Vector& origin, const char *soundname );
virtual void PlaybackEventFull( int flags, int clientindex, unsigned short eventindex, float delay, Vector& origin, Vector& angles, float fparam1, float fparam2, int iparam1, int iparam2, int bparam1, int bparam2 );
virtual IPhysicsSurfaceProps *GetSurfaceProps( void );
virtual bool IsWorldEntity( const CBaseHandle &handle );
private:
// results, tallied on client and server, but only used by server to run SV_Impact.
// we store off our velocity in the trace_t structure so that we can determine results
// of shoving boxes etc. around.
struct touchlist_t
{
Vector deltavelocity;
trace_t trace;
touchlist_t() {}
private:
touchlist_t( const touchlist_t &src );
};
CUtlVector<touchlist_t> m_TouchList;
};
//-----------------------------------------------------------------------------
// Singleton
//-----------------------------------------------------------------------------
IMPLEMENT_MOVEHELPER();
static CMoveHelperClient s_MoveHelperClient;
//-----------------------------------------------------------------------------
// Constructor
//-----------------------------------------------------------------------------
CMoveHelperClient::CMoveHelperClient( void )
{
SetSingleton( this );
}
CMoveHelperClient::~CMoveHelperClient( void )
{
SetSingleton( 0 );
}
//-----------------------------------------------------------------------------
// Purpose:
// Output : const char
//-----------------------------------------------------------------------------
char const* CMoveHelperClient::GetName( EntityHandle_t handle ) const
{
return "";
}
//-----------------------------------------------------------------------------
// Touch list
//-----------------------------------------------------------------------------
void CMoveHelperClient::ResetTouchList( void )
{
m_TouchList.RemoveAll();
}
//-----------------------------------------------------------------------------
// Adds to the touched list
//-----------------------------------------------------------------------------
bool CMoveHelperClient::AddToTouched( const trace_t& tr, const Vector& impactvelocity )
{
int i;
// Look for duplicates
for (i = 0; i < m_TouchList.Size(); i++)
{
if (m_TouchList[i].trace.m_pEnt == tr.m_pEnt)
{
return false;
}
}
i = m_TouchList.AddToTail();
m_TouchList[i].trace = tr;
VectorCopy( impactvelocity, m_TouchList[i].deltavelocity );
return true;
}
void CMoveHelperClient::ProcessImpacts( void )
{
C_BasePlayer *pPlayer = C_BasePlayer::GetLocalPlayer();
if ( !pPlayer )
return;
// Relink in order to build absorigin and absmin/max to reflect any changes
// from prediction. Relink will early out on SOLID_NOT
// TODO: Touch triggers on the client
//pPlayer->PhysicsTouchTriggers();
// Don't bother if the player ain't solid
if ( pPlayer->IsSolidFlagSet( FSOLID_NOT_SOLID ) )
return;
// Save off the velocity, cause we need to temporarily reset it
Vector vel = pPlayer->GetAbsVelocity();
// Touch other objects that were intersected during the movement.
for (int i = 0 ; i < m_TouchList.Size(); i++)
{
// Run the impact function as if we had run it during movement.
C_BaseEntity *entity = ClientEntityList().GetEnt( m_TouchList[i].trace.m_pEnt->entindex() );
if ( !entity )
continue;
Assert( entity != pPlayer );
// Don't ever collide with self!!!!
if ( entity == pPlayer )
continue;
// Reconstruct trace results.
m_TouchList[i].trace.m_pEnt = entity;
// Use the velocity we had when we collided, so boxes will move, etc.
pPlayer->SetAbsVelocity( m_TouchList[i].deltavelocity );
entity->PhysicsImpact( pPlayer, m_TouchList[i].trace );
}
// Restore the velocity
pPlayer->SetAbsVelocity( vel );
// So no stuff is ever left over, sigh...
ResetTouchList();
}
void CMoveHelperClient::StartSound( const Vector& origin, const char *soundname )
{
if ( !soundname )
return;
CLocalPlayerFilter filter;
filter.UsePredictionRules();
C_BaseEntity::EmitSound( filter, SOUND_FROM_LOCAL_PLAYER, soundname, &origin );
}
//-----------------------------------------------------------------------------
// Play a sound
//-----------------------------------------------------------------------------
void CMoveHelperClient::StartSound( const Vector& origin, int channel,
char const* pSample, float volume, soundlevel_t soundlevel, int fFlags, int pitch )
{
if ( pSample )
{
C_BaseEntity::PrecacheScriptSound( pSample );
CLocalPlayerFilter filter;
filter.UsePredictionRules();
EmitSound_t ep;
ep.m_nChannel = channel;
ep.m_pSoundName = pSample;
ep.m_flVolume = volume;
ep.m_SoundLevel = soundlevel;
ep.m_nPitch = pitch;
ep.m_pOrigin = &origin;
C_BaseEntity::EmitSound( filter, SOUND_FROM_LOCAL_PLAYER, ep );
}
}
//-----------------------------------------------------------------------------
// Play a event
//-----------------------------------------------------------------------------
void CMoveHelperClient::PlaybackEventFull( int flags, int clientindex, unsigned short eventindex, float delay, Vector& origin, Vector& angles, float fparam1, float fparam2, int iparam1, int iparam2, int bparam1, int bparam2 )
{
// TODO
if (g_pMoveData->m_bFirstRunOfFunctions )
{
}
}
//-----------------------------------------------------------------------------
// Surface properties interface
//-----------------------------------------------------------------------------
IPhysicsSurfaceProps *CMoveHelperClient::GetSurfaceProps( void )
{
extern IPhysicsSurfaceProps *physprops;
return physprops;
}
//-----------------------------------------------------------------------------
// Purpose:
// Input : bDeveloper -
// *pFormat -
// ... -
//-----------------------------------------------------------------------------
void CMoveHelperClient::Con_NPrintf( int idx, char const* pFormat, ...)
{
va_list marker;
char msg[8192];
va_start(marker, pFormat);
Q_vsnprintf(msg, sizeof( msg ), pFormat, marker);
va_end(marker);
#if defined( CSTRIKE_DLL ) || defined( DOD_DLL ) // reltodo
engine->Con_NPrintf( idx, "%s", msg );
#else
engine->Con_NPrintf( idx, msg );
#endif
}
//-----------------------------------------------------------------------------
// Purpose: Called when the player falls onto a surface fast enough to take
// damage, according to the rules in CGameMovement::CheckFalling.
// Output : Returns true if the player survived the fall, false if they died.
//-----------------------------------------------------------------------------
bool CMoveHelperClient::PlayerFallingDamage(void)
{
// Do nothing; falling damage is applied in MoveHelper_Server::PlayerFallingDamage.
return(true);
}
//-----------------------------------------------------------------------------
// Purpose: Sets an animation in the player.
// Input : eAnim - Animation to set.
//-----------------------------------------------------------------------------
void CMoveHelperClient::PlayerSetAnimation( PLAYER_ANIM eAnim )
{
// Do nothing on the client. Animations are set on the server.
}
bool CMoveHelperClient::IsWorldEntity( const CBaseHandle &handle )
{
return handle == cl_entitylist->GetNetworkableHandle( 0 );
}