Gravgun optimization, fix mad jumping weapons

This commit is contained in:
mittorn 2016-08-18 19:10:06 +00:00
parent 4642ef3ee0
commit d46a9e493a
3 changed files with 22 additions and 9 deletions

View File

@ -343,6 +343,7 @@ void CGrav::Attack2(void)
} }
} }
if ( crossent ){ if ( crossent ){
if(m_fireMode != FIRE_NARROW)
DestroyEffect(); DestroyEffect();
m_fireMode = FIRE_NARROW; m_fireMode = FIRE_NARROW;
Vector origin = crossent->pev->origin; Vector origin = crossent->pev->origin;

View File

@ -207,7 +207,11 @@ float CItem::TouchGravGun( CBaseEntity *attacker, int stage)
} }
SetThink( &CItem::Materialize ); SetThink( &CItem::Materialize );
pev->nextthink = g_pGameRules->FlItemRespawnTime( this ); pev->nextthink = g_pGameRules->FlItemRespawnTime( this );
if( ( pev->movetype == MOVETYPE_TOSS ) && ( stage > 1 ) )
{
pev->movetype = MOVETYPE_BOUNCE; pev->movetype = MOVETYPE_BOUNCE;
pev->velocity = Vector( 0, 0, 0 );
}
return 400; return 400;
} }

View File

@ -507,8 +507,11 @@ void CBasePlayerItem::Materialize( void )
float CBasePlayerItem::TouchGravGun( CBaseEntity *attacker, int stage ) 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->movetype = MOVETYPE_BOUNCE;
pev->velocity = Vector( 0, 0, 0 );
}
if( stage == 2 ) if( stage == 2 )
{ {
if( (attacker->pev->origin - pev->origin ).Length() < 90 ) if( (attacker->pev->origin - pev->origin ).Length() < 90 )
@ -522,8 +525,9 @@ float CBasePlayerItem::TouchGravGun( CBaseEntity *attacker, int stage )
return 0; return 0;
if( stage == 2 ) if( stage == 2 )
{ {
UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle); //UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle);
float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y; //float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y;
float atarget = attacker->pev->v_angle.y;
pev->angles.y = UTIL_AngleMod(pev->angles.y); pev->angles.y = UTIL_AngleMod(pev->angles.y);
atarget = UTIL_AngleMod(atarget); atarget = UTIL_AngleMod(atarget);
pev->avelocity.y = UTIL_AngleDiff(atarget, pev->angles.y) * 10; 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) 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->movetype = MOVETYPE_BOUNCE;
pev->velocity = Vector( 0, 0, 0 );
}
if( stage == 2 ) if( stage == 2 )
{ {
if( (attacker->pev->origin - pev->origin ).Length() < 90 ) if( (attacker->pev->origin - pev->origin ).Length() < 90 )
@ -1128,8 +1135,9 @@ float CBasePlayerAmmo::TouchGravGun( CBaseEntity *attacker, int stage)
if( stage == 2 ) if( stage == 2 )
{ {
UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle); //UTIL_MakeVectors( attacker->pev->v_angle + attacker->pev->punchangle);
float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y; //float atarget = UTIL_VecToAngles(gpGlobals->v_forward).y;
float atarget = attacker->pev->v_angle.y;
pev->angles.y = UTIL_AngleMod(pev->angles.y); pev->angles.y = UTIL_AngleMod(pev->angles.y);
atarget = UTIL_AngleMod(atarget); atarget = UTIL_AngleMod(atarget);
pev->avelocity.y = UTIL_AngleDiff(atarget, pev->angles.y) * 10; pev->avelocity.y = UTIL_AngleDiff(atarget, pev->angles.y) * 10;
@ -1145,7 +1153,7 @@ float CBasePlayerAmmo::TouchGravGun( CBaseEntity *attacker, int stage)
SetThink( &CBasePlayerAmmo::Materialize ); SetThink( &CBasePlayerAmmo::Materialize );
pev->nextthink = g_pGameRules->FlAmmoRespawnTime( this ); pev->nextthink = g_pGameRules->FlAmmoRespawnTime( this );
} }
return 200; return 500;
} }
void CBasePlayerAmmo::Materialize( void ) void CBasePlayerAmmo::Materialize( void )
{ {