Browse Source

Merge branch 'opfor' into opforfixed

opforfixed
Andrey Akhmichin 2 years ago
parent
commit
6cfc082738
No known key found for this signature in database
GPG Key ID: 1F180D249B0643C0
  1. 35
      dlls/gearbox/voltigore.cpp

35
dlls/gearbox/voltigore.cpp

@ -1226,6 +1226,8 @@ public:
Schedule_t* GetSchedule(); Schedule_t* GetSchedule();
Schedule_t* GetScheduleOfType(int Type); Schedule_t* GetScheduleOfType(int Type);
CBaseEntity *CheckTraceHullAttack( float flDist, int iDamage, int iDmgType );
virtual int SizeForGrapple() { return GRAPPLE_SMALL; } virtual int SizeForGrapple() { return GRAPPLE_SMALL; }
}; };
@ -1274,7 +1276,7 @@ void CBabyVoltigore::HandleAnimEvent(MonsterEvent_t* pEvent)
case VOLTIGORE_AE_PUNCH_SINGLE: case VOLTIGORE_AE_PUNCH_SINGLE:
{ {
CBaseEntity *pHurt = CheckTraceHullAttack(70, gSkillData.babyVoltigoreDmgPunch, DMG_CLUB | DMG_ALWAYSGIB); CBaseEntity *pHurt = CheckTraceHullAttack(64, gSkillData.babyVoltigoreDmgPunch, DMG_CLUB );
if (pHurt) if (pHurt)
{ {
if (FBitSet(pHurt->pev->flags, FL_MONSTER|FL_CLIENT)) if (FBitSet(pHurt->pev->flags, FL_MONSTER|FL_CLIENT))
@ -1300,7 +1302,7 @@ void CBabyVoltigore::HandleAnimEvent(MonsterEvent_t* pEvent)
case VOLTIGORE_AE_PUNCH_BOTH: case VOLTIGORE_AE_PUNCH_BOTH:
{ {
CBaseEntity *pHurt = CheckTraceHullAttack(70, gSkillData.babyVoltigoreDmgPunch, DMG_CLUB | DMG_ALWAYSGIB); CBaseEntity *pHurt = CheckTraceHullAttack(64, gSkillData.babyVoltigoreDmgPunch, DMG_CLUB );
if (pHurt) if (pHurt)
{ {
if (FBitSet(pHurt->pev->flags, FL_MONSTER|FL_CLIENT)) if (FBitSet(pHurt->pev->flags, FL_MONSTER|FL_CLIENT))
@ -1404,6 +1406,8 @@ Schedule_t *CBabyVoltigore::GetSchedule(void)
break; break;
} }
default:
break;
} }
return CBaseMonster::GetSchedule(); return CBaseMonster::GetSchedule();
@ -1422,3 +1426,30 @@ Schedule_t *CBabyVoltigore::GetScheduleOfType(int Type)
break; break;
} }
} }
CBaseEntity *CBabyVoltigore::CheckTraceHullAttack( float flDist, int iDamage, int iDmgType )
{
TraceResult tr;
UTIL_MakeAimVectors( pev->angles );
Vector vecStart = pev->origin;
vecStart.z += pev->size.z;
Vector vecEnd = vecStart + ( gpGlobals->v_forward * flDist );
UTIL_TraceHull( vecStart, vecEnd, dont_ignore_monsters, head_hull, ENT( pev ), &tr );
if( tr.pHit )
{
CBaseEntity *pEntity = CBaseEntity::Instance( tr.pHit );
if( iDamage > 0 )
{
pEntity->TakeDamage( pev, pev, iDamage, iDmgType );
}
return pEntity;
}
return NULL;
}

Loading…
Cancel
Save