From 766cdff5ffa72b65d7f106658d1603f47739b2ba Mon Sep 17 00:00:00 2001 From: chai <215380520@qq.com> Date: Fri, 27 Oct 2023 11:05:14 +0800 Subject: + init --- GameCode/StatsAfterDealingDamage.cs | 68 +++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 GameCode/StatsAfterDealingDamage.cs (limited to 'GameCode/StatsAfterDealingDamage.cs') diff --git a/GameCode/StatsAfterDealingDamage.cs b/GameCode/StatsAfterDealingDamage.cs new file mode 100644 index 0000000..d228813 --- /dev/null +++ b/GameCode/StatsAfterDealingDamage.cs @@ -0,0 +1,68 @@ +using UnityEngine; +using UnityEngine.Events; + +public class StatsAfterDealingDamage : MonoBehaviour +{ + public float duration = 3f; + + public float movementSpeedMultiplier = 1f; + + public float jumpMultiplier = 1f; + + public float hpMultiplier = 1f; + + public UnityEvent startEvent; + + public UnityEvent endEvent; + + private bool isOn; + + private CharacterData data; + + private void Start() + { + data = GetComponentInParent(); + } + + private void Update() + { + bool flag = data.stats.sinceDealtDamage < duration; + if (isOn != flag) + { + isOn = flag; + _ = base.transform.localScale; + if (isOn) + { + data.health *= hpMultiplier; + data.maxHealth *= hpMultiplier; + data.stats.movementSpeed *= movementSpeedMultiplier; + data.stats.jump *= jumpMultiplier; + data.stats.ConfigureMassAndSize(); + startEvent.Invoke(); + } + else + { + data.health /= hpMultiplier; + data.maxHealth /= hpMultiplier; + data.stats.movementSpeed /= movementSpeedMultiplier; + data.stats.jump /= jumpMultiplier; + data.stats.ConfigureMassAndSize(); + endEvent.Invoke(); + } + } + } + + public void Interupt() + { + if (isOn) + { + data.health /= hpMultiplier; + data.maxHealth /= hpMultiplier; + data.stats.movementSpeed /= movementSpeedMultiplier; + data.stats.jump /= jumpMultiplier; + data.stats.ConfigureMassAndSize(); + endEvent.Invoke(); + isOn = false; + } + } +} -- cgit v1.1-26-g67d0