UnityのCustomPropertyDrawerを利用してInspectorのGUIを変更してみます。
はじめに
Unityのバージョンは「2021.3.14f1」で作成しています。
PropertyDrawerを利用してInspectorの表示を変更してみます。
実装開始
まずは下記のスクリプトを作成します。
using UnityEngine; public class InspectorTest : MonoBehaviour { public int volume; }
オブジェクトにスクリプトを追加すると、下記のようにInspectorに表示されます。
data:image/s3,"s3://crabby-images/c408b/c408b766659b0c2233f34df5701256a6c6107110" alt=""
下記のように記載すると、Inspectorにヘッダーを追加することができます。
using UnityEngine; public class InspectorTest : MonoBehaviour { [Header("---Config---")] public int volume; }
data:image/s3,"s3://crabby-images/e9851/e985144bce5cdcc24bc254559868fbe41df920f9" alt=""
また、下記のようにすると、上限値、下限値をセットすることもできます。
using UnityEngine; public class InspectorTest : MonoBehaviour { [Header("---Config---")] [Range(0, 100)] public int volume; }
data:image/s3,"s3://crabby-images/bf092/bf092ce6a590ab287ce254738f4d8cc6fea28004" alt=""
これらはUnityが標準で用意しているものですが、自分で好きなようにInspector表示を作成することもできます。
CustomPropertyDrawerを利用する
スクリプトを下記に変更します。int型の変数二つをシリアル化したシンプルなものです。
using UnityEngine; public class InspectorTest : MonoBehaviour { public ConfigClass con; } [System.Serializable] public class ConfigClass { public int sfx; public int volume; }
そのままだとInspectorには下記のように表示されます。
data:image/s3,"s3://crabby-images/24133/241332a248ab0f50eeb7a7c46b63ea7270e43a2e" alt=""
次に下記スクリプトを作成します。
using UnityEngine; using UnityEditor; [CustomPropertyDrawer(typeof(ConfigClass))] public class Drawer : PropertyDrawer { public override void OnGUI(Rect position, SerializedProperty property, GUIContent label) { EditorGUI.BeginProperty(position, label, property); position = EditorGUI.PrefixLabel(position, GUIUtility.GetControlID(FocusType.Passive), label); var indent = EditorGUI.indentLevel; EditorGUI.indentLevel = 0; EditorGUIUtility.labelWidth = 40; var sfxRect = new Rect(position.x, position.y, 80, position.height); var volumeRect = new Rect(position.x + 90, position.y, 80, position.height); EditorGUI.PropertyField(sfxRect, property.FindPropertyRelative("sfx"),new GUIContent("SFX")); EditorGUI.PropertyField(volumeRect, property.FindPropertyRelative("volume"), new GUIContent("VOL")); EditorGUI.indentLevel = indent; EditorGUI.EndProperty(); } }
下記のように横並びで表示されるようになります。
data:image/s3,"s3://crabby-images/34173/34173c3987e9453641888bf4e9bbbd6c933cf018" alt=""
長いスクリプトですが、実際に表示を変更しているのは下記の部分です。
EditorGUIUtility.labelWidth = 40; var sfxRect = new Rect(position.x, position.y, 80, position.height); var volumeRect = new Rect(position.x + 90, position.y, 80, position.height); EditorGUI.PropertyField(sfxRect, property.FindPropertyRelative("sfx"),new GUIContent("SFX")); EditorGUI.PropertyField(volumeRect, property.FindPropertyRelative("volume"), new GUIContent("VOL"));
下記のように変更すると、スライダーを2つ並べることもできます。
var sfxRect = new Rect(position.x, position.y, 150, position.height); var volumeRect = new Rect(position.x+160, position.y, 150, position.height); EditorGUI.IntSlider(sfxRect, property.FindPropertyRelative("sfx"), 0, 100, new GUIContent("SFX")); EditorGUI.IntSlider(volumeRect, property.FindPropertyRelative("volume"), 0, 100, new GUIContent("VOL"));
data:image/s3,"s3://crabby-images/7a238/7a23859d044d8e29144d19f138c3a9e3dd3596e2" alt=""
詳しくは下記の公式リファレンスにて。