diff options
author | chai <215380520@qq.com> | 2024-05-20 22:36:58 +0800 |
---|---|---|
committer | chai <215380520@qq.com> | 2024-05-20 22:36:58 +0800 |
commit | a22c505984697881f5f911a165ee022087b69e09 (patch) | |
tree | d3c030aef1ae9b8a01c889dd2902bb1e3324e72b /Thronefall_v1.0/Decompile/BarricadeDamage.cs | |
parent | 4a4cc82d069b26bc4d4532e73860f86b211ca239 (diff) |
Diffstat (limited to 'Thronefall_v1.0/Decompile/BarricadeDamage.cs')
-rw-r--r-- | Thronefall_v1.0/Decompile/BarricadeDamage.cs | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/Thronefall_v1.0/Decompile/BarricadeDamage.cs b/Thronefall_v1.0/Decompile/BarricadeDamage.cs new file mode 100644 index 0000000..09842f3 --- /dev/null +++ b/Thronefall_v1.0/Decompile/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<DamageModifyer> damage; + + public LayerMask lmTakeDamage; + + private Collider[] overlapColliders = new Collider[50]; + + private float timeSinceLastCollisionCheck; + + private BoxCollider myCollider; + + private void Start() + { + myCollider = GetComponent<BoxCollider>(); + 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<TaggedObject>(); + 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; + } + } +} |