diff options
author | chai <215380520@qq.com> | 2024-05-23 10:08:29 +0800 |
---|---|---|
committer | chai <215380520@qq.com> | 2024-05-23 10:08:29 +0800 |
commit | 8722a9920c1f6119bf6e769cba270e63097f8e25 (patch) | |
tree | 2eaf9865de7fb1404546de4a4296553d8f68cc3b /Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Graphs/Grid/Jobs/JobCheckCollisions.cs | |
parent | 3ba4020b69e5971bb0df7ee08b31d10ea4d01937 (diff) |
+ astar project
Diffstat (limited to 'Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Graphs/Grid/Jobs/JobCheckCollisions.cs')
-rw-r--r-- | Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Graphs/Grid/Jobs/JobCheckCollisions.cs | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Graphs/Grid/Jobs/JobCheckCollisions.cs b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Graphs/Grid/Jobs/JobCheckCollisions.cs new file mode 100644 index 0000000..71a3d2c --- /dev/null +++ b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Graphs/Grid/Jobs/JobCheckCollisions.cs @@ -0,0 +1,33 @@ +using UnityEngine; +using Unity.Collections; +using Pathfinding.Jobs; + +namespace Pathfinding.Graphs.Grid.Jobs { + /// <summary> + /// Checks if nodes are obstructed by obstacles or not. + /// + /// See: <see cref="GraphCollision"/> + /// </summary> + struct JobCheckCollisions : IJobTimeSliced { + [ReadOnly] + public NativeArray<Vector3> nodePositions; + public NativeArray<bool> collisionResult; + public GraphCollision collision; + int startIndex; + + public void Execute () { + Execute(TimeSlice.Infinite); + } + + public bool Execute (TimeSlice timeSlice) { + for (int i = startIndex; i < nodePositions.Length; i++) { + collisionResult[i] = collisionResult[i] && collision.Check(nodePositions[i]); + if ((i & 127) == 0 && timeSlice.expired) { + startIndex = i + 1; + return false; + } + } + return true; + } + } +} |