Editor
                
                
                class in
          UnityEditor
                /
                Inherits from:ScriptableObject
                
                
                
                  Suggest a change
                  
                    
                    
                      Success!
                      Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.
                      Close
                     
                    
                      Submission failed
                      For some reason your suggested change could not be submitted. Please <a>try again</a> in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.
                      Close
                     
                    
                   
                 
                
                
                
                
               
              
              
                Description
                Base class to derive custom Editors from. Use this to create your own custom inspectors and editors for your objects.
               
              
                Consider a script MyPlayer with variables for armor, damage, and a reference to a gun GameObject:
               
              
        #pragma strict
// This is not an editor script.
public class MyPlayer extends MonoBehaviour {
	public var armor: int = 75;
	public var damage: int = 25;
	public var gun: GameObject;
	function Update() {
		// Update logic here...
	}
}
        
using UnityEngine;
using System.Collections;
// This is not an editor script.
public class MyPlayer : MonoBehaviour {
    public int armor = 75;
    public int damage = 25;
    public GameObject gun;
    void Update () {
	// Update logic here...
    }
}
       
              
                Using a custom Editor, the apperance of the script in the Inspector can be changed, for example to look like this:

Custom editor in the Inspector.
You can attach the Editor to a custom component by using the CustomEditor attribute.
There are multiple ways to design custom Editors.
If you want the Editor to support multi-object editing, you can use the CanEditMultipleObjects attribute.
Instead of modifying script variables directly, it's advantageous to use the SerializedObject and SerializedProperty
system to edit them, since this automatically handles multi-object editing, undo, and prefab overrides.  If this approach is used a user can select multiple assets in the hierarchy window and change the values for all of them at once.
               
              
        #pragma strict
// Custom Editor using SerializedProperties.
// Automatic handling of multi-object editing, undo, and prefab overrides.
@CustomEditor(MyPlayer)
@CanEditMultipleObjects
public class MyPlayerEditor extends Editor {
	var damageProp: SerializedProperty;
	var armorProp: SerializedProperty;
	var gunProp: SerializedProperty;
	function OnEnable() {
		// Setup the SerializedProperties.
		damageProp = serializedObject.FindProperty("damage");
		armorProp = serializedObject.FindProperty("armor");
		gunProp = serializedObject.FindProperty("gun");
	}
	public override function OnInspectorGUI() {
		// Update the serializedProperty - always do this in the beginning of OnInspectorGUI.
		serializedObject.Update();
		// Show the custom GUI controls.
		EditorGUILayout.IntSlider(damageProp, 0, 100, new GUIContent("Damage"));
		// Only show the damage progress bar if all the objects have the same damage value:
		if (!damageProp.hasMultipleDifferentValues)
			ProgressBar(damageProp.intValue / 100.0f, "Damage");
		EditorGUILayout.IntSlider(armorProp, 0, 100, new GUIContent("Armor"));
		// Only show the armor progress bar if all the objects have the same armor value:
		if (!armorProp.hasMultipleDifferentValues)
			ProgressBar(armorProp.intValue / 100.0f, "Armor");
		EditorGUILayout.PropertyField(gunProp, new GUIContent("Gun Object"));
		// Apply changes to the serializedProperty - always do this in the end of OnInspectorGUI.
		serializedObject.ApplyModifiedProperties();
	}
	// Custom GUILayout progress bar.
	function ProgressBar(value: float, label: String) {
		// Get a rect for the progress bar using the same margins as a textfield:
		var rect: Rect = GUILayoutUtility.GetRect(18, 18, "TextField");
		EditorGUI.ProgressBar(rect, value, label);
		EditorGUILayout.Space();
	}
}
        
using UnityEditor;
using UnityEngine;
using System.Collections;
// Custom Editor using SerializedProperties.
// Automatic handling of multi-object editing, undo, and prefab overrides.
[CustomEditor(typeof(MyPlayer))]
[CanEditMultipleObjects]
public class MyPlayerEditor : Editor {
	SerializedProperty damageProp;
	SerializedProperty armorProp;
	SerializedProperty gunProp;
	
	void OnEnable () {
		// Setup the SerializedProperties.
		damageProp = serializedObject.FindProperty ("damage");
		armorProp = serializedObject.FindProperty ("armor");
		gunProp = serializedObject.FindProperty ("gun");
	}
	
	public override void OnInspectorGUI() {
		// Update the serializedProperty - always do this in the beginning of OnInspectorGUI.
		serializedObject.Update ();
		
		// Show the custom GUI controls.
		EditorGUILayout.IntSlider (damageProp, 0, 100, new GUIContent ("Damage"));
		// Only show the damage progress bar if all the objects have the same damage value:
		if (!damageProp.hasMultipleDifferentValues)
			ProgressBar (damageProp.intValue / 100.0f, "Damage");
		
		EditorGUILayout.IntSlider (armorProp, 0, 100, new GUIContent ("Armor"));
		// Only show the armor progress bar if all the objects have the same armor value:
		if (!armorProp.hasMultipleDifferentValues)
			ProgressBar (armorProp.intValue / 100.0f, "Armor");
		
		EditorGUILayout.PropertyField (gunProp, new GUIContent ("Gun Object"));
		
		// Apply changes to the serializedProperty - always do this in the end of OnInspectorGUI.
		serializedObject.ApplyModifiedProperties ();
	}
	
	// Custom GUILayout progress bar.
	void ProgressBar (float value, string label) {
		// Get a rect for the progress bar using the same margins as a textfield:
		Rect rect = GUILayoutUtility.GetRect (18, 18, "TextField");
		EditorGUI.ProgressBar (rect, value, label);
		EditorGUILayout.Space ();
	}
}
       
              
                Alternatively, if automatic handling of multi-object editing, undo,
and prefab overrides is not needed, the script variables can be
modified directly by the editor without using the SerializedObject
and SerializedProperty system, as in the example below.
               
              
        #pragma strict
// Example script with properties.
public class MyPlayer extends MonoBehaviour {
	public var damage: int;
	public var armor: int;
	public var gun: GameObject;
	// ...other code...
}
// Custom Editor the "old" way by modifying the script variables directly.
// No handling of multi-object editing, undo, and prefab overrides!
@CustomEditor(MyPlayer)
public class MyPlayerEditor extends Editor {
	public override function OnInspectorGUI() {
		var mp: MyPlayer = MyPlayertarget;
		mp.damage = EditorGUILayout.IntSlider("Damage", mp.damage, 0, 100);
		ProgressBar(mp.damage / 100.0f, "Damage");
		mp.armor = EditorGUILayout.IntSlider("Armor", mp.armor, 0, 100);
		ProgressBar(mp.armor / 100.0f, "Armor");
		var allowSceneObjects: boolean = !EditorUtility.IsPersistent(target);
		mp.gun = GameObjectEditorGUILayout.ObjectField("Gun Object", mp.gun, GameObject, allowSceneObjects);
	}
	// Custom GUILayout progress bar.
	function ProgressBar(value: float, label: String) {
		// Get a rect for the progress bar using the same margins as a textfield:
		var rect: Rect = GUILayoutUtility.GetRect(18, 18, "TextField");
		EditorGUI.ProgressBar(rect, value, label);
		EditorGUILayout.Space();
	}
}
        
using UnityEditor;
using UnityEngine;
using System.Collections;
// Example script with properties.
public class MyPlayer : MonoBehaviour {
	public int damage;
	public int armor;
	public GameObject gun;
	// ...other code...
}
// Custom Editor the "old" way by modifying the script variables directly.
// No handling of multi-object editing, undo, and prefab overrides!
[CustomEditor (typeof(MyPlayer))]
public class MyPlayerEditor : Editor {
	
	public override void OnInspectorGUI () {
		MyPlayer mp = (MyPlayer)target;
		mp.damage = EditorGUILayout.IntSlider ("Damage", mp.damage, 0, 100);
		ProgressBar (mp.damage / 100.0f, "Damage");
		
		mp.armor = EditorGUILayout.IntSlider ("Armor", mp.armor, 0, 100);
		ProgressBar (mp.armor / 100.0f, "Armor");
		
		bool allowSceneObjects = !EditorUtility.IsPersistent (target);
		mp.gun = (GameObject)EditorGUILayout.ObjectField ("Gun Object", mp.gun, typeof(GameObject), allowSceneObjects);
	}
	
	// Custom GUILayout progress bar.
	void ProgressBar (float value, string label) {
		// Get a rect for the progress bar using the same margins as a textfield:
		Rect rect = GUILayoutUtility.GetRect (18, 18, "TextField");
		EditorGUI.ProgressBar (rect, value, label);
		EditorGUILayout.Space ();
	}
}
       
              
                Variables
                
      | serializedObject | A SerializedObject representing the object or objects being inspected. | 
      | target | The object being inspected. | 
      | targets | An array of all the object being inspected. | 
    
               
              
                Public Functions
                
      | DrawDefaultInspector | Draw the built-in inspector. | 
      | DrawHeader | Call this function to draw the header of the editor. | 
      | DrawPreview | The first entry point for Preview Drawing. | 
      | GetInfoString | Implement this method to show asset information on top of the asset preview. | 
      | GetPreviewTitle | Override this method if you want to change the label of the Preview area. | 
      | HasPreviewGUI | Override this method in subclasses if you implement OnPreviewGUI. | 
      | OnInspectorGUI | Implement this function to make a custom inspector. | 
      | OnInteractivePreviewGUI | Implement to create your own interactive custom preview. Interactive custom previews are used in the preview area of the inspector and the object selector. | 
      | OnPreviewGUI | Implement to create your own custom preview for the preview area of the inspector, primary editor headers and the object selector. | 
      | OnPreviewSettings | Override this method if you want to show custom controls in the preview header. | 
      | RenderStaticPreview | Override this method if you want to render a static preview that shows. | 
      | Repaint | Repaint any inspectors that shows this editor. | 
      | RequiresConstantRepaint | Does this edit require to be repainted constantly in its current state? | 
      | UseDefaultMargins | Override this method in subclasses to return false if you don't want default margins. | 
    
               
              
                Static Functions
                
      | CreateCachedEditor | On return previousEditor is an editor for targetObject or targetObjects. The function either returns if the editor is already tracking the objects, or Destroys the previous editor and creates a new one. | 
      | CreateEditor | Make a custom editor for targetObject or targetObjects. | 
    
               
              
                Messages
                
      | OnSceneGUI | Enables the Editor to handle an event in the scene view. | 
    
               
              
                Inherited members
      
      Variables
        | hideFlags | Should the object be hidden, saved with the scene or modifiable by the user? | 
        | name | The name of the object. | 
      
Operators
        | bool | Does the object exist? | 
        | operator != | Compares if two objects refer to a different object. | 
        | operator == | Compares two object references to see if they refer to the same object. | 
      
Messages
        | Awake | This function is called when the ScriptableObject script is started. | 
        | OnDestroy | This function is called when the scriptable object will be destroyed. | 
        | OnDisable | This function is called when the scriptable object goes out of scope. | 
        | OnEnable | This function is called when the object is loaded. |