summaryrefslogtreecommitdiff
path: root/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphMaskDrawer.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/GraphMaskDrawer.cs
parent3ba4020b69e5971bb0df7ee08b31d10ea4d01937 (diff)
+ astar project
Diffstat (limited to 'Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphMaskDrawer.cs')
-rw-r--r--Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphMaskDrawer.cs30
1 files changed, 30 insertions, 0 deletions
diff --git a/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphMaskDrawer.cs b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphMaskDrawer.cs
new file mode 100644
index 0000000..06f9560
--- /dev/null
+++ b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/GraphMaskDrawer.cs
@@ -0,0 +1,30 @@
+using UnityEditor;
+using UnityEngine;
+
+namespace Pathfinding {
+ [CustomPropertyDrawer(typeof(GraphMask))]
+ public class GraphMaskDrawer : PropertyDrawer {
+ string[] graphLabels = new string[32];
+
+ public override void OnGUI (Rect position, SerializedProperty property, GUIContent label) {
+ // Make sure the AstarPath object is initialized and the graphs are loaded, this is required to be able to show graph names in the mask popup
+ AstarPath.FindAstarPath();
+
+ for (int i = 0; i < graphLabels.Length; i++) {
+ if (AstarPath.active == null || AstarPath.active.data.graphs == null || i >= AstarPath.active.data.graphs.Length || AstarPath.active.data.graphs[i] == null) graphLabels[i] = "Graph " + i + (i == 31 ? "+" : "");
+ else {
+ graphLabels[i] = AstarPath.active.data.graphs[i].name + " (graph " + i + ")";
+ }
+ }
+
+ EditorGUI.BeginChangeCheck();
+ EditorGUI.showMixedValue = property.hasMultipleDifferentValues;
+ var valueProp = property.FindPropertyRelative("value");
+ int newVal = EditorGUI.MaskField(position, label, valueProp.intValue, graphLabels);
+ if (EditorGUI.EndChangeCheck()) {
+ valueProp.intValue = newVal;
+ }
+ EditorGUI.showMixedValue = false;
+ }
+ }
+}