From 8722a9920c1f6119bf6e769cba270e63097f8e25 Mon Sep 17 00:00:00 2001 From: chai <215380520@qq.com> Date: Thu, 23 May 2024 10:08:29 +0800 Subject: + astar project --- .../com.arongranberg.astar/Core/AI/TurnBasedAI.cs | 25 ++++++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Core/AI/TurnBasedAI.cs (limited to 'Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Core/AI/TurnBasedAI.cs') diff --git a/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Core/AI/TurnBasedAI.cs b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Core/AI/TurnBasedAI.cs new file mode 100644 index 0000000..2bce7cf --- /dev/null +++ b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Core/AI/TurnBasedAI.cs @@ -0,0 +1,25 @@ +using UnityEngine; +using System.Collections.Generic; + +namespace Pathfinding.Examples { + /// Helper script in the example scene 'Turn Based' + [HelpURL("https://arongranberg.com/astar/documentation/stable/turnbasedai.html")] + public class TurnBasedAI : VersionedMonoBehaviour { + public int movementPoints = 2; + public BlockManager blockManager; + public SingleNodeBlocker blocker; + public GraphNode targetNode; + public BlockManager.TraversalProvider traversalProvider; + + void Start () { + blocker.BlockAtCurrentPosition(); + } + + protected override void Awake () { + base.Awake(); + // Set the traversal provider to block all nodes that are blocked by a SingleNodeBlocker + // except the SingleNodeBlocker owned by this AI (we don't want to be blocked by ourself) + traversalProvider = new BlockManager.TraversalProvider(blockManager, BlockManager.BlockMode.AllExceptSelector, new List() { blocker }); + } + } +} -- cgit v1.1-26-g67d0