CScriptPickup: Brace conditionals where applicable

This commit is contained in:
Lioncash 2020-05-07 13:02:52 -04:00
parent c3f723007e
commit 510778b7cd
1 changed files with 23 additions and 16 deletions

View File

@ -29,11 +29,13 @@ CScriptPickup::CScriptPickup(TUniqueId uid, std::string_view name, const CEntity
, x268_fadeInTime(fadeInTime) , x268_fadeInTime(fadeInTime)
, x26c_lifeTime(lifeTime) , x26c_lifeTime(lifeTime)
, x278_delayTimer(startDelay) { , x278_delayTimer(startDelay) {
if (pickupEffect.IsValid()) if (pickupEffect.IsValid()) {
x27c_pickupParticleDesc = g_SimplePool->GetObj({SBIG('PART'), pickupEffect}); x27c_pickupParticleDesc = g_SimplePool->GetObj({SBIG('PART'), pickupEffect});
}
if (x64_modelData && x64_modelData->GetAnimationData()) if (x64_modelData && x64_modelData->GetAnimationData()) {
x64_modelData->GetAnimationData()->SetAnimation(CAnimPlaybackParms(0, -1, 1.f, true), false); x64_modelData->GetAnimationData()->SetAnimation(CAnimPlaybackParms(0, -1, 1.f, true), false);
}
if (x278_delayTimer != 0.f) { if (x278_delayTimer != 0.f) {
xb4_drawFlags = CModelFlags(5, 0, 3, zeus::CColor(1.f, 1.f, 1.f, 0.f)); xb4_drawFlags = CModelFlags(5, 0, 3, zeus::CColor(1.f, 1.f, 1.f, 0.f));
@ -45,8 +47,9 @@ CScriptPickup::CScriptPickup(TUniqueId uid, std::string_view name, const CEntity
void CScriptPickup::Accept(IVisitor& visitor) { visitor.Visit(this); } void CScriptPickup::Accept(IVisitor& visitor) { visitor.Visit(this); }
void CScriptPickup::Think(float dt, CStateManager& mgr) { void CScriptPickup::Think(float dt, CStateManager& mgr) {
if (!GetActive()) if (!GetActive()) {
return; return;
}
if (x278_delayTimer >= 0.f) { if (x278_delayTimer >= 0.f) {
CPhysicsActor::Stop(); CPhysicsActor::Stop();
@ -55,8 +58,9 @@ void CScriptPickup::Think(float dt, CStateManager& mgr) {
} }
x270_curTime += dt; x270_curTime += dt;
if (x28c_25_inTractor && (x26c_lifeTime - x270_curTime) < 2.f) if (x28c_25_inTractor && (x26c_lifeTime - x270_curTime) < 2.f) {
x270_curTime = zeus::max(x270_curTime - 2.f * dt, x26c_lifeTime - 2.f - FLT_EPSILON); x270_curTime = zeus::max(x270_curTime - 2.f * dt, x26c_lifeTime - 2.f - FLT_EPSILON);
}
CModelFlags drawFlags{0, 0, 3, zeus::CColor(1.f, 1.f, 1.f, 1.f)}; CModelFlags drawFlags{0, 0, 3, zeus::CColor(1.f, 1.f, 1.f, 1.f)};
@ -70,10 +74,11 @@ void CScriptPickup::Think(float dt, CStateManager& mgr) {
} }
} else if (x26c_lifeTime != 0.f) { } else if (x26c_lifeTime != 0.f) {
float alpha = 1.f; float alpha = 1.f;
if (x26c_lifeTime < 2.f) if (x26c_lifeTime < 2.f) {
alpha = 1.f - (x26c_lifeTime / x270_curTime); alpha = 1.f - (x26c_lifeTime / x270_curTime);
else if ((x26c_lifeTime - x270_curTime) < 2.f) } else if ((x26c_lifeTime - x270_curTime) < 2.f) {
alpha = (x26c_lifeTime - x270_curTime) * 0.5f; alpha = (x26c_lifeTime - x270_curTime) * 0.5f;
}
drawFlags = CModelFlags(5, 0, 3, zeus::CColor(1.f, alpha)); drawFlags = CModelFlags(5, 0, 3, zeus::CColor(1.f, alpha));
drawFlags.x2_flags &= 0xFFFC; drawFlags.x2_flags &= 0xFFFC;
@ -101,12 +106,13 @@ void CScriptPickup::Think(float dt, CStateManager& mgr) {
} }
SetVelocityWR(posDelta); SetVelocityWR(posDelta);
} else if (x28c_24_generated) { } else if (x28c_24_generated) {
float chargeFactor = const float chargeFactor =
mgr.GetPlayer().GetPlayerGun()->IsCharging() ? mgr.GetPlayer().GetPlayerGun()->GetChargeBeamFactor() : 0.f; mgr.GetPlayer().GetPlayerGun()->IsCharging() ? mgr.GetPlayer().GetPlayerGun()->GetChargeBeamFactor() : 0.f;
if (chargeFactor > CPlayerGun::skTractorBeamFactor) { if (chargeFactor > CPlayerGun::skTractorBeamFactor) {
zeus::CVector3f posDelta = GetTranslation() - mgr.GetCameraManager()->GetFirstPersonCamera()->GetTranslation(); const zeus::CVector3f posDelta =
float relFov = zeus::CRelAngle(zeus::degToRad(g_tweakGame->GetFirstPersonFOV())).asRel(); GetTranslation() - mgr.GetCameraManager()->GetFirstPersonCamera()->GetTranslation();
const float relFov = zeus::CRelAngle(zeus::degToRad(g_tweakGame->GetFirstPersonFOV())).asRel();
if (mgr.GetCameraManager()->GetFirstPersonCamera()->GetTransform(). if (mgr.GetCameraManager()->GetFirstPersonCamera()->GetTransform().
frontVector().dot(posDelta.normalized()) > std::cos(relFov) && frontVector().dot(posDelta.normalized()) > std::cos(relFov) &&
posDelta.magSquared() < (30.f * 30.f)) { posDelta.magSquared() < (30.f * 30.f)) {
@ -117,24 +123,25 @@ void CScriptPickup::Think(float dt, CStateManager& mgr) {
} }
} }
if (x26c_lifeTime != 0.f && x270_curTime > x26c_lifeTime) if (x26c_lifeTime != 0.f && x270_curTime > x26c_lifeTime) {
mgr.FreeScriptObject(GetUniqueId()); mgr.FreeScriptObject(GetUniqueId());
}
} }
void CScriptPickup::Touch(CActor& act, CStateManager& mgr) { void CScriptPickup::Touch(CActor& act, CStateManager& mgr) {
if (GetActive() && x278_delayTimer < 0.f && TCastToPtr<CPlayer>(act)) { if (GetActive() && x278_delayTimer < 0.f && TCastToPtr<CPlayer>(act)) {
if (x258_itemType >= CPlayerState::EItemType::Truth && x258_itemType <= CPlayerState::EItemType::Newborn) { if (x258_itemType >= CPlayerState::EItemType::Truth && x258_itemType <= CPlayerState::EItemType::Newborn) {
CAssetId id = MP1::CArtifactDoll::GetArtifactHeadScanFromItemType(x258_itemType); const CAssetId id = MP1::CArtifactDoll::GetArtifactHeadScanFromItemType(x258_itemType);
if (id.IsValid()) if (id.IsValid()) {
mgr.GetPlayerState()->SetScanTime(id, 0.5f); mgr.GetPlayerState()->SetScanTime(id, 0.5f);
} }
}
if (x27c_pickupParticleDesc) { if (x27c_pickupParticleDesc) {
if (mgr.GetPlayerState()->GetActiveVisor(mgr) != CPlayerState::EPlayerVisor::Thermal) { if (mgr.GetPlayerState()->GetActiveVisor(mgr) != CPlayerState::EPlayerVisor::Thermal) {
mgr.AddObject(new CExplosion(x27c_pickupParticleDesc, mgr.AllocateUniqueId(), true, mgr.AddObject(new CExplosion(x27c_pickupParticleDesc, mgr.AllocateUniqueId(), true,
CEntityInfo(GetAreaIdAlways(), CEntity::NullConnectionList, kInvalidEditorId), CEntityInfo(GetAreaIdAlways(), CEntity::NullConnectionList, kInvalidEditorId),
"Explosion - Pickup Effect", x34_transform, 0, zeus::skOne3f, "Explosion - Pickup Effect", x34_transform, 0, zeus::skOne3f, zeus::skWhite));
zeus::skWhite));
} }
} }
@ -144,8 +151,8 @@ void CScriptPickup::Touch(CActor& act, CStateManager& mgr) {
SendScriptMsgs(EScriptObjectState::Arrived, mgr, EScriptObjectMessage::None); SendScriptMsgs(EScriptObjectState::Arrived, mgr, EScriptObjectMessage::None);
if (x260_capacity > 0) { if (x260_capacity > 0) {
u32 total = mgr.GetPlayerState()->GetPickupTotal(); const u32 total = mgr.GetPlayerState()->GetPickupTotal();
u32 colRate = mgr.GetPlayerState()->CalculateItemCollectionRate(); const u32 colRate = mgr.GetPlayerState()->CalculateItemCollectionRate();
if (total == colRate) { if (total == colRate) {
CPersistentOptions& opts = g_GameState->SystemOptions(); CPersistentOptions& opts = g_GameState->SystemOptions();
mgr.QueueMessage( mgr.QueueMessage(