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/ModifierEditors/SmoothModifierEditor.cs | |
| parent | 3ba4020b69e5971bb0df7ee08b31d10ea4d01937 (diff) | |
+ astar project
Diffstat (limited to 'Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/ModifierEditors/SmoothModifierEditor.cs')
| -rw-r--r-- | Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/ModifierEditors/SmoothModifierEditor.cs | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/ModifierEditors/SmoothModifierEditor.cs b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/ModifierEditors/SmoothModifierEditor.cs new file mode 100644 index 0000000..0059533 --- /dev/null +++ b/Other/AstarPathfindingDemo/Packages/com.arongranberg.astar/Editor/ModifierEditors/SmoothModifierEditor.cs @@ -0,0 +1,45 @@ +using UnityEngine; +using UnityEditor; + +namespace Pathfinding { + [CustomEditor(typeof(SimpleSmoothModifier))] + [CanEditMultipleObjects] + public class SmoothModifierEditor : EditorBase { + protected override void Inspector () { + var smoothType = FindProperty("smoothType"); + + PropertyField("smoothType"); + + if (!smoothType.hasMultipleDifferentValues) { + switch ((SimpleSmoothModifier.SmoothType)smoothType.enumValueIndex) { + case SimpleSmoothModifier.SmoothType.Simple: + if (PropertyField("uniformLength")) { + FloatField("maxSegmentLength", min: 0.005f); + } else { + IntSlider("subdivisions", 0, 6); + } + + PropertyField("iterations"); + ClampInt("iterations", 0); + + PropertyField("strength"); + break; + case SimpleSmoothModifier.SmoothType.OffsetSimple: + PropertyField("iterations"); + ClampInt("iterations", 0); + + FloatField("offset", min: 0f); + break; + case SimpleSmoothModifier.SmoothType.Bezier: + IntSlider("subdivisions", 0, 6); + PropertyField("bezierTangentLength"); + break; + case SimpleSmoothModifier.SmoothType.CurvedNonuniform: + FloatField("maxSegmentLength", min: 0.005f); + PropertyField("factor"); + break; + } + } + } + } +} |
