Version: Unity 6 Preview (6000.0)
LanguageEnglish
  • C#

Editor.OnSceneGUI()

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

Cancel

Description

Enables the Editor to handle an event in the Scene view.

In the OnSceneGUI you can, for example, edit meshes, paint terrain, or have advanced gizmos. Refer to the Handles class for methods related to drawing interactable visuals in the SceneView.

If you want to draw elements in the Scene view, for instance by using `Graphics.DrawMeshNow`, only do so during EventType.Repaint.

In the following two scripts, OnSceneGUI is used to draw lines between GameObjects. The first script shows how OnSceneGUI is used. In this script, a GameObject is used as a parent. The script obtains the position of the parent and then draws lines from that position to GameObjects stored in an array. The script uses Handles.DrawLine to draw lines. The documentation for Handles.DrawLine has a very similar example.

using UnityEngine;
using UnityEditor;

[CustomEditor( typeof( DrawLine ) )] public class DrawLineEditor : Editor { // Draw lines between a chosen GameObject // and a selection of added GameObjects

void OnSceneGUI() { // Get the chosen GameObject DrawLine t = target as DrawLine;

if( t == null || t.GameObjects == null ) return;

// Grab the center of the parent Vector3 center = t.transform.position;

// Iterate over GameObject added to the array... for( int i = 0; i < t.GameObjects.Length; i++ ) { // ... and draw a line between them if( t.GameObjects[i] != null ) Handles.DrawLine( center, t.GameObjects[i].transform.position ); } } }

This script stores the array of GameObjects which have a line drawn to them. This regular script is attached to a GameObject which is considered to be the starting point for all lines.

using UnityEngine;

[ExecuteInEditMode] public class DrawLine : MonoBehaviour { // an array of game objects which will have a // line drawn to in the Scene editor public GameObject[] GameObjects; }