From d46a9e493a3057986b55f4c556e1d345b9c17307 Mon Sep 17 00:00:00 2001 From: mittorn Date: Thu, 18 Aug 2016 19:10:06 +0000 Subject: [PATCH] Gravgun optimization, fix mad jumping weapons --- dlls/gravgun.cpp | 3 ++- dlls/items.cpp | 6 +++++- dlls/weapons.cpp | 22 +++++++++++++++------- 3 files changed, 22 insertions(+), 9 deletions(-) diff --git a/dlls/gravgun.cpp b/dlls/gravgun.cpp index 850d7015..0afd9c32 100644 --- a/dlls/gravgun.cpp +++ b/dlls/gravgun.cpp @@ -343,7 +343,8 @@ void CGrav::Attack2(void) } } if ( crossent ){ - DestroyEffect(); + if(m_fireMode != FIRE_NARROW) + DestroyEffect(); m_fireMode = FIRE_NARROW; Vector origin = crossent->pev->origin; if(crossent->IsBSPModel()) diff --git a/dlls/items.cpp b/dlls/items.cpp index 1ab03915..f0b1a6a4 100644 --- a/dlls/items.cpp +++ b/dlls/items.cpp @@ -207,7 +207,11 @@ float CItem::TouchGravGun( CBaseEntity *attacker, int stage) } SetThink( &CItem::Materialize ); pev->nextthink = g_pGameRules->FlItemRespawnTime( this ); - pev->movetype = MOVETYPE_BOUNCE; + if( ( pev->movetype == MOVETYPE_TOSS ) && ( stage > 1 ) ) + { + pev->movetype = MOVETYPE_BOUNCE; + pev->velocity = Vector( 0, 0, 0 ); + } return 400; } diff --git a/dlls/weapons.cpp b/dlls/weapons.cpp index cab70ef0..e918cffe 100644 --- a/dlls/weapons.cpp +++ b/dlls/weapons.cpp @@ -507,8 +507,11 @@ void CBasePlayerItem::Materialize( void ) float CBasePlayerItem::TouchGravGun( CBaseEntity *attacker, int stage ) { - if( m_pfnTouch == &CBasePlayerItem::DefaultTouch ) + if( ( pev->movetype == MOVETYPE_TOSS ) && ( stage > 1 ) && ( m_pfnTouch == &CBasePlayerItem::DefaultTouch ) ) + { pev->movetype = MOVETYPE_BOUNCE; + pev->velocity = Vector( 0, 0, 0 ); + } if( stage == 2 ) { if( (attacker->pev->origin - pev->origin ).Length() < 90 ) @@ -522,8 +525,9 @@ float CBasePlayerItem::TouchGravGun( CBaseEntity *attacker, int stage ) return 0; if( stage == 2 ) { - UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle); - float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y; + //UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle); + //float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y; + float atarget = attacker->pev->v_angle.y; pev->angles.y = UTIL_AngleMod(pev->angles.y); atarget = UTIL_AngleMod(atarget); pev->avelocity.y = UTIL_AngleDiff(atarget, pev->angles.y) * 10; @@ -1112,8 +1116,11 @@ CBaseEntity* CBasePlayerAmmo::Respawn( void ) } float CBasePlayerAmmo::TouchGravGun( CBaseEntity *attacker, int stage) { - if( m_pfnTouch == &CBasePlayerAmmo::DefaultTouch ) + if( ( pev->movetype == MOVETYPE_TOSS ) && ( stage > 1 ) && ( m_pfnTouch == &CBasePlayerAmmo::DefaultTouch ) ) + { pev->movetype = MOVETYPE_BOUNCE; + pev->velocity = Vector( 0, 0, 0 ); + } if( stage == 2 ) { if( (attacker->pev->origin - pev->origin ).Length() < 90 ) @@ -1128,8 +1135,9 @@ float CBasePlayerAmmo::TouchGravGun( CBaseEntity *attacker, int stage) if( stage == 2 ) { - UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle); - float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y; + //UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle); + //float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y; + float atarget = attacker->pev->v_angle.y; pev->angles.y = UTIL_AngleMod(pev->angles.y); atarget = UTIL_AngleMod(atarget); pev->avelocity.y = UTIL_AngleDiff(atarget, pev->angles.y) * 10; @@ -1145,7 +1153,7 @@ float CBasePlayerAmmo::TouchGravGun( CBaseEntity *attacker, int stage) SetThink( &CBasePlayerAmmo::Materialize ); pev->nextthink = g_pGameRules->FlAmmoRespawnTime( this ); } - return 200; + return 500; } void CBasePlayerAmmo::Materialize( void ) {