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.
CloseFor 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
CreateGUI
is called when the EditorWindow's rootVisualElement is ready to be populated.
Use CreateGUI
to add UI Toolkit UI elements to your window.
When creating a custom Editor window, follow these guidelines:
It's important to note that CreateGUI
might not be called before the first call to Update.
For more information, refer to the order of execution of the Editor window.
For an example on how to create an Editor window to react to user input, refer to Create a custom Editor window with C# script.
// The window appears in front of the Editor. // The window shows the type of a Unity object the cursor is over. using UnityEngine; using UnityEditor; using UnityEngine.UIElements; public class MouseOverWindowExample : EditorWindow { string mouseOver = "Nothing..."; Label label; [MenuItem("Examples/Mouse Over Example")] static void Init() { GetWindow<MouseOverWindowExample>("mouseOver"); } void CreateGUI() { label = new Label($"Mouse over: {mouseOver}"); rootVisualElement.Add(label); } void Update() { label.schedule.Execute(() => { mouseOver = EditorWindow.mouseOverWindow ? EditorWindow.mouseOverWindow.ToString() : "Nothing..."; label.text = $"Mouse over: {mouseOver}"; }).Every(10); } }