diff options
| author | chai <chaifix@163.com> | 2020-10-15 07:24:10 +0800 |
|---|---|---|
| committer | chai <chaifix@163.com> | 2020-10-15 07:24:10 +0800 |
| commit | e846c64d6f927879cb8a095e62d773a8d7b3c9f4 (patch) | |
| tree | 7882744bbf2b6c7096ec15fb300f088c5a0807c5 /Assets/Plugins/Editor/AdvancedInspector/FieldEditors/RigidbodyConstraintsEditor.cs | |
| parent | cd12e74241678ee3c0752484d310b202187ba24c (diff) | |
*ability system
Diffstat (limited to 'Assets/Plugins/Editor/AdvancedInspector/FieldEditors/RigidbodyConstraintsEditor.cs')
| -rw-r--r-- | Assets/Plugins/Editor/AdvancedInspector/FieldEditors/RigidbodyConstraintsEditor.cs | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/Assets/Plugins/Editor/AdvancedInspector/FieldEditors/RigidbodyConstraintsEditor.cs b/Assets/Plugins/Editor/AdvancedInspector/FieldEditors/RigidbodyConstraintsEditor.cs new file mode 100644 index 00000000..781c92b8 --- /dev/null +++ b/Assets/Plugins/Editor/AdvancedInspector/FieldEditors/RigidbodyConstraintsEditor.cs @@ -0,0 +1,69 @@ +using UnityEngine; +using UnityEditor; +using System; +using System.Collections; + +namespace AdvancedInspector +{ + public class RigidbodyConstraintsEditor : FieldEditor + { + private const int LABEL_WIDTH = 96; + private const int TOGGLE_WIDTH = 28; + + public override bool EditDerived + { + get { return false; } + } + + public override bool Expandable + { + get { return true; } + } + + public override Type[] EditedTypes + { + get { return new Type[] { typeof(RigidbodyConstraints) }; } + } + + public override void Draw(InspectorField field, GUIStyle style) + { + field.Expandable = true; + if (!field.Expanded) + return; + + EditorGUI.showMixedValue = field.Mixed; + + EditorGUI.BeginChangeCheck(); + + RigidbodyConstraints value = (RigidbodyConstraints)GetValue(field); + int newValue = 0; + + EditorGUILayout.BeginHorizontal(); + GUILayout.Label("Freeze Position ", GUILayout.Width(LABEL_WIDTH)); + if (GUILayout.Toggle(value.Has(RigidbodyConstraints.FreezePositionX), "X", GUILayout.Width(TOGGLE_WIDTH))) + newValue += (int)RigidbodyConstraints.FreezePositionX; + + if (GUILayout.Toggle(value.Has(RigidbodyConstraints.FreezePositionY), "Y", GUILayout.Width(TOGGLE_WIDTH))) + newValue += (int)RigidbodyConstraints.FreezePositionY; + + if (GUILayout.Toggle(value.Has(RigidbodyConstraints.FreezePositionZ), "Z", GUILayout.Width(TOGGLE_WIDTH))) + newValue += (int)RigidbodyConstraints.FreezePositionZ; + EditorGUILayout.EndHorizontal(); + + EditorGUILayout.BeginHorizontal(); + GUILayout.Label("Freeze Rotation ", GUILayout.Width(LABEL_WIDTH)); + if (GUILayout.Toggle(value.Has(RigidbodyConstraints.FreezeRotationX), "X", GUILayout.Width(TOGGLE_WIDTH))) + newValue += (int)RigidbodyConstraints.FreezeRotationX; + + if (GUILayout.Toggle(value.Has(RigidbodyConstraints.FreezeRotationY), "Y", GUILayout.Width(TOGGLE_WIDTH))) + newValue += (int)RigidbodyConstraints.FreezeRotationY; + + if (GUILayout.Toggle(value.Has(RigidbodyConstraints.FreezeRotationZ), "Z", GUILayout.Width(TOGGLE_WIDTH))) + newValue += (int)RigidbodyConstraints.FreezeRotationZ; + EditorGUILayout.EndHorizontal(); + + if (EditorGUI.EndChangeCheck()) + field.SetValue(Enum.ToObject(typeof(RigidbodyConstraints), newValue)); + } + } +}
\ No newline at end of file |
