summaryrefslogtreecommitdiff
path: root/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/ExampleScenes/Scenes/OldExamples/Example18_RTS/RTSWeapon.cs
diff options
context:
space:
mode:
authorchai <215380520@qq.com>2024-05-23 10:08:29 +0800
committerchai <215380520@qq.com>2024-05-23 10:08:29 +0800
commit8722a9920c1f6119bf6e769cba270e63097f8e25 (patch)
tree2eaf9865de7fb1404546de4a4296553d8f68cc3b /Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/ExampleScenes/Scenes/OldExamples/Example18_RTS/RTSWeapon.cs
parent3ba4020b69e5971bb0df7ee08b31d10ea4d01937 (diff)
+ astar project
Diffstat (limited to 'Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/ExampleScenes/Scenes/OldExamples/Example18_RTS/RTSWeapon.cs')
-rw-r--r--Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/ExampleScenes/Scenes/OldExamples/Example18_RTS/RTSWeapon.cs33
1 files changed, 33 insertions, 0 deletions
diff --git a/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/ExampleScenes/Scenes/OldExamples/Example18_RTS/RTSWeapon.cs b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/ExampleScenes/Scenes/OldExamples/Example18_RTS/RTSWeapon.cs
new file mode 100644
index 0000000..6edcabf
--- /dev/null
+++ b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/ExampleScenes/Scenes/OldExamples/Example18_RTS/RTSWeapon.cs
@@ -0,0 +1,33 @@
+using UnityEngine;
+using System.Collections;
+
+namespace Pathfinding.Examples.RTS {
+ [HelpURL("https://arongranberg.com/astar/documentation/stable/rtsweapon.html")]
+ public class RTSWeapon : MonoBehaviour {
+ public bool ranged;
+ public float range;
+ public float cooldown;
+ public float attackDuration;
+ public bool canMoveWhileAttacking = false;
+
+ float lastAttackTime = float.NegativeInfinity;
+
+ public virtual bool Aim (RTSUnit target) {
+ return Time.time - lastAttackTime >= cooldown;
+ }
+
+ public bool isAttacking {
+ get {
+ return Time.time - lastAttackTime < attackDuration;
+ }
+ }
+
+ public bool InRangeOf (Vector3 point) {
+ return (transform.position - point).sqrMagnitude < range*range;
+ }
+
+ public virtual void Attack (RTSUnit target) {
+ lastAttackTime = Time.time;
+ }
+ }
+}