CameraFacingBillboard

From Unify Community Wiki
Revision as of 17:40, 2 November 2011 by Juanelo (Talk | contribs)

Jump to: navigation, search

Author: Neil Carter (NCarter)

Contents

Description

This script makes the object which it is attached to align itself with the camera. This is useful for billboards which should always face the camera and be the same way up as it is.

Usage

Place this script on a GameObject that you want to face the camera. Then, with the object selected, use the inspector to select the Camera you want the object to face.

You might want to change Vector3.back to Vector3.front, depending on the initial orientation of your object.

Technical Discussion

Note that the script doesn't simply point the object at the camera. Instead, it makes the object point in the same direction as the camera's forward axis (that is, the direction the camera is looking in). This might seem intuitively wrong, but it's actually correct for the one-point-perspective world of realtime computer graphics.

C# - CameraFacingBillboard.cs

<csharp>using UnityEngine; using System.Collections;

public class CameraFacingBillboard : MonoBehaviour {

   public Camera m_Camera;
   void Update()
   {
       transform.LookAt(transform.position + m_Camera.transform.rotation * Vector3.back,
           m_Camera.transform.rotation * Vector3.up);
   }

} </csharp>

Mods

This Mod will additionally:
-find the default camera in the scene
-create an empty "container" GameObject as parent of the billboard, and will rotate this object instead. This allows the user to assign a predefined rotation to the billboard object.
-require initialization. (just set "autoInit" to "true")
Mod Author: juanelo


<csharp>//cameraFacingBillboard.cs v02 //by Neil Carter (NCarter) //modified by Juan Castaneda (juanelo) // //added in-between GRP object to perform rotations on //added auto-find main camera //added un-initialized state, where script will do nothing using UnityEngine; using System.Collections;


public class CameraFacingBillboard : MonoBehaviour {

   public Camera m_Camera;

public bool amActive =false; public bool autoInit =false; GameObject myContainer;

void Awake(){ if (autoInit == true){ m_Camera = Camera.main; amActive = true; }

myContainer = new GameObject(); myContainer.name = "GRP_"+transform.gameObject.name; myContainer.transform.position = transform.position; transform.parent = myContainer.transform; }


   void Update(){
       if(amActive==true){
       	myContainer.transform.LookAt(myContainer.transform.position + m_Camera.transform.rotation * Vector3.back, m_Camera.transform.rotation * Vector3.up);

}

   }

}</csharp>

Personal tools
Namespaces

Variants
Actions
Navigation
Extras
Toolbox