Version: 2017.4
LanguageEnglish
  • C#
  • JS

Script language

Select your preferred scripting language. All code snippets will be displayed in this language.

MonoBehaviour.OnWillRenderObject()

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

OnWillRenderObject is called for each camera if the object is visible and not a UI element.

The function is not called if the MonoBehaviour is disabled.

The function is called during the culling process just before rendering each culled object. For usage in a proper context, see the script Water.cs in Assets->Import Package->Effects

Note that Camera.current will be set to the camera that will render the object.

Note: This has no effect when called from a UI element.

#pragma strict
public class ExampleScript extends MonoBehaviour {
	public var rend: Renderer;
	private var timePass: float = 0.0f;
	function Start() {
		rend = GetComponent.<Renderer>();
	}
	function OnWillRenderObject() {
		timePass += Time.deltaTime;
		if (timePass > 1.0f) {
			timePass = 0.0f;
			print(gameObject.name + " is being rendered by " + Camera.current.name + " at " + Time.time);
		}
	}
}
using UnityEngine;
using System.Collections;

public class ExampleScript : MonoBehaviour { public Renderer rend;

private float timePass = 0.0f;

void Start() { rend = GetComponent<Renderer>(); }

void OnWillRenderObject() { timePass += Time.deltaTime;

if (timePass > 1.0f) { timePass = 0.0f; print(gameObject.name + " is being rendered by " + Camera.current.name + " at " + Time.time); } } }

This is called multiple times per frame.