diff options
| author | chai <215380520@qq.com> | 2023-11-02 11:51:31 +0800 |
|---|---|---|
| committer | chai <215380520@qq.com> | 2023-11-02 11:51:31 +0800 |
| commit | 7f493f682503f5186308de7b8f74b5b49233cfe4 (patch) | |
| tree | 8a91e2056bc79788ee4735dce88b8d516ba12beb /GameCode/PerkHpModifyer.cs | |
+init
Diffstat (limited to 'GameCode/PerkHpModifyer.cs')
| -rw-r--r-- | GameCode/PerkHpModifyer.cs | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/GameCode/PerkHpModifyer.cs b/GameCode/PerkHpModifyer.cs new file mode 100644 index 0000000..3c7186c --- /dev/null +++ b/GameCode/PerkHpModifyer.cs @@ -0,0 +1,31 @@ +using UnityEngine; + +public class PerkHpModifyer : MonoBehaviour +{ + public Equippable requiredPerk; + + public float hpMultiplyer; + + public Hp hp; + + private void Start() + { + if (PerkManager.IsEquipped(requiredPerk)) + { + BuildSlot componentInParent = GetComponentInParent<BuildSlot>(); + if ((bool)componentInParent) + { + foreach (BuildSlot.Upgrade upgrade in componentInParent.Upgrades) + { + foreach (BuildSlot.UpgradeBranch upgradeBranch in upgrade.upgradeBranches) + { + upgradeBranch.hpChange = Mathf.RoundToInt((float)upgradeBranch.hpChange * hpMultiplyer); + } + } + } + hp.maxHp *= hpMultiplyer; + hp.Heal(float.MaxValue); + } + Object.Destroy(this); + } +} |
