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/Editor/GraphEditors/LayerGridGraphEditor.cs | |
parent | 3ba4020b69e5971bb0df7ee08b31d10ea4d01937 (diff) |
+ astar project
Diffstat (limited to 'Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphEditors/LayerGridGraphEditor.cs')
-rw-r--r-- | Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphEditors/LayerGridGraphEditor.cs | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphEditors/LayerGridGraphEditor.cs b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphEditors/LayerGridGraphEditor.cs new file mode 100644 index 0000000..bedf8b8 --- /dev/null +++ b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphEditors/LayerGridGraphEditor.cs @@ -0,0 +1,44 @@ +using UnityEngine; +using UnityEditor; +using Pathfinding.Graphs.Grid; + +namespace Pathfinding { + [CustomGraphEditor(typeof(LayerGridGraph), "Layered Grid Graph")] + public class LayerGridGraphEditor : GridGraphEditor { + protected override void DrawMiddleSection (GridGraph graph) { + var layerGridGraph = graph as LayerGridGraph; + + DrawNeighbours(graph); + + layerGridGraph.characterHeight = EditorGUILayout.DelayedFloatField("Character Height", layerGridGraph.characterHeight); + DrawMaxClimb(graph); + + DrawMaxSlope(graph); + DrawErosion(graph); + } + + protected override void DrawMaxClimb (GridGraph graph) { + var layerGridGraph = graph as LayerGridGraph; + + base.DrawMaxClimb(graph); + layerGridGraph.maxStepHeight = Mathf.Clamp(layerGridGraph.maxStepHeight, 0, layerGridGraph.characterHeight); + + if (layerGridGraph.maxStepHeight >= layerGridGraph.characterHeight) { + EditorGUILayout.HelpBox("Max step height needs to be smaller or equal to character height", MessageType.Info); + } + } + + protected override void DrawCollisionEditor (GraphCollision collision) { + base.DrawCollisionEditor(collision); + + if (collision.thickRaycast) { + EditorGUILayout.HelpBox("Note: Thick raycast cannot be used with this graph type", MessageType.Error); + } + } + + protected override void DrawUse2DPhysics (GraphCollision collision) { + // 2D physics does not make sense for a layered grid graph + collision.use2D = false; + } + } +} |