From c5f145786f4c6d2fe4bea831dfc16e52228920a5 Mon Sep 17 00:00:00 2001 From: chai <215380520@qq.com> Date: Sun, 19 May 2024 16:05:01 +0800 Subject: * move --- Thronefall_1_0/GameCode/BarricadeDamage.cs | 63 ++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 Thronefall_1_0/GameCode/BarricadeDamage.cs (limited to 'Thronefall_1_0/GameCode/BarricadeDamage.cs') diff --git a/Thronefall_1_0/GameCode/BarricadeDamage.cs b/Thronefall_1_0/GameCode/BarricadeDamage.cs new file mode 100644 index 0000000..09842f3 --- /dev/null +++ b/Thronefall_1_0/GameCode/BarricadeDamage.cs @@ -0,0 +1,63 @@ +using System.Collections.Generic; +using UnityEngine; + +public class BarricadeDamage : MonoBehaviour +{ + public float preSelectRadius = 4f; + + public float slowTime = 3f; + + public List damage; + + public LayerMask lmTakeDamage; + + private Collider[] overlapColliders = new Collider[50]; + + private float timeSinceLastCollisionCheck; + + private BoxCollider myCollider; + + private void Start() + { + myCollider = GetComponent(); + timeSinceLastCollisionCheck = Random.value; + } + + private void Update() + { + timeSinceLastCollisionCheck += Time.deltaTime; + if (timeSinceLastCollisionCheck < 0.2f) + { + return; + } + timeSinceLastCollisionCheck = 0f; + foreach (TaggedObject enemyUnit in TagManager.instance.EnemyUnits) + { + if (!(Vector3.Distance(base.transform.position, enemyUnit.transform.position) <= preSelectRadius) || enemyUnit.Hp.PathfindMovement.IsSlowed) + { + continue; + } + overlapColliders = Physics.OverlapBox(base.transform.position, myCollider.size, base.transform.rotation, lmTakeDamage); + Collider[] array = overlapColliders; + for (int i = 0; i < array.Length; i++) + { + TaggedObject componentInParent = array[i].GetComponentInParent(); + if (!componentInParent || !componentInParent.Tags.Contains(TagManager.ETag.EnemyOwned)) + { + continue; + } + Hp hp = componentInParent.Hp; + if ((bool)hp) + { + PathfindMovement pathfindMovement = hp.PathfindMovement; + if ((bool)pathfindMovement && !pathfindMovement.IsSlowed) + { + pathfindMovement.Slow(slowTime); + hp.TakeDamage(DamageModifyer.CalculateDamageOnTarget(componentInParent, damage)); + } + } + } + break; + } + } +} -- cgit v1.1-26-g67d0