game: restore combine elite soldiers ability to use alt-fire of SMG1

This commit is contained in:
SanyaSho 2022-08-04 16:17:51 +03:00
parent 5caf8adbd7
commit d628a7ae80
2 changed files with 53 additions and 24 deletions

View File

@ -378,7 +378,7 @@ void CNPC_Combine::PostNPCInit()
// an AR2. // an AR2.
if( !GetActiveWeapon() || !FClassnameIs( GetActiveWeapon(), "weapon_ar2" ) ) if( !GetActiveWeapon() || !FClassnameIs( GetActiveWeapon(), "weapon_ar2" ) )
{ {
DevWarning("**Combine Elite Soldier MUST be equipped with AR2\n"); // DevWarning("**Combine Elite Soldier MUST be equipped with AR2\n");
} }
} }
@ -2320,7 +2320,18 @@ void CNPC_Combine::HandleAnimEvent( animevent_t *pEvent )
{ {
if ( pEvent->event == COMBINE_AE_BEGIN_ALTFIRE ) if ( pEvent->event == COMBINE_AE_BEGIN_ALTFIRE )
{ {
EmitSound( "Weapon_CombineGuard.Special1" ); if( FClassnameIs( GetActiveWeapon(), "weapon_ar2" ) )
{
EmitSound( "Weapon_CombineGuard.Special1" );
}
else if( FClassnameIs( GetActiveWeapon(), "weapon_smg1" ) )
{
EmitSound( "Weapon_SMG1.Double" );
}
else
{
EmitSound( "Weapon_CombineGuard.Special1" );
}
handledEvent = true; handledEvent = true;
} }
else if ( pEvent->event == COMBINE_AE_ALTFIRE ) else if ( pEvent->event == COMBINE_AE_ALTFIRE )

View File

@ -45,7 +45,7 @@ public:
float GetFireRate( void ) { return 0.075f; } // 13.3hz float GetFireRate( void ) { return 0.075f; } // 13.3hz
int CapabilitiesGet( void ) { return bits_CAP_WEAPON_RANGE_ATTACK1; } int CapabilitiesGet( void ) { return bits_CAP_WEAPON_RANGE_ATTACK1; }
int WeaponRangeAttack2Condition( float flDot, float flDist ); int WeaponRangeAttack2Condition(/* float flDot, float flDist */);
Activity GetPrimaryAttackActivity( void ); Activity GetPrimaryAttackActivity( void );
virtual const Vector& GetBulletSpread( void ) virtual const Vector& GetBulletSpread( void )
@ -228,32 +228,50 @@ void CWeaponSMG1::Operator_HandleAnimEvent( animevent_t *pEvent, CBaseCombatChar
} }
break; break;
/*//FIXME: Re-enable case EVENT_WEAPON_AR2_ALTFIRE:
case EVENT_WEAPON_AR2_GRENADE:
{ {
CAI_BaseNPC *npc = pOperator->MyNPCPointer(); CAI_BaseNPC *npc = pOperator->MyNPCPointer();
Vector vecShootOrigin, vecShootDir; Vector vecShootOrigin, vecShootDir;
vecShootOrigin = pOperator->Weapon_ShootPosition(); vecShootOrigin = pOperator->Weapon_ShootPosition();
vecShootDir = npc->GetShootEnemyDir( vecShootOrigin ); //vecShootDir = npc->GetShootEnemyDir( vecShootOrigin );
Vector vecThrow = m_vecTossVelocity; //Checks if it can fire the grenade
WeaponRangeAttack2Condition();
CGrenadeAR2 *pGrenade = (CGrenadeAR2*)Create( "grenade_ar2", vecShootOrigin, vec3_angle, npc ); Vector vecThrow = m_vecTossVelocity;
pGrenade->SetAbsVelocity( vecThrow );
pGrenade->SetLocalAngularVelocity( QAngle( 0, 400, 0 ) );
pGrenade->SetMoveType( MOVETYPE_FLYGRAVITY );
pGrenade->m_hOwner = npc;
pGrenade->m_pMyWeaponAR2 = this;
pGrenade->SetDamage(sk_npc_dmg_ar2_grenade.GetFloat());
// FIXME: arrgg ,this is hard coded into the weapon??? //If on the rare case the vector is 0 0 0, cancel for avoid launching the grenade without speed
m_flNextGrenadeCheck = gpGlobals->curtime + 6;// wait six seconds before even looking again to see if a grenade can be thrown. //This should be on WeaponRangeAttack2Condition(), but for some unknown reason return CASE_NONE
//doesn't stop the launch
if( vecThrow == Vector(0, 0, 0) )
{
break;
}
m_iClip2--; CGrenadeAR2 *pGrenade = (CGrenadeAR2*)Create("grenade_ar2", vecShootOrigin, vec3_angle, npc);
pGrenade->SetAbsVelocity( vecThrow );
pGrenade->SetLocalAngularVelocity(RandomAngle(-400, 400)); //tumble in air
pGrenade->SetMoveType( MOVETYPE_FLYGRAVITY, MOVECOLLIDE_FLY_BOUNCE );
pGrenade->SetThrower(GetOwner());
pGrenade->SetGravity(0.5); // lower gravity since grenade is aerodynamic and engine doesn't know it.
pGrenade->SetDamage( sk_plr_dmg_smg1_grenade.GetFloat() );
if( g_pGameRules->IsSkillLevel( SKILL_HARD ) )
{
m_flNextGrenadeCheck = gpGlobals->curtime + RandomFloat(2, 3);
}
else
{
m_flNextGrenadeCheck = gpGlobals->curtime + 6;// wait six seconds before even looking again to see if a grenade can be thrown.
}
m_iClip2--;
} }
break; break;
*/
default: default:
BaseClass::Operator_HandleAnimEvent( pEvent, pOperator ); BaseClass::Operator_HandleAnimEvent( pEvent, pOperator );
@ -272,7 +290,7 @@ Activity CWeaponSMG1::GetPrimaryAttackActivity( void )
if ( m_nShotsFired < 3 ) if ( m_nShotsFired < 3 )
return ACT_VM_RECOIL1; return ACT_VM_RECOIL1;
if ( m_nShotsFired < 4 ) if ( m_nShotsFired < 4 )
return ACT_VM_RECOIL2; return ACT_VM_RECOIL2;
@ -394,11 +412,11 @@ void CWeaponSMG1::SecondaryAttack( void )
// flDist - // flDist -
// Output : int // Output : int
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
int CWeaponSMG1::WeaponRangeAttack2Condition( float flDot, float flDist ) int CWeaponSMG1::WeaponRangeAttack2Condition(/* float flDot, float flDist */)
{ {
CAI_BaseNPC *npcOwner = GetOwner()->MyNPCPointer(); CAI_BaseNPC *npcOwner = GetOwner()->MyNPCPointer();
return COND_NONE; // return COND_NONE;
/* /*
// -------------------------------------------------------- // --------------------------------------------------------