From d36c606cedf0334986d80ae29f45c98ad38276d5 Mon Sep 17 00:00:00 2001 From: pongo1231 Date: Mon, 12 Feb 2024 21:46:10 +0000 Subject: [PATCH] ChaosMod/EffectDispatcher: Apply timer speed meta modifier to displacement distance --- ChaosMod/Components/EffectDispatcher.cpp | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/ChaosMod/Components/EffectDispatcher.cpp b/ChaosMod/Components/EffectDispatcher.cpp index 124c20048..0c05970c1 100644 --- a/ChaosMod/Components/EffectDispatcher.cpp +++ b/ChaosMod/Components/EffectDispatcher.cpp @@ -289,14 +289,16 @@ void EffectDispatcher::OnRun() deltaTime = 0; } - if (!PauseTimer && !m_DistanceChaosState.EnableDistanceBasedEffectDispatch) + if (!PauseTimer) { - UpdateTimer(deltaTime); - } - - if (!PauseTimer && m_DistanceChaosState.EnableDistanceBasedEffectDispatch) - { - UpdateTravelledDistance(); + if (m_DistanceChaosState.EnableDistanceBasedEffectDispatch) + { + UpdateTravelledDistance(); + } + else + { + UpdateTimer(deltaTime); + } } DrawTimerBar(); @@ -335,13 +337,14 @@ void EffectDispatcher::UpdateTravelledDistance() return; } - float distance = + auto distance = GET_DISTANCE_BETWEEN_COORDS(position.x, position.y, position.z, m_DistanceChaosState.SavedPosition.x, m_DistanceChaosState.SavedPosition.y, m_DistanceChaosState.SavedPosition.z, true); if (m_DistanceChaosState.DistanceType == DistanceChaosState::TravelledDistanceType::Displacement) { - if (distance >= m_DistanceChaosState.DistanceToActivateEffect) + if (distance * (ComponentExists() ? GetComponent()->TimerSpeedModifier : 1.f) + >= m_DistanceChaosState.DistanceToActivateEffect) { if (DispatchEffectsOnTimer) {