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); } }