2015-06-30 15:46:07 +06:00
|
|
|
#include "precompiled.h"
|
|
|
|
|
2015-07-09 06:22:48 +06:00
|
|
|
#define GERMAN_GIB_COUNT 4
|
|
|
|
#define HUMAN_GIB_COUNT 6
|
|
|
|
#define ALIEN_GIB_COUNT 4
|
|
|
|
|
2015-06-30 15:46:07 +06:00
|
|
|
/* <5f4cb> ../cstrike/dlls/combat.cpp:52 */
|
2015-07-09 06:22:48 +06:00
|
|
|
void CGib::LimitVelocity(void)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-09 06:22:48 +06:00
|
|
|
float length = pev->velocity.Length();
|
|
|
|
|
|
|
|
// ceiling at 1500. The gib velocity equation is not bounded properly. Rather than tune it
|
|
|
|
// in 3 separate places again, I'll just limit it here.
|
|
|
|
if (length > 1500.0)
|
|
|
|
{
|
|
|
|
// This should really be sv_maxvelocity * 0.75 or something
|
|
|
|
pev->velocity = pev->velocity.Normalize() * 1500;
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <60320> ../cstrike/dlls/combat.cpp:63 */
|
|
|
|
NOBODY void CGib::SpawnStickyGibs(entvars_t *pevVictim, Vector vecOrigin, int cGibs)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// int i; // 65
|
|
|
|
// {
|
|
|
|
// class CGib *pGib; // 75
|
|
|
|
// GetClassPtr<CGib>(CGib *a); // 75
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 93
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 100
|
|
|
|
// Instance(entvars_t *pev); // 106
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 110
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 118
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// float X,
|
|
|
|
// float Y,
|
|
|
|
// float Z); // 124
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// float X,
|
|
|
|
// float Y,
|
|
|
|
// float Z); // 124
|
|
|
|
// LimitVelocity(CGib *const this); // 128
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 114
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5ff7f> ../cstrike/dlls/combat.cpp:132 */
|
|
|
|
NOBODY void CGib::SpawnHeadGib(entvars_t *pevVictim)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class CGib *pGib; // 134
|
|
|
|
// GetClassPtr<CGib>(CGib *a); // 134
|
|
|
|
// {
|
|
|
|
// edict_t *pentPlayer; // 151
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 149
|
|
|
|
// {
|
|
|
|
// entvars_t *pevPlayer; // 156
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 159
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 159
|
|
|
|
// Normalize(const Vector *const this); // 159
|
|
|
|
// }
|
|
|
|
// edict(CBaseEntity *const this); // 151
|
|
|
|
// Instance(entvars_t *pev); // 172
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 184
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 176
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 180
|
|
|
|
// }
|
|
|
|
// LimitVelocity(CGib *const this); // 187
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
2015-07-09 06:22:48 +06:00
|
|
|
void (*pCGib__SpawnRandomGibs)(entvars_t *pevVictim, int cGibs, int human);
|
|
|
|
|
2015-06-30 15:46:07 +06:00
|
|
|
/* <606c8> ../cstrike/dlls/combat.cpp:190 */
|
2015-07-09 06:22:48 +06:00
|
|
|
NOBODY void __declspec(naked) CGib::SpawnRandomGibs(entvars_t *pevVictim, int cGibs, int human)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-09 06:22:48 +06:00
|
|
|
// TODO: Reverse me!
|
|
|
|
__asm
|
|
|
|
{
|
|
|
|
jmp pCGib__SpawnRandomGibs
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f58a> ../cstrike/dlls/combat.cpp:263 */
|
|
|
|
NOBODY BOOL CBaseMonster::HasHumanGibs_(void)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// int myClass; // 265
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f5ca> ../cstrike/dlls/combat.cpp:278 */
|
|
|
|
NOBODY BOOL CBaseMonster::HasAlienGibs_(void)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// int myClass; // 280
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f60a> ../cstrike/dlls/combat.cpp:295 */
|
|
|
|
NOBODY void CBaseMonster::FadeMonster_(void)
|
|
|
|
{
|
|
|
|
// StopAnimation(CBaseMonster *const this); // 297
|
|
|
|
// SUB_StartFadeOut(CBaseEntity *const this); // 303
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <60a59> ../cstrike/dlls/combat.cpp:310 */
|
|
|
|
NOBODY void CBaseMonster::GibMonster_(void)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// TraceResult tr; // 312
|
|
|
|
// BOOL gibbed; // 313
|
|
|
|
// EMIT_SOUND(edict_t *entity,
|
|
|
|
// int channel,
|
|
|
|
// const char *sample,
|
|
|
|
// float volume,
|
|
|
|
// float attenuation); // 315
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f65e> ../cstrike/dlls/combat.cpp:355 */
|
|
|
|
NOBODY Activity CBaseMonster::GetDeathActivity_(void)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// Activity deathActivity; // 357
|
|
|
|
// BOOL fTriedDirection; // 358
|
|
|
|
// float flDot; // 359
|
|
|
|
// TraceResult tr; // 360
|
|
|
|
// class Vector vecSrc; // 361
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 375
|
|
|
|
// DotProduct(const Vector &a,
|
|
|
|
// const Vector &b); // 375
|
|
|
|
// edict(CBaseEntity *const this); // 461
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 461
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 461
|
|
|
|
// edict(CBaseEntity *const this); // 450
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 450
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 450
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f848> ../cstrike/dlls/combat.cpp:476 */
|
|
|
|
NOBODY Activity CBaseMonster::GetSmallFlinchActivity(void)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// Activity flinchActivity; // 478
|
|
|
|
// BOOL fTriedDirection; // 479
|
|
|
|
// float flDot; // 480
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f8a6> ../cstrike/dlls/combat.cpp:525 */
|
2015-07-05 17:05:26 +06:00
|
|
|
void CBaseMonster::BecomeDead_(void)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-05 17:05:26 +06:00
|
|
|
// don't let autoaim aim at corpses.
|
|
|
|
pev->takedamage = DAMAGE_YES;
|
|
|
|
|
|
|
|
// give the corpse half of the monster's original maximum health.
|
|
|
|
pev->health = pev->max_health / 2;
|
|
|
|
|
|
|
|
// max_health now becomes a counter for how many blood decals the corpse can place.
|
|
|
|
pev->max_health = 5;
|
|
|
|
|
|
|
|
// make the corpse fly away from the attack vector
|
|
|
|
pev->movetype = MOVETYPE_TOSS;
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f8cc> ../cstrike/dlls/combat.cpp:542 */
|
|
|
|
NOBODY BOOL CBaseMonster::ShouldGibMonster(int iGib)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f8f8> ../cstrike/dlls/combat.cpp:551 */
|
|
|
|
NOBODY void CBaseMonster::CallGibMonster(void)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// BOOL fade; // 553
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f938> ../cstrike/dlls/combat.cpp:598 */
|
|
|
|
NOBODY void CBaseMonster::Killed_(entvars_t *pevAttacker, int iGib)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// unsigned int cCount; // 600
|
|
|
|
// BOOL fDone; // 601
|
|
|
|
// class CBaseEntity *pOwner; // 619
|
|
|
|
// HasMemory(CBaseMonster *const this,
|
|
|
|
// int iMemory); // 603
|
|
|
|
// ShouldGibMonster(CBaseMonster *const this,
|
|
|
|
// int iGib); // 605
|
|
|
|
// Remember(CBaseMonster *const this,
|
|
|
|
// int iMemory); // 610
|
|
|
|
// EMIT_SOUND(edict_t *entity,
|
|
|
|
// int channel,
|
|
|
|
// const char *sample,
|
|
|
|
// float volume,
|
|
|
|
// float attenuation); // 613
|
|
|
|
// SetConditions(CBaseMonster *const this,
|
|
|
|
// int iConditions); // 616
|
|
|
|
// Instance(edict_t *pent); // 619
|
|
|
|
// ShouldGibMonster(CBaseMonster *const this,
|
|
|
|
// int iGib); // 625
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5e84e> ../cstrike/dlls/combat.cpp:652 */
|
2015-07-09 06:22:48 +06:00
|
|
|
void CBaseEntity::SUB_StartFadeOut(void)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-09 06:22:48 +06:00
|
|
|
if (pev->rendermode == kRenderNormal)
|
|
|
|
{
|
|
|
|
pev->renderamt = 255.0f;
|
|
|
|
pev->rendermode = kRenderTransTexture;
|
|
|
|
}
|
|
|
|
|
|
|
|
pev->solid = SOLID_NOT;
|
|
|
|
pev->avelocity = g_vecZero;
|
|
|
|
pev->nextthink = gpGlobals->time + 0.1f;
|
|
|
|
|
|
|
|
SetThink(&CBaseEntity::SUB_FadeOut);
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <5ea72> ../cstrike/dlls/combat.cpp:667 */
|
2015-07-09 06:22:48 +06:00
|
|
|
void CBaseEntity::SUB_FadeOut(void)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-09 06:22:48 +06:00
|
|
|
if (pev->renderamt > 7)
|
|
|
|
{
|
|
|
|
pev->renderamt -= 7.0f;
|
|
|
|
pev->nextthink = gpGlobals->time + 0.1f;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
pev->renderamt = 0.0f;
|
|
|
|
pev->nextthink = gpGlobals->time + 0.2f;
|
|
|
|
SetThink(&CBaseEntity::SUB_Remove);
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <5eab1> ../cstrike/dlls/combat.cpp:688 */
|
2015-07-09 06:22:48 +06:00
|
|
|
void CGib::WaitTillLand(void)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-09 06:22:48 +06:00
|
|
|
if (!IsInWorld())
|
|
|
|
{
|
|
|
|
UTIL_Remove(this);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pev->velocity == g_vecZero)
|
|
|
|
{
|
|
|
|
SetThink(&CBaseEntity::SUB_StartFadeOut);
|
|
|
|
pev->nextthink = gpGlobals->time + m_lifeTime;
|
|
|
|
|
|
|
|
if (m_bloodColor != DONT_BLEED)
|
|
|
|
CSoundEnt::InsertSound(bits_SOUND_MEAT, pev->origin, 384, 25);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
pev->nextthink = gpGlobals->time + 0.5f;
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <5eee0> ../cstrike/dlls/combat.cpp:718 */
|
2015-07-09 06:22:48 +06:00
|
|
|
void CGib::BounceGibTouch(CBaseEntity *pOther)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-09 06:22:48 +06:00
|
|
|
if (pev->flags & FL_ONGROUND)
|
|
|
|
{
|
|
|
|
pev->velocity = pev->velocity * 0.9;
|
|
|
|
pev->angles.x = 0;
|
|
|
|
pev->angles.z = 0;
|
|
|
|
pev->avelocity.x = 0;
|
|
|
|
pev->avelocity.z = 0;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (g_Language != LANGUAGE_GERMAN && m_cBloodDecals > 0 && m_bloodColor != DONT_BLEED)
|
|
|
|
{
|
|
|
|
TraceResult tr;
|
|
|
|
Vector vecSpot = pev->origin + Vector(0, 0, 8);
|
|
|
|
UTIL_TraceLine(vecSpot, vecSpot + Vector(0, 0, -24), ignore_monsters, ENT(pev), &tr);
|
|
|
|
UTIL_BloodDecalTrace(&tr, m_bloodColor);
|
|
|
|
m_cBloodDecals--;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m_material != matNone && !RANDOM_LONG(0, 2))
|
|
|
|
{
|
|
|
|
float zvel = fabs(pev->velocity.z);
|
|
|
|
float volume = 0.8 * min(1, zvel / 450);
|
|
|
|
|
|
|
|
CBreakable::MaterialSoundRandom(edict(), (Materials)m_material, volume);
|
|
|
|
}
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <5ed6d> ../cstrike/dlls/combat.cpp:761 */
|
|
|
|
NOBODY void CGib::StickyGibTouch(CBaseEntity *pOther)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class Vector vecSpot; // 763
|
|
|
|
// TraceResult tr; // 764
|
|
|
|
// FClassnameIs(entvars_t *pev,
|
|
|
|
// const char *szClassname); // 769
|
|
|
|
// }
|
|
|
|
// StickyGibTouch(CGib *const this,
|
|
|
|
// class CBaseEntity *pOther); // 761
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5fb0b> ../cstrike/dlls/combat.cpp:789 */
|
2015-07-09 06:22:48 +06:00
|
|
|
void CGib::Spawn(const char *szGibModel)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-09 06:22:48 +06:00
|
|
|
pev->movetype = MOVETYPE_BOUNCE;
|
|
|
|
|
|
|
|
// deading the bounce a bit
|
|
|
|
pev->friction = 0.55;
|
|
|
|
|
|
|
|
// sometimes an entity inherits the edict from a former piece of glass,
|
|
|
|
// and will spawn using the same render FX or rendermode! bad!
|
|
|
|
pev->renderamt = 255.0;
|
|
|
|
pev->rendermode = kRenderNormal;
|
|
|
|
pev->renderfx = kRenderFxNone;
|
|
|
|
|
|
|
|
/// hopefully this will fix the VELOCITY TOO LOW crap
|
|
|
|
pev->solid = SOLID_SLIDEBOX;
|
|
|
|
|
|
|
|
if (pev->classname)
|
|
|
|
RemoveEntityHashValue(pev, STRING(pev->classname), CLASSNAME);
|
|
|
|
|
|
|
|
MAKE_STRING_CLASS("gib", pev);
|
|
|
|
AddEntityHashValue(pev, STRING(pev->classname), CLASSNAME);
|
|
|
|
|
|
|
|
SET_MODEL(ENT(pev), szGibModel);
|
|
|
|
UTIL_SetSize(pev, Vector(0, 0, 0), Vector(0, 0, 0));
|
|
|
|
|
|
|
|
pev->nextthink = gpGlobals->time + 4.0f;
|
|
|
|
m_lifeTime = 25.0f;
|
|
|
|
|
|
|
|
SetThink(&CGib::WaitTillLand);
|
|
|
|
SetTouch(&CGib::BounceGibTouch);
|
|
|
|
|
|
|
|
m_material = matNone;
|
|
|
|
|
|
|
|
// how many blood decals this gib can place (1 per bounce until none remain).
|
|
|
|
m_cBloodDecals = 5;
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <60aea> ../cstrike/dlls/combat.cpp:815 */
|
|
|
|
int CBaseMonster::TakeHealth_(float flHealth, int bitsDamageType)
|
|
|
|
{
|
|
|
|
if (pev->takedamage == DAMAGE_NO)
|
|
|
|
return 0;
|
|
|
|
|
2015-07-05 17:05:26 +06:00
|
|
|
// clear out any damage types we healed.
|
|
|
|
// UNDONE: generic health should not heal any
|
|
|
|
// UNDONE: time-based damage
|
|
|
|
|
2015-06-30 15:46:07 +06:00
|
|
|
m_bitsDamageType &= ~(bitsDamageType & ~DMG_TIMEBASED);
|
|
|
|
return CBaseEntity::TakeHealth(flHealth, bitsDamageType);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <60d7a> ../cstrike/dlls/combat.cpp:845 */
|
|
|
|
NOBODY int CBaseMonster::TakeDamage_(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// float flTake; // 847
|
|
|
|
// class Vector vecDir; // 848
|
|
|
|
// FNullEnt(entvars_t *pev); // 872
|
|
|
|
// {
|
|
|
|
// class CBaseEntity *pInflictor; // 874
|
|
|
|
// Instance(entvars_t *pev); // 874
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 877
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 877
|
|
|
|
// Normalize(const Vector *const this); // 877
|
|
|
|
// Normalize(const Vector *const this); // 878
|
|
|
|
// }
|
|
|
|
// FNullEnt(entvars_t *pev); // 939
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 957
|
|
|
|
// SetConditions(CBaseMonster *const this,
|
|
|
|
// int iConditions); // 964
|
|
|
|
// SetConditions(CBaseMonster *const this,
|
|
|
|
// int iConditions); // 969
|
|
|
|
// SetConditions(CBaseMonster *const this,
|
|
|
|
// int iConditions); // 912
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 954
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 954
|
|
|
|
// HasConditions(CBaseMonster *const this,
|
|
|
|
// int iConditions); // 947
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <60b32> ../cstrike/dlls/combat.cpp:981 */
|
|
|
|
NOBODY int CBaseMonster::DeadTakeDamage(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int bitsDamageType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class Vector vecDir; // 983
|
|
|
|
// FNullEnt(entvars_t *pev); // 987
|
|
|
|
// {
|
|
|
|
// class CBaseEntity *pInflictor; // 989
|
|
|
|
// Instance(entvars_t *pev); // 989
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 992
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 992
|
|
|
|
// Normalize(const Vector *const this); // 992
|
|
|
|
// Normalize(const Vector *const this); // 993
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <61120> ../cstrike/dlls/combat.cpp:1027 */
|
|
|
|
NOBODY float CBaseMonster::DamageForce(float damage)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// float force; // 1029
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <61174> ../cstrike/dlls/combat.cpp:1044 */
|
|
|
|
NOBODY void RadiusFlash(Vector vecSrc, entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int iClassIgnore, int bitsDamageType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class CBaseEntity *pEntity; // 1046
|
|
|
|
// TraceResult tr; // 1047
|
|
|
|
// float flAdjustedDamage; // 1048
|
|
|
|
// float falloff; // 1048
|
|
|
|
// class Vector vecSpot; // 1049
|
|
|
|
// float flRadius; // 1050
|
|
|
|
// int bInWater; // 1058
|
|
|
|
// edict(CBaseEntity *const this); // 1085
|
|
|
|
// {
|
|
|
|
// TraceResult tr2; // 1088
|
|
|
|
// class Vector vecLOS; // 1110
|
|
|
|
// float flDot; // 1111
|
|
|
|
// float fadeTime; // 1120
|
|
|
|
// float fadeHold; // 1120
|
|
|
|
// int alpha; // 1121
|
|
|
|
// class CBasePlayer *pPlayer; // 1137
|
|
|
|
// float currentHoldTime; // 1140
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 1102
|
|
|
|
// Length(const Vector *const this); // 1102
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1115
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 1115
|
|
|
|
// DotProduct(const Vector &a,
|
|
|
|
// const Vector &b); // 1117
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// float X,
|
|
|
|
// float Y,
|
|
|
|
// float Z); // 1157
|
|
|
|
// {
|
|
|
|
// int i; // 1160
|
|
|
|
// {
|
|
|
|
// class CBasePlayer *pObserver;// 1162
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// float X,
|
|
|
|
// float Y,
|
|
|
|
// float Z); // 1166
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5f042> ../cstrike/dlls/combat.cpp:1185 */
|
|
|
|
NOBODY void GetAmountOfPlayerVisible(Vector vecSrc, CBaseEntity *entity)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// float retval; // 1187
|
|
|
|
// TraceResult tr; // 1189
|
|
|
|
// floatconst topOfHead; // 1204
|
|
|
|
// class Vector spot; // 1216
|
|
|
|
// class Vector2D dir; // 1232
|
|
|
|
// floatconst standFeet; // 1205
|
|
|
|
// floatconst crouchFeet; // 1206
|
|
|
|
// class Vector2D perp; // 1234
|
|
|
|
// floatconst edgeOffset; // 1235
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// float X,
|
|
|
|
// float Y,
|
|
|
|
// float Z); // 1216
|
|
|
|
// NormalizeInPlace(Vector2D *const this); // 1233
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5dc27> ../cstrike/dlls/combat.cpp:1262 */
|
|
|
|
NOBODY void RadiusDamage(Vector vecSrc, entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, float flRadius, int iClassIgnore, int bitsDamageType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class CBaseEntity *pEntity; // 1264
|
|
|
|
// TraceResult tr; // 1265
|
|
|
|
// float flAdjustedDamage; // 1266
|
|
|
|
// float falloff; // 1266
|
|
|
|
// class Vector vecSpot; // 1267
|
|
|
|
// int bInWater; // 1275
|
|
|
|
// {
|
|
|
|
// bool useLOS; // 1300
|
|
|
|
// float damageRatio; // 1305
|
|
|
|
// float length; // 1308
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5dcf9> ../cstrike/dlls/combat.cpp:1349 */
|
|
|
|
NOBODY void RadiusDamage2(Vector vecSrc, entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, float flRadius, int iClassIgnore, int bitsDamageType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class CBaseEntity *pEntity; // 1351
|
|
|
|
// TraceResult tr; // 1352
|
|
|
|
// float flAdjustedDamage; // 1353
|
|
|
|
// float falloff; // 1353
|
|
|
|
// class Vector vecSpot; // 1354
|
|
|
|
// int bInWater; // 1362
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
2015-07-05 17:05:26 +06:00
|
|
|
/* <5e0d2> ../cstrike/dlls/combat.cpp:1442 */
|
|
|
|
NOBODY void CBaseMonster::RadiusDamage(entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int iClassIgnore, int bitsDamageType)
|
|
|
|
{
|
|
|
|
if (flDamage > 80)
|
|
|
|
::RadiusDamage(pev->origin, pevInflictor, pevAttacker, flDamage, flDamage * 3.5, iClassIgnore, bitsDamageType);
|
|
|
|
else
|
|
|
|
RadiusDamage2(pev->origin, pevInflictor, pevAttacker, flDamage, iClassIgnore, bitsDamageType);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5e0d2> ../cstrike/dlls/combat.cpp:1448 */
|
|
|
|
NOXREF void CBaseMonster::RadiusDamage(Vector vecSrc, entvars_t *pevInflictor, entvars_t *pevAttacker, float flDamage, int iClassIgnore, int bitsDamageType)
|
|
|
|
{
|
|
|
|
if (flDamage > 80)
|
|
|
|
::RadiusDamage(vecSrc, pevInflictor, pevAttacker, flDamage, flDamage * 3.5, iClassIgnore, bitsDamageType);
|
|
|
|
else
|
|
|
|
RadiusDamage2(vecSrc, pevInflictor, pevAttacker, flDamage, iClassIgnore, bitsDamageType);
|
|
|
|
}
|
|
|
|
|
2015-06-30 15:46:07 +06:00
|
|
|
/* <61949> ../cstrike/dlls/combat.cpp:1454 */
|
|
|
|
NOBODY CBaseEntity *CBaseMonster::CheckTraceHullAttack(float flDist, int iDamage, int iDmgType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// TraceResult tr; // 1456
|
|
|
|
// class Vector vecStart; // 1463
|
|
|
|
// class Vector vecEnd; // 1465
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1463
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 1465
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1465
|
|
|
|
// {
|
|
|
|
// class CBaseEntity *pEntity; // 1471
|
|
|
|
// Instance(edict_t *pent); // 1471
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <61ae6> ../cstrike/dlls/combat.cpp:1490 */
|
|
|
|
NOBODY BOOL CBaseMonster::FInViewCone_(CBaseEntity *pEntity)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class Vector2D vec2LOS; // 1492
|
|
|
|
// float flDot; // 1493
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 1497
|
|
|
|
// Normalize(const class Vector2D *const this); // 1498
|
|
|
|
// DotProduct(const class Vector2D &a,
|
|
|
|
// const class Vector2D &b); // 1500
|
|
|
|
// }
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <61be6> ../cstrike/dlls/combat.cpp:1517 */
|
|
|
|
NOBODY BOOL CBaseMonster::FInViewCone_(Vector *pOrigin)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class Vector2D vec2LOS; // 1519
|
|
|
|
// float flDot; // 1520
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 1524
|
|
|
|
// Normalize(const class Vector2D *const this); // 1525
|
|
|
|
// DotProduct(const class Vector2D &a,
|
|
|
|
// const class Vector2D &b); // 1527
|
|
|
|
// }
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5ecb4> ../cstrike/dlls/combat.cpp:1543 */
|
|
|
|
NOBODY BOOL CBaseEntity::FVisible_(CBaseEntity *pEntity)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// TraceResult tr; // 1545
|
|
|
|
// class Vector vecLookerOrigin; // 1546
|
|
|
|
// class Vector vecTargetOrigin; // 1547
|
|
|
|
// }
|
|
|
|
// FVisible(CBaseEntity *const this,
|
|
|
|
// class CBaseEntity *pEntity); // 1543
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5e9bb> ../cstrike/dlls/combat.cpp:1576 */
|
|
|
|
NOBODY BOOL CBaseEntity::FVisible_(Vector &vecOrigin)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// TraceResult tr; // 1578
|
|
|
|
// class Vector vecLookerOrigin; // 1579
|
|
|
|
// }
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5e872> ../cstrike/dlls/combat.cpp:1600 */
|
|
|
|
NOBODY void CBaseEntity::TraceAttack_(entvars_t *pevAttacker, float flDamage, Vector vecDir, TraceResult *ptr, int bitsDamageType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class Vector vecOrigin; // 1602
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 1602
|
|
|
|
// {
|
|
|
|
// int blood; // 1608
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1612
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1613
|
|
|
|
// }
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 1602
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <61ce5> ../cstrike/dlls/combat.cpp:1647 */
|
|
|
|
NOBODY void CBaseMonster::TraceAttack_(entvars_t *pevAttacker, float flDamage, Vector vecDir, TraceResult *ptr, int bitsDamageType)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// class Vector vecOrigin; // 1684
|
|
|
|
// int blood; // 1687
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 1684
|
|
|
|
// operator-(const Vector *const this,
|
|
|
|
// const Vector &v); // 1684
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1691
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <61df9> ../cstrike/dlls/combat.cpp:1704 */
|
|
|
|
NOBODY void CBaseEntity::FireBullets(ULONG cShots, Vector vecSrc, Vector vecDirShooting, Vector vecSpread, float flDistance, int iBulletType, int iTracerFreq, int iDamage, entvars_t *pevAttacker)
|
|
|
|
{
|
|
|
|
// {
|
|
|
|
// int tracerCount; // 1706
|
|
|
|
// int tracer; // 1707
|
|
|
|
// TraceResult tr; // 1708
|
|
|
|
// class Vector vecRight; // 1709
|
|
|
|
// class Vector vecUp; // 1710
|
|
|
|
// bool m_bCreatedShotgunSpark; // 1711
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1709
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1710
|
|
|
|
// {
|
|
|
|
// ULONG iShot; // 1722
|
|
|
|
// {
|
|
|
|
// int spark; // 1724
|
|
|
|
// float x; // 1727
|
|
|
|
// float y; // 1727
|
|
|
|
// float z; // 1727
|
|
|
|
// class Vector vecDir; // 1734
|
|
|
|
// class Vector vecEnd; // 1737
|
|
|
|
// operator*(float fl,
|
|
|
|
// const Vector &v); // 1736
|
|
|
|
// operator*(float fl,
|
|
|
|
// const Vector &v); // 1736
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1736
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1736
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 1739
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1739
|
|
|
|
// {
|
|
|
|
// class Vector vecTracerSrc; // 1745
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 1749
|
|
|
|
// operator*(const Vector *const this,
|
|
|
|
// float fl); // 1749
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1749
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1749
|
|
|
|
// operator+(const Vector *const this,
|
|
|
|
// const Vector &v); // 1749
|
|
|
|
// MESSAGE_BEGIN(int msg_dest,
|
|
|
|
// int msg_type,
|
|
|
|
// const float *pOrigin,
|
|
|
|
// edict_t *ed); // 1765
|
|
|
|
// }
|
|
|
|
// {
|
|
|
|
// class CBaseEntity *pEntity; // 1780
|
|
|
|
// Instance(edict_t *pent); // 1780
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1784
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1786
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1786
|
|
|
|
// {
|
|
|
|
// float flDamage; // 1802
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1793
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1830
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1822
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1824
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1824
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1814
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1816
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1816
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1806
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1810
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1797
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1839
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1840
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1840
|
|
|
|
// FNullEnt(const edict_t *pent); // 1842
|
|
|
|
// VARS(edict_t *pent); // 1842
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1833
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1833
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1851
|
|
|
|
// Vector(Vector *const this,
|
|
|
|
// const Vector &v); // 1851
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <62693> ../cstrike/dlls/combat.cpp:1856 */
|
2015-07-05 17:05:26 +06:00
|
|
|
NOXREF char *vstr(float *v)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-05 17:05:26 +06:00
|
|
|
static int idx = 0;
|
|
|
|
static char string[ 16 ][ 1024 ];
|
|
|
|
|
|
|
|
idx = (idx + 1) % 0xF;
|
|
|
|
Q_sprintf(string[ idx ], "%.4f %.4f %.4f", v[0], v[1], v[2]);
|
|
|
|
|
|
|
|
return string[ idx ];
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
Vector (*pFireBullets3)(Vector, Vector, float, float, int, int, int, float, entvars_t *, bool, int);
|
|
|
|
|
|
|
|
/* <62709> ../cstrike/dlls/combat.cpp:1869 */
|
|
|
|
Vector __declspec(naked) CBaseEntity::FireBullets3(Vector vecSrc, Vector vecDirShooting, float vecSpread, float flDistance, int iPenetration, int iBulletType, int iDamage, float flRangeModifier, entvars_t *pevAttacker, bool bPistol, int shared_rand)
|
|
|
|
{
|
|
|
|
UNTESTED
|
2015-07-05 17:05:26 +06:00
|
|
|
//TODO: crash a test to czero
|
2015-06-30 15:46:07 +06:00
|
|
|
|
|
|
|
__asm
|
|
|
|
{
|
|
|
|
jmp pFireBullets3
|
|
|
|
}
|
|
|
|
/* int iOriginalPenetration = iPenetration;
|
|
|
|
int iPenetrationPower;
|
|
|
|
|
|
|
|
//int iSparksAmount;
|
|
|
|
int iCurrentDamage = iDamage;
|
|
|
|
|
|
|
|
float flPenetrationDistance;
|
|
|
|
float flCurrentDistance;
|
|
|
|
|
|
|
|
TraceResult tr;
|
|
|
|
TraceResult tr2;
|
|
|
|
|
|
|
|
CBaseEntity *pEntity;
|
|
|
|
Vector vecDir;
|
|
|
|
Vector vecEnd;
|
|
|
|
|
|
|
|
bool bHitMetal = false;
|
|
|
|
|
|
|
|
Vector vecRight = gpGlobals->v_right;
|
|
|
|
Vector vecUp = gpGlobals->v_up;
|
|
|
|
|
|
|
|
switch (iBulletType)
|
|
|
|
{
|
|
|
|
case BULLET_PLAYER_9MM:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 21;
|
|
|
|
flPenetrationDistance = 800;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BULLET_PLAYER_45ACP:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 15;
|
|
|
|
flPenetrationDistance = 500;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BULLET_PLAYER_50AE:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 30;
|
|
|
|
flPenetrationDistance = 1000;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BULLET_PLAYER_762MM:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 39;
|
|
|
|
flPenetrationDistance = 5000.0f;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BULLET_PLAYER_556MM:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 35;
|
|
|
|
flPenetrationDistance = 4000;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BULLET_PLAYER_338MAG:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 45;
|
|
|
|
flPenetrationDistance = 8000;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BULLET_PLAYER_57MM:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 30;
|
|
|
|
flPenetrationDistance = 2000;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case BULLET_PLAYER_357SIG:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 25;
|
|
|
|
flPenetrationDistance = 800;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
iPenetrationPower = 0;
|
|
|
|
flPenetrationDistance = 0;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!pevAttacker)
|
2015-07-05 17:05:26 +06:00
|
|
|
pevAttacker = pev; // the default attacker is ourselves
|
2015-06-30 15:46:07 +06:00
|
|
|
|
|
|
|
gMultiDamage.type = (DMG_BULLET | DMG_NEVERGIB);
|
|
|
|
|
|
|
|
float x, y, z;
|
|
|
|
|
|
|
|
if (IsPlayer())
|
|
|
|
{
|
2015-07-05 17:05:26 +06:00
|
|
|
// Use player's random seed.
|
|
|
|
// get circular gaussian spread
|
2015-06-30 15:46:07 +06:00
|
|
|
x = UTIL_SharedRandomFloat(shared_rand, -0.5, 0.5) + UTIL_SharedRandomFloat(shared_rand + 1, -0.5, 0.5);
|
|
|
|
y = UTIL_SharedRandomFloat(shared_rand + 2, -0.5, 0.5) + UTIL_SharedRandomFloat(shared_rand + 3, -0.5, 0.5);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
do
|
|
|
|
{
|
|
|
|
x = RANDOM_FLOAT(-0.5, 0.5) + RANDOM_FLOAT(-0.5, 0.5);
|
|
|
|
y = RANDOM_FLOAT(-0.5, 0.5) + RANDOM_FLOAT(-0.5, 0.5);
|
|
|
|
z = x * x + y * y;
|
|
|
|
}
|
|
|
|
while (z > 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
vecDir = vecDirShooting + x * vecSpread * vecRight + y * vecSpread * vecUp;
|
|
|
|
vecEnd = vecSrc + vecDir * flDistance;
|
|
|
|
|
|
|
|
float flDamageModifier = 0.5;
|
|
|
|
|
|
|
|
while (iPenetration != 0)
|
|
|
|
{
|
|
|
|
ClearMultiDamage();
|
|
|
|
UTIL_TraceLine(vecSrc, vecEnd, dont_ignore_monsters, ENT(pev), &tr);
|
|
|
|
|
|
|
|
if (tr.flFraction != 1)
|
|
|
|
TheBots->OnEvent(EVENT_BULLET_IMPACT, this, NULL);
|
|
|
|
|
|
|
|
switch (UTIL_TextureHit(&tr, vecSrc, vecEnd))
|
|
|
|
{
|
|
|
|
case CHAR_TEX_METAL:
|
|
|
|
{
|
|
|
|
bHitMetal = true;
|
|
|
|
iPenetrationPower *= 0.15;
|
|
|
|
flDamageModifier = 0.2;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CHAR_TEX_CONCRETE:
|
|
|
|
{
|
|
|
|
iPenetrationPower *= 0.25;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CHAR_TEX_GRATE:
|
|
|
|
{
|
|
|
|
bHitMetal = true;
|
|
|
|
iPenetrationPower *= 0.5;
|
|
|
|
flDamageModifier = 0.4;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CHAR_TEX_VENT:
|
|
|
|
{
|
|
|
|
bHitMetal = true;
|
|
|
|
iPenetrationPower *= 0.5;
|
|
|
|
flDamageModifier = 0.45;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CHAR_TEX_TILE:
|
|
|
|
{
|
|
|
|
iPenetrationPower *= 0.65;
|
|
|
|
flDamageModifier = 0.3;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CHAR_TEX_COMPUTER:
|
|
|
|
{
|
|
|
|
bHitMetal = true;
|
|
|
|
iPenetrationPower *= 0.4;
|
|
|
|
flDamageModifier = 0.45;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case CHAR_TEX_WOOD:
|
|
|
|
{
|
|
|
|
flDamageModifier = 0.6;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
if (tr.flFraction != 1.0)
|
|
|
|
{
|
|
|
|
pEntity = CBaseEntity::Instance(tr.pHit);
|
|
|
|
iPenetration--;
|
|
|
|
|
|
|
|
flCurrentDistance = tr.flFraction * flDistance;
|
|
|
|
iCurrentDamage *= pow(flRangeModifier, flCurrentDistance / 500);
|
|
|
|
|
|
|
|
if (flCurrentDistance > flPenetrationDistance)
|
|
|
|
iPenetration = 0;
|
|
|
|
|
|
|
|
if (tr.iHitgroup == HITGROUP_SHIELD)
|
|
|
|
{
|
|
|
|
if (RANDOM_LONG(0, 1))
|
|
|
|
EMIT_SOUND(pEntity->edict(), CHAN_VOICE, "weapons/ric_metal-1.wav", VOL_NORM, ATTN_NORM);
|
|
|
|
else
|
|
|
|
EMIT_SOUND(pEntity->edict(), CHAN_VOICE, "weapons/ric_metal-2.wav", VOL_NORM, ATTN_NORM);
|
|
|
|
|
|
|
|
UTIL_Sparks(tr.vecEndPos);
|
|
|
|
|
|
|
|
pEntity->pev->punchangle.x = iCurrentDamage * RANDOM_FLOAT(-0.15, 0.15);
|
|
|
|
pEntity->pev->punchangle.z = iCurrentDamage * RANDOM_FLOAT(-0.15, 0.15);
|
|
|
|
|
|
|
|
if (pEntity->pev->punchangle.x < 4)
|
|
|
|
pEntity->pev->punchangle.x = -4;//TODO:?? 4 ?
|
|
|
|
|
|
|
|
if (pEntity->pev->punchangle.z < -5)
|
|
|
|
pEntity->pev->punchangle.z = -5;
|
|
|
|
|
|
|
|
else if (pEntity->pev->punchangle.z > 5)
|
|
|
|
pEntity->pev->punchangle.z = 5;
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
float flDistanceModifier;
|
|
|
|
//if (VARS(tr.pHit)->solid != SOLID_BSP || !iPenetration)
|
|
|
|
if (pEntity->pev->solid != SOLID_BSP || !iPenetration)
|
|
|
|
{
|
|
|
|
iPenetrationPower = 42;
|
|
|
|
flDamageModifier = 0.75;
|
|
|
|
flDistanceModifier = 0.75;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
flDistanceModifier = 0.5;
|
|
|
|
|
|
|
|
DecalGunshot(&tr, iBulletType, (!bPistol && RANDOM_LONG(0, 3)), pev, bHitMetal);
|
|
|
|
|
|
|
|
vecSrc = tr.vecEndPos + (vecDir * iPenetrationPower);
|
|
|
|
flDistance = (flDistance - flCurrentDistance) * flDistanceModifier;
|
|
|
|
vecEnd = vecSrc + (vecDir * flDistance);
|
|
|
|
|
|
|
|
pEntity->TraceAttack(pevAttacker, iCurrentDamage, vecDir, &tr, DMG_BULLET | DMG_NEVERGIB);
|
|
|
|
iCurrentDamage *= flDamageModifier;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
iPenetration = 0;
|
|
|
|
|
|
|
|
ApplyMultiDamage(pev, pevAttacker);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Vector(x * vecSpread, y * vecSpread, 0);*/
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <5eb17> ../cstrike/dlls/combat.cpp:2075 */
|
|
|
|
void CBaseEntity::TraceBleed_(float flDamage, Vector vecDir, TraceResult *ptr, int bitsDamageType)
|
|
|
|
{
|
|
|
|
if (BloodColor() == DONT_BLEED)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (!flDamage)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (!(bitsDamageType & (DMG_CRUSH | DMG_BULLET | DMG_SLASH | DMG_BLAST | DMG_CLUB | DMG_MORTAR)))
|
|
|
|
return;
|
|
|
|
|
2015-07-05 17:05:26 +06:00
|
|
|
// make blood decal on the wall!
|
2015-06-30 15:46:07 +06:00
|
|
|
TraceResult Bloodtr;
|
|
|
|
Vector vecTraceDir;
|
|
|
|
float flNoise;
|
|
|
|
int cCount;
|
2015-07-05 17:05:26 +06:00
|
|
|
int i;
|
2015-06-30 15:46:07 +06:00
|
|
|
|
|
|
|
if (flDamage < 10.0f)
|
|
|
|
{
|
|
|
|
flNoise = 0.1f;
|
|
|
|
cCount = 1;
|
|
|
|
}
|
|
|
|
else if (flDamage < 25.0f)
|
|
|
|
{
|
|
|
|
flNoise = 0.2f;
|
|
|
|
cCount = 2;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
flNoise = 0.3f;
|
|
|
|
cCount = 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < cCount; i++)
|
|
|
|
{
|
2015-07-05 17:05:26 +06:00
|
|
|
// trace in the opposite direction the shot came from (the direction the shot is going)
|
2015-06-30 15:46:07 +06:00
|
|
|
vecTraceDir = vecDir * -1.0f;
|
2015-07-05 17:05:26 +06:00
|
|
|
|
2015-06-30 15:46:07 +06:00
|
|
|
vecTraceDir.x += RANDOM_FLOAT(-flNoise, flNoise);
|
|
|
|
vecTraceDir.y += RANDOM_FLOAT(-flNoise, flNoise);
|
|
|
|
vecTraceDir.z += RANDOM_FLOAT(-flNoise, flNoise);
|
|
|
|
|
|
|
|
UTIL_TraceLine(ptr->vecEndPos, ptr->vecEndPos + vecTraceDir * -172.0f, ignore_monsters, ENT(pev), &Bloodtr);
|
|
|
|
if (Bloodtr.flFraction != 1.0f)
|
|
|
|
{
|
|
|
|
if (!RANDOM_LONG(0, 2))
|
|
|
|
UTIL_BloodDecalTrace(&Bloodtr, BloodColor());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* <62e0e> ../cstrike/dlls/combat.cpp:2145 */
|
2015-07-05 17:05:26 +06:00
|
|
|
NOXREF void CBaseMonster::MakeDamageBloodDecal(int cCount, float flNoise, TraceResult *ptr, Vector &vecDir)
|
2015-06-30 15:46:07 +06:00
|
|
|
{
|
2015-07-05 17:05:26 +06:00
|
|
|
// make blood decal on the wall!
|
|
|
|
TraceResult Bloodtr;
|
|
|
|
Vector vecTraceDir;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if (!IsAlive())
|
|
|
|
{
|
|
|
|
// dealing with a dead monster.
|
|
|
|
if (pev->max_health <= 0)
|
|
|
|
{
|
|
|
|
// no blood decal for a monster that has already decalled its limit.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
pev->max_health--;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0 ; i < cCount ; i++)
|
|
|
|
{
|
|
|
|
vecTraceDir = vecDir;
|
|
|
|
|
|
|
|
vecTraceDir.x += RANDOM_FLOAT(-flNoise, flNoise);
|
|
|
|
vecTraceDir.y += RANDOM_FLOAT(-flNoise, flNoise);
|
|
|
|
vecTraceDir.z += RANDOM_FLOAT(-flNoise, flNoise);
|
|
|
|
|
|
|
|
UTIL_TraceLine(ptr->vecEndPos, ptr->vecEndPos + vecTraceDir * 172, ignore_monsters, ENT(pev), &Bloodtr);
|
|
|
|
|
|
|
|
if (Bloodtr.flFraction != 1.0)
|
|
|
|
{
|
|
|
|
UTIL_BloodDecalTrace(&Bloodtr, BloodColor());
|
|
|
|
}
|
|
|
|
}
|
2015-06-30 15:46:07 +06:00
|
|
|
}
|
|
|
|
|
|
|
|
/* <62f3e> ../cstrike/dlls/combat.cpp:2197 */
|
|
|
|
void CBaseMonster::BloodSplat(const Vector &vecSrc, const Vector &vecDir, int HitLocation, int iVelocity)
|
|
|
|
{
|
|
|
|
if (HitLocation != HITGROUP_HEAD)
|
|
|
|
return;
|
|
|
|
|
|
|
|
MESSAGE_BEGIN(MSG_PVS, SVC_TEMPENTITY, vecSrc);
|
|
|
|
WRITE_BYTE(TE_BLOODSTREAM);
|
|
|
|
WRITE_COORD(vecSrc.x);
|
|
|
|
WRITE_COORD(vecSrc.y);
|
|
|
|
WRITE_COORD(vecSrc.z);
|
|
|
|
WRITE_COORD(vecDir.x);
|
|
|
|
WRITE_COORD(vecDir.y);
|
|
|
|
WRITE_COORD(vecDir.z);
|
|
|
|
WRITE_BYTE(223);
|
|
|
|
WRITE_BYTE(iVelocity + RANDOM_LONG(0, 100));
|
|
|
|
MESSAGE_END();
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef HOOK_GAMEDLL
|
|
|
|
|
|
|
|
void CBaseMonster::KeyValue(KeyValueData *pkvd)
|
|
|
|
{
|
|
|
|
KeyValue_(pkvd);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CBaseMonster::TraceAttack(entvars_t *pevAttacker,float flDamage,Vector vecDir,TraceResult *ptr,int bitsDamageType)
|
|
|
|
{
|
|
|
|
TraceAttack_(pevAttacker, flDamage, vecDir, ptr, bitsDamageType);
|
|
|
|
}
|
|
|
|
|
|
|
|
int CBaseMonster::TakeDamage(entvars_t *pevInflictor,entvars_t *pevAttacker,float flDamage,int bitsDamageType)
|
|
|
|
{
|
|
|
|
return TakeDamage_(pevInflictor, pevAttacker, flDamage, bitsDamageType);
|
|
|
|
}
|
|
|
|
|
|
|
|
int CBaseMonster::TakeHealth(float flHealth,int bitsDamageType)
|
|
|
|
{
|
|
|
|
return TakeHealth_(flHealth, bitsDamageType);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CBaseMonster::Killed(entvars_t *pevAttacker,int iGib)
|
|
|
|
{
|
|
|
|
Killed_(pevAttacker, iGib);
|
|
|
|
}
|
|
|
|
|
|
|
|
float CBaseMonster::ChangeYaw(int speed)
|
|
|
|
{
|
|
|
|
return ChangeYaw_(speed);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL CBaseMonster::HasHumanGibs(void)
|
|
|
|
{
|
|
|
|
return HasHumanGibs_();
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL CBaseMonster::HasAlienGibs(void)
|
|
|
|
{
|
|
|
|
return HasHumanGibs_();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CBaseMonster::FadeMonster(void)
|
|
|
|
{
|
|
|
|
FadeMonster_();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CBaseMonster::GibMonster(void)
|
|
|
|
{
|
|
|
|
GibMonster_();
|
|
|
|
}
|
|
|
|
|
|
|
|
Activity CBaseMonster::GetDeathActivity(void)
|
|
|
|
{
|
|
|
|
return GetDeathActivity_();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CBaseMonster::BecomeDead(void)
|
|
|
|
{
|
|
|
|
BecomeDead_();
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL CBaseMonster::ShouldFadeOnDeath(void)
|
|
|
|
{
|
|
|
|
return ShouldFadeOnDeath_();
|
|
|
|
}
|
|
|
|
|
|
|
|
int CBaseMonster::IRelationship(CBaseEntity *pTarget)
|
|
|
|
{
|
|
|
|
return IRelationship_(pTarget);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CBaseMonster::MonsterInitDead(void)
|
|
|
|
{
|
|
|
|
MonsterInitDead_();
|
|
|
|
}
|
|
|
|
|
|
|
|
void CBaseMonster::Look(int iDistance)
|
|
|
|
{
|
|
|
|
Look_(iDistance);
|
|
|
|
}
|
|
|
|
|
|
|
|
CBaseEntity *CBaseMonster::BestVisibleEnemy(void)
|
|
|
|
{
|
|
|
|
return BestVisibleEnemy_();
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL CBaseMonster::FInViewCone(CBaseEntity *pEntity)
|
|
|
|
{
|
|
|
|
return FInViewCone_(pEntity);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL CBaseMonster::FInViewCone(Vector *pOrigin)
|
|
|
|
{
|
|
|
|
return FInViewCone_(pOrigin);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // HOOK_GAMEDLL
|