mirror of
https://github.com/GTAmodding/re3.git
synced 2025-01-13 23:48:21 +00:00
Fix ped buoyancy
This commit is contained in:
parent
f60e3d667a
commit
ab071163e5
1 changed files with 55 additions and 58 deletions
113
src/peds/Ped.cpp
113
src/peds/Ped.cpp
|
@ -17003,72 +17003,69 @@ CPed::ProcessBuoyancy(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
float speedMult = 0.0f;
|
}
|
||||||
if (buoyancyImpulse.z / m_fMass > GRAVITY * CTimer::GetTimeStep()
|
float speedMult = 0.0f;
|
||||||
|| mod_Buoyancy.m_waterlevel > GetPosition().z) {
|
if (buoyancyImpulse.z / m_fMass > GRAVITY * CTimer::GetTimeStep()
|
||||||
|
|| mod_Buoyancy.m_waterlevel > GetPosition().z + 0.6f) {
|
||||||
|
speedMult = pow(0.9f, CTimer::GetTimeStep());
|
||||||
|
m_vecMoveSpeed.x *= speedMult;
|
||||||
|
m_vecMoveSpeed.y *= speedMult;
|
||||||
|
m_vecMoveSpeed.z *= speedMult;
|
||||||
|
bIsStanding = false;
|
||||||
|
bIsDrowning = true;
|
||||||
|
InflictDamage(nil, WEAPONTYPE_DROWNING, 3.0f * CTimer::GetTimeStep(), PEDPIECE_TORSO, 0);
|
||||||
|
}
|
||||||
|
if (buoyancyImpulse.z / m_fMass > GRAVITY * 0.25f * CTimer::GetTimeStep()) {
|
||||||
|
if (speedMult == 0.0f) {
|
||||||
speedMult = pow(0.9f, CTimer::GetTimeStep());
|
speedMult = pow(0.9f, CTimer::GetTimeStep());
|
||||||
m_vecMoveSpeed.x *= speedMult;
|
|
||||||
m_vecMoveSpeed.y *= speedMult;
|
|
||||||
m_vecMoveSpeed.z *= speedMult;
|
|
||||||
bIsStanding = false;
|
|
||||||
bIsDrowning = true;
|
|
||||||
InflictDamage(nil, WEAPONTYPE_DROWNING, 3.0f * CTimer::GetTimeStep(), PEDPIECE_TORSO, 0);
|
|
||||||
}
|
|
||||||
if (buoyancyImpulse.z / m_fMass > GRAVITY * 0.25f * CTimer::GetTimeStep()) {
|
|
||||||
if (speedMult == 0.0f) {
|
|
||||||
speedMult = pow(0.9f, CTimer::GetTimeStep());
|
|
||||||
}
|
|
||||||
m_vecMoveSpeed.x *= speedMult;
|
|
||||||
m_vecMoveSpeed.y *= speedMult;
|
|
||||||
if (m_vecMoveSpeed.z >= -0.1f) {
|
|
||||||
if (m_vecMoveSpeed.z < -0.04f)
|
|
||||||
m_vecMoveSpeed.z = -0.02f;
|
|
||||||
} else {
|
|
||||||
m_vecMoveSpeed.z = -0.01f;
|
|
||||||
DMAudio.PlayOneShot(m_audioEntityId, SOUND_SPLASH, 0.0f);
|
|
||||||
CVector aBitForward = 2.2f * m_vecMoveSpeed + GetPosition();
|
|
||||||
float level = 0.0f;
|
|
||||||
if (CWaterLevel::GetWaterLevel(aBitForward, &level, false))
|
|
||||||
aBitForward.z = level;
|
|
||||||
|
|
||||||
CParticleObject::AddObject(POBJECT_PED_WATER_SPLASH, aBitForward, CVector(0.0f, 0.0f, 0.1f), 0.0f, 200, color, true);
|
|
||||||
nGenerateRaindrops = CTimer::GetTimeInMilliseconds() + 80;
|
|
||||||
nGenerateWaterCircles = CTimer::GetTimeInMilliseconds() + 100;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else
|
m_vecMoveSpeed.x *= speedMult;
|
||||||
return;
|
m_vecMoveSpeed.y *= speedMult;
|
||||||
} else
|
if (m_vecMoveSpeed.z >= -0.1f) {
|
||||||
bTouchingWater = false;
|
if (m_vecMoveSpeed.z < -0.04f)
|
||||||
|
m_vecMoveSpeed.z = -0.02f;
|
||||||
if (nGenerateWaterCircles && CTimer::GetTimeInMilliseconds() >= nGenerateWaterCircles) {
|
} else {
|
||||||
CVector pos = GetPosition();
|
m_vecMoveSpeed.z = -0.01f;
|
||||||
float level = 0.0f;
|
DMAudio.PlayOneShot(m_audioEntityId, SOUND_SPLASH, 0.0f);
|
||||||
if (CWaterLevel::GetWaterLevel(pos, &level, false))
|
CVector aBitForward = 2.2f * m_vecMoveSpeed + GetPosition();
|
||||||
pos.z = level;
|
float level = 0.0f;
|
||||||
|
if (CWaterLevel::GetWaterLevel(aBitForward, &level, false))
|
||||||
|
aBitForward.z = level;
|
||||||
|
|
||||||
if (pos.z != 0.0f) {
|
CParticleObject::AddObject(POBJECT_PED_WATER_SPLASH, aBitForward, CVector(0.0f, 0.0f, 0.1f), 0.0f, 200, color, true);
|
||||||
nGenerateWaterCircles = 0;
|
nGenerateRaindrops = CTimer::GetTimeInMilliseconds() + 80;
|
||||||
for(int i = 0; i < 4; i++) {
|
nGenerateWaterCircles = CTimer::GetTimeInMilliseconds() + 100;
|
||||||
pos.x += CGeneral::GetRandomNumberInRange(-0.75f, 0.75f);
|
|
||||||
pos.y += CGeneral::GetRandomNumberInRange(-0.75f, 0.75f);
|
|
||||||
CParticle::AddParticle(PARTICLE_RAIN_SPLASH_BIGGROW, pos, CVector(0.0f, 0.0f, 0.0f), nil, 0.0f, color, 0, 0, 0, 0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
if (nGenerateWaterCircles && CTimer::GetTimeInMilliseconds() >= nGenerateWaterCircles) {
|
||||||
|
CVector pos = GetPosition();
|
||||||
|
float level = 0.0f;
|
||||||
|
if (CWaterLevel::GetWaterLevel(pos, &level, false))
|
||||||
|
pos.z = level;
|
||||||
|
|
||||||
if (nGenerateRaindrops && CTimer::GetTimeInMilliseconds() >= nGenerateRaindrops) {
|
if (pos.z != 0.0f) {
|
||||||
CVector pos = GetPosition();
|
nGenerateWaterCircles = 0;
|
||||||
float level = 0.0f;
|
for(int i = 0; i < 4; i++) {
|
||||||
if (CWaterLevel::GetWaterLevel(pos, &level, false))
|
pos.x += CGeneral::GetRandomNumberInRange(-0.75f, 0.75f);
|
||||||
pos.z = level;
|
pos.y += CGeneral::GetRandomNumberInRange(-0.75f, 0.75f);
|
||||||
|
CParticle::AddParticle(PARTICLE_RAIN_SPLASH_BIGGROW, pos, CVector(0.0f, 0.0f, 0.0f), nil, 0.0f, color, 0, 0, 0, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (nGenerateRaindrops && CTimer::GetTimeInMilliseconds() >= nGenerateRaindrops) {
|
||||||
|
CVector pos = GetPosition();
|
||||||
|
float level = 0.0f;
|
||||||
|
if (CWaterLevel::GetWaterLevel(pos, &level, false))
|
||||||
|
pos.z = level;
|
||||||
|
|
||||||
if (pos.z >= 0.0f) {
|
if (pos.z >= 0.0f) {
|
||||||
pos.z += 0.25f;
|
pos.z += 0.25f;
|
||||||
nGenerateRaindrops = 0;
|
nGenerateRaindrops = 0;
|
||||||
CParticleObject::AddObject(POBJECT_SPLASHES_AROUND, pos, CVector(0.0f, 0.0f, 0.0f), 4.5f, 1500, CRGBA(0,0,0,0), true);
|
CParticleObject::AddObject(POBJECT_SPLASHES_AROUND, pos, CVector(0.0f, 0.0f, 0.0f), 4.5f, 1500, CRGBA(0,0,0,0), true);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
} else
|
||||||
|
bTouchingWater = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// --MIAMI: Done
|
// --MIAMI: Done
|
||||||
|
|
Loading…
Reference in a new issue