summaryrefslogtreecommitdiff
path: root/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphEditors/LayerGridGraphEditor.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/Editor/GraphEditors/LayerGridGraphEditor.cs
parent3ba4020b69e5971bb0df7ee08b31d10ea4d01937 (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.cs44
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;
+ }
+ }
+}