Modified baseanim so that it respects the server +
This commit is contained in:
parent
f154a494cd
commit
fb69fa738b
7 changed files with 82 additions and 41 deletions
|
@ -7,6 +7,7 @@
|
||||||
#include "cbase.h"
|
#include "cbase.h"
|
||||||
#include "c_baseanimating.h"
|
#include "c_baseanimating.h"
|
||||||
#include "c_sprite.h"
|
#include "c_sprite.h"
|
||||||
|
#include "cdll_client_int.h"
|
||||||
#include "model_types.h"
|
#include "model_types.h"
|
||||||
#include "bone_setup.h"
|
#include "bone_setup.h"
|
||||||
#include "ivrenderview.h"
|
#include "ivrenderview.h"
|
||||||
|
@ -898,6 +899,52 @@ void C_BaseAnimating::RemoveBaseAnimatingInterpolatedVars()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void C_BaseAnimating::StudioFrameAdvanceInternal( CStudioHdr *pStudioHdr, float flCycleDelta )
|
||||||
|
{
|
||||||
|
float flNewCycle = GetCycle() + flCycleDelta;
|
||||||
|
if (flNewCycle < 0.0 || flNewCycle >= 1.0)
|
||||||
|
{
|
||||||
|
if (m_bSequenceLoops)
|
||||||
|
{
|
||||||
|
flNewCycle -= (int)(flNewCycle);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
flNewCycle = (flNewCycle < 0.0f) ? 0.0f : 1.0f;
|
||||||
|
}
|
||||||
|
m_bSequenceFinished = true; // just in case it wasn't caught in GetEvents
|
||||||
|
}
|
||||||
|
else if (flNewCycle > GetLastVisibleCycle( pStudioHdr, GetSequence() ))
|
||||||
|
{
|
||||||
|
m_bSequenceFinished = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
SetCycle( flNewCycle );
|
||||||
|
|
||||||
|
/*
|
||||||
|
if (!IsPlayer())
|
||||||
|
Msg("%s %6.3f : %6.3f %6.3f (%.3f) %.3f\n",
|
||||||
|
GetClassname(), gpGlobals->curtime,
|
||||||
|
m_flAnimTime.Get(), m_flPrevAnimTime, flInterval, GetCycle() );
|
||||||
|
*/
|
||||||
|
|
||||||
|
m_flGroundSpeed = GetSequenceGroundSpeed( pStudioHdr, GetSequence() ) * GetModelScale();
|
||||||
|
|
||||||
|
// Msg("%s : %s : %5.1f\n", GetClassname(), GetSequenceName( GetSequence() ), GetCycle() );
|
||||||
|
InvalidatePhysicsRecursive( ANIMATION_CHANGED );
|
||||||
|
|
||||||
|
InvalidateBoneCacheIfOlderThan( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_BaseAnimating::InvalidateBoneCacheIfOlderThan( float deltaTime )
|
||||||
|
{
|
||||||
|
CBoneCache *pcache = Studio_GetBoneCache( m_hitboxBoneCacheHandle );
|
||||||
|
if ( !pcache || !pcache->IsValid( gpGlobals->curtime, deltaTime ) )
|
||||||
|
{
|
||||||
|
InvalidateBoneCache();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void C_BaseAnimating::LockStudioHdr()
|
void C_BaseAnimating::LockStudioHdr()
|
||||||
{
|
{
|
||||||
Assert( m_hStudioHdr == MDLHANDLE_INVALID && m_pStudioHdr == NULL );
|
Assert( m_hStudioHdr == MDLHANDLE_INVALID && m_pStudioHdr == NULL );
|
||||||
|
@ -5304,7 +5351,7 @@ void C_BaseAnimating::GetBlendedLinearVelocity( Vector *pVec )
|
||||||
float C_BaseAnimating::FrameAdvance( float flInterval )
|
float C_BaseAnimating::FrameAdvance( float flInterval )
|
||||||
{
|
{
|
||||||
CStudioHdr *hdr = GetModelPtr();
|
CStudioHdr *hdr = GetModelPtr();
|
||||||
if ( !hdr )
|
if ( !hdr || !hdr->SequencesAvailable() )
|
||||||
return 0.0f;
|
return 0.0f;
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
|
@ -5313,24 +5360,30 @@ float C_BaseAnimating::FrameAdvance( float flInterval )
|
||||||
bool bWatch = false; // Q_strstr( hdr->name, "medkit_large" ) ? true : false;
|
bool bWatch = false; // Q_strstr( hdr->name, "medkit_large" ) ? true : false;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
float curtime = gpGlobals->curtime;
|
UpdateModelScale();
|
||||||
|
|
||||||
|
if ( !m_flOldAnimTime )
|
||||||
|
{
|
||||||
|
m_flOldAnimTime = m_flAnimTime;
|
||||||
|
}
|
||||||
|
|
||||||
if (flInterval == 0.0f)
|
if (flInterval == 0.0f)
|
||||||
{
|
{
|
||||||
flInterval = ( curtime - m_flAnimTime );
|
flInterval = GetAnimTimeInterval();
|
||||||
if (flInterval <= 0.001f)
|
if (flInterval <= 0.001f)
|
||||||
{
|
{
|
||||||
return 0.0f;
|
return 0.0f;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !m_flAnimTime )
|
// Set current
|
||||||
{
|
m_flAnimTime = gpGlobals->curtime;
|
||||||
flInterval = 0.0f;
|
|
||||||
}
|
|
||||||
|
|
||||||
float cyclerate = GetSequenceCycleRate( hdr, GetSequence() );
|
// Latch prev
|
||||||
float addcycle = flInterval * cyclerate * m_flPlaybackRate;
|
m_flOldAnimTime = m_flAnimTime - flInterval;
|
||||||
|
|
||||||
|
float flCycleRate = GetSequenceCycleRate( hdr, GetSequence() );
|
||||||
|
float flAddCycle = flInterval * flCycleRate * m_flPlaybackRate;
|
||||||
|
|
||||||
if( GetServerIntendedCycle() != -1.0f )
|
if( GetServerIntendedCycle() != -1.0f )
|
||||||
{
|
{
|
||||||
|
@ -5348,42 +5401,28 @@ float C_BaseAnimating::FrameAdvance( float flInterval )
|
||||||
|
|
||||||
if( adjustOkay )
|
if( adjustOkay )
|
||||||
{
|
{
|
||||||
float originalAdvance = addcycle;
|
float originalAdvance = flAddCycle;
|
||||||
addcycle = (serverAdvance + addcycle) / 2;
|
flAddCycle = (serverAdvance + flAddCycle) / 2;
|
||||||
|
|
||||||
const float MAX_CYCLE_ADJUSTMENT = 0.1f;
|
const float MAX_CYCLE_ADJUSTMENT = 0.1f;
|
||||||
addcycle = MIN( MAX_CYCLE_ADJUSTMENT, addcycle );// Don't do too big of a jump; it's too jarring as well.
|
flAddCycle = MIN( MAX_CYCLE_ADJUSTMENT, flAddCycle );// Don't do too big of a jump; it's too jarring as well.
|
||||||
|
|
||||||
DevMsg( 2, "(%d): Cycle latch used to correct %.2f in to %.2f instead of %.2f.\n",
|
DevMsg( 2, "(%d): Cycle latch used to correct %.2f in to %.2f instead of %.2f.\n",
|
||||||
entindex(), GetCycle(), GetCycle() + addcycle, GetCycle() + originalAdvance );
|
entindex(), GetCycle(), GetCycle() + flAddCycle, GetCycle() + originalAdvance );
|
||||||
}
|
}
|
||||||
|
|
||||||
SetServerIntendedCycle(-1.0f); // Only use a correction once, it isn't valid any time but right now.
|
SetServerIntendedCycle(-1.0f); // Only use a correction once, it isn't valid any time but right now.
|
||||||
}
|
}
|
||||||
|
|
||||||
float flNewCycle = GetCycle() + addcycle;
|
float flNewCycle = GetCycle() + flAddCycle;
|
||||||
m_flAnimTime = curtime;
|
|
||||||
|
|
||||||
if ( bWatch )
|
if ( bWatch )
|
||||||
{
|
{
|
||||||
Msg("%i CLIENT Time: %6.3f : (Interval %f) : cycle %f rate %f add %f\n",
|
Msg("%i CLIENT Time: %6.3f : (Interval %f) : cycle %f rate %f add %f\n",
|
||||||
gpGlobals->tickcount, gpGlobals->curtime, flInterval, flNewCycle, cyclerate, addcycle );
|
gpGlobals->tickcount, gpGlobals->curtime, flInterval, flNewCycle, flCycleRate, flAddCycle );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( (flNewCycle < 0.0f) || (flNewCycle >= 1.0f) )
|
StudioFrameAdvanceInternal( hdr, flAddCycle );
|
||||||
{
|
|
||||||
if ( IsSequenceLooping( hdr, GetSequence() ) )
|
|
||||||
{
|
|
||||||
flNewCycle -= (int)(flNewCycle);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
flNewCycle = (flNewCycle < 0.0f) ? 0.0f : 1.0f;
|
|
||||||
}
|
|
||||||
m_bSequenceFinished = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
SetCycle( flNewCycle );
|
|
||||||
|
|
||||||
return flInterval;
|
return flInterval;
|
||||||
}
|
}
|
||||||
|
|
|
@ -363,6 +363,7 @@ public:
|
||||||
int GetNumBodyGroups( void );
|
int GetNumBodyGroups( void );
|
||||||
|
|
||||||
class CBoneCache *GetBoneCache( CStudioHdr *pStudioHdr );
|
class CBoneCache *GetBoneCache( CStudioHdr *pStudioHdr );
|
||||||
|
void InvalidateBoneCacheIfOlderThan( float deltaTime );
|
||||||
void SetHitboxSet( int setnum );
|
void SetHitboxSet( int setnum );
|
||||||
void SetHitboxSetByName( const char *setname );
|
void SetHitboxSetByName( const char *setname );
|
||||||
int GetHitboxSet( void );
|
int GetHitboxSet( void );
|
||||||
|
@ -635,6 +636,7 @@ private:
|
||||||
virtual void OnModelLoadComplete( const model_t* pModel );
|
virtual void OnModelLoadComplete( const model_t* pModel );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void StudioFrameAdvanceInternal( CStudioHdr *pStudioHdr, float flInterval );
|
||||||
void LockStudioHdr();
|
void LockStudioHdr();
|
||||||
void UnlockStudioHdr();
|
void UnlockStudioHdr();
|
||||||
mutable CStudioHdr *m_pStudioHdr;
|
mutable CStudioHdr *m_pStudioHdr;
|
||||||
|
|
|
@ -675,7 +675,7 @@ void C_CSPlayer::RecvProxy_CycleLatch( const CRecvProxyData *pData, void *pStruc
|
||||||
if( pPlayer->IsLocalPlayer() )
|
if( pPlayer->IsLocalPlayer() )
|
||||||
return; // Don't need to fixup ourselves.
|
return; // Don't need to fixup ourselves.
|
||||||
|
|
||||||
float incomingCycle = (float)(pData->m_Value.m_Int) / 16; // Came in as 4 bit fixed point
|
float incomingCycle = pData->m_Value.m_Float; // Came in as 4 bit fixed point
|
||||||
float currentCycle = pPlayer->GetCycle();
|
float currentCycle = pPlayer->GetCycle();
|
||||||
bool closeEnough = fabs(currentCycle - incomingCycle) < CycleLatchTolerance;
|
bool closeEnough = fabs(currentCycle - incomingCycle) < CycleLatchTolerance;
|
||||||
if( fabs(currentCycle - incomingCycle) > (1 - CycleLatchTolerance) )
|
if( fabs(currentCycle - incomingCycle) > (1 - CycleLatchTolerance) )
|
||||||
|
@ -783,7 +783,7 @@ IMPLEMENT_CLIENTCLASS_DT( C_CSPlayer, DT_CSPlayer, CCSPlayer )
|
||||||
RecvPropInt( RECVINFO( m_iProgressBarDuration ) ),
|
RecvPropInt( RECVINFO( m_iProgressBarDuration ) ),
|
||||||
RecvPropFloat( RECVINFO( m_flProgressBarStartTime ) ),
|
RecvPropFloat( RECVINFO( m_flProgressBarStartTime ) ),
|
||||||
RecvPropEHandle( RECVINFO( m_hRagdoll ) ),
|
RecvPropEHandle( RECVINFO( m_hRagdoll ) ),
|
||||||
RecvPropInt( RECVINFO( m_cycleLatch ), 0, &C_CSPlayer::RecvProxy_CycleLatch ),
|
RecvPropFloat( RECVINFO( m_cycleLatch ), SPROP_NOSCALE, &C_CSPlayer::RecvProxy_CycleLatch ),
|
||||||
|
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
|
|
|
@ -374,7 +374,7 @@ private:
|
||||||
int m_iLastPrimaryAddon;
|
int m_iLastPrimaryAddon;
|
||||||
int m_iLastSecondaryAddon;
|
int m_iLastSecondaryAddon;
|
||||||
|
|
||||||
int m_cycleLatch; // server periodically updates this to fix up our anims, here it is a 4 bit fixed point
|
float m_cycleLatch; // server periodically updates this to fix up our anims, here it is a 4 bit fixed point
|
||||||
float m_serverIntendedCycle; // server periodically updates this to fix up our anims, here it is the float we want, or -1 for no override
|
float m_serverIntendedCycle; // server periodically updates this to fix up our anims, here it is the float we want, or -1 for no override
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -498,8 +498,7 @@ void CBaseAnimating::StudioFrameAdvance()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Time since last animation
|
// Time since last animation
|
||||||
float flInterval = gpGlobals->curtime - m_flAnimTime;
|
float flInterval = GetAnimTimeInterval();
|
||||||
flInterval = clamp( flInterval, 0.f, MAX_ANIMTIME_INTERVAL );
|
|
||||||
|
|
||||||
//Msg( "%i %s interval %f\n", entindex(), GetClassname(), flInterval );
|
//Msg( "%i %s interval %f\n", entindex(), GetClassname(), flInterval );
|
||||||
if (flInterval <= 0.001f)
|
if (flInterval <= 0.001f)
|
||||||
|
@ -508,11 +507,12 @@ void CBaseAnimating::StudioFrameAdvance()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Latch prev
|
|
||||||
m_flPrevAnimTime = m_flAnimTime;
|
|
||||||
// Set current
|
// Set current
|
||||||
m_flAnimTime = gpGlobals->curtime;
|
m_flAnimTime = gpGlobals->curtime;
|
||||||
|
|
||||||
|
// Latch prev
|
||||||
|
m_flPrevAnimTime = m_flAnimTime - flInterval;
|
||||||
|
|
||||||
// Drive cycle
|
// Drive cycle
|
||||||
float flCycleRate = GetSequenceCycleRate( pStudioHdr, GetSequence() ) * m_flPlaybackRate;
|
float flCycleRate = GetSequenceCycleRate( pStudioHdr, GetSequence() ) * m_flPlaybackRate;
|
||||||
|
|
||||||
|
|
|
@ -398,7 +398,7 @@ IMPLEMENT_SERVERCLASS_ST( CCSPlayer, DT_CSPlayer )
|
||||||
SendPropInt( SENDINFO( m_iProgressBarDuration ), 4, SPROP_UNSIGNED ),
|
SendPropInt( SENDINFO( m_iProgressBarDuration ), 4, SPROP_UNSIGNED ),
|
||||||
SendPropFloat( SENDINFO( m_flProgressBarStartTime ), 0, SPROP_NOSCALE ),
|
SendPropFloat( SENDINFO( m_flProgressBarStartTime ), 0, SPROP_NOSCALE ),
|
||||||
SendPropEHandle( SENDINFO( m_hRagdoll ) ),
|
SendPropEHandle( SENDINFO( m_hRagdoll ) ),
|
||||||
SendPropInt( SENDINFO( m_cycleLatch ), 4, SPROP_UNSIGNED ),
|
SendPropFloat( SENDINFO( m_cycleLatch ), 0, SPROP_NOSCALE ),
|
||||||
|
|
||||||
|
|
||||||
END_SEND_TABLE()
|
END_SEND_TABLE()
|
||||||
|
@ -936,7 +936,7 @@ void CCSPlayer::Spawn()
|
||||||
|
|
||||||
m_applyDeafnessTime = 0.0f;
|
m_applyDeafnessTime = 0.0f;
|
||||||
|
|
||||||
m_cycleLatch = 0;
|
m_cycleLatch = 0.0f;
|
||||||
m_cycleLatchTimer.Start( RandomFloat( 0.0f, CycleLatchInterval ) );
|
m_cycleLatchTimer.Start( RandomFloat( 0.0f, CycleLatchInterval ) );
|
||||||
|
|
||||||
StockPlayerAmmo();
|
StockPlayerAmmo();
|
||||||
|
@ -1677,7 +1677,7 @@ void CCSPlayer::PostThink()
|
||||||
m_cycleLatchTimer.Start( CycleLatchInterval );
|
m_cycleLatchTimer.Start( CycleLatchInterval );
|
||||||
|
|
||||||
// Cycle is a float from 0 to 1. We don't need to transmit a whole float for that. Compress it in to a small fixed point
|
// Cycle is a float from 0 to 1. We don't need to transmit a whole float for that. Compress it in to a small fixed point
|
||||||
m_cycleLatch.GetForModify() = 16 * GetCycle();// 4 point fixed
|
m_cycleLatch.GetForModify() = GetCycle();// 4 point fixed
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -906,7 +906,7 @@ private:
|
||||||
// This lets us rate limit the commands the players can execute so they don't overflow things like reliable buffers.
|
// This lets us rate limit the commands the players can execute so they don't overflow things like reliable buffers.
|
||||||
CUtlDict<float,int> m_RateLimitLastCommandTimes;
|
CUtlDict<float,int> m_RateLimitLastCommandTimes;
|
||||||
|
|
||||||
CNetworkVar(int, m_cycleLatch); // Every so often, we are going to transmit our cycle to the client to correct divergence caused by PVS changes
|
CNetworkVar(float, m_cycleLatch); // Every so often, we are going to transmit our cycle to the client to correct divergence caused by PVS changes
|
||||||
CountdownTimer m_cycleLatchTimer;
|
CountdownTimer m_cycleLatchTimer;
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
|
|
Loading…
Reference in a new issue