Camera script like in EVE online

Hi, i’m having troubles making a script for my camera, I need something like in EVE online but i can’t make that work, i need my camera to stay in the same position even if my game object moves up or down, and i need to zoom in or out, can anyone help me with this?

What do you mean by “stay in the same position even if my game object moves up or down”? Should it follow the game object, or not? If yes, then just make it a child of the GO. As for zooming, you would need to set the camera’s http://docs.unity3d.com/ScriptReference/Camera-fieldOfView.htmlfield of view variable (increase or decrease it when the mouse wheel is turned up or down, for example).

Also, what have you tried so far? Please show us your script.

yes it should follow the object, but the script i made ,when i turn right, the camera turns right too…i want my camera only to rotate if i move my mouse if you understand me :slight_smile:

Take a look at the SmoothFollow script included with the Standard Assets, it will make the camera look at a target position of your liking at al times.

It’s good but i need the one where i can rotate it with the mouse

try this script http://wiki.unity3d.com/index.php?title=MouseOrbitZoom

The only way to achieve this is to have a container for the player and move that around. When you play say a jump animation only the child objects move and not the parent. Then you camera will not move when the player jumps. When you jump however the parent collider must be offset based on the jump so it can move around terrain / obstacles and then you can reset the position once you have completed the jump. All of this can be done via animations. As far as the camera goes, I suggest moving the camera via spherical coordinates. If you try to relate x,y,z into making a circle you will have so many headaches. Instead transform into spherical points to make things easier. This way you can control the ‘zoom’ level via the radius of the sphere, and keep everything equidistance since each component x, y, z depends on phi the angle from the Z axis (in unity it would be Y since that is what is facing upwards).

I made two scripts SphericalMovement.cs and Mouse.cs. SphericalMovement should be placed on the object you want to move around some given target like a camera for instance. The Mouse.cs is not necessary but is only needed to call the methods on SphericalMovement.cs to move the object around. These two scripts needs to be on the same object. By adding the Mouse.cs to the camera the SphericalMovement.cs component will also be added automatically.

SphericalMovement.cs

using UnityEngine;
using System.Collections;

public class SphericalMovement : MonoBehaviour {
    [SerializeField] Transform target; // Target assinged via inspector.
    [SerializeField] string targetTag; // Target to be found if the target to move about is not yet in the scene.
    [SerializeField] float targetFindDelay = 0.1f; // Delay before searching for the target.
    [SerializeField] float minDistance = 2.0f; // Minimum zoom distance.
    [SerializeField] float maxDistance = 10.0f; // Maximum zoom distance.
    [SerializeField] float rotateSpeed = 15.0f; // The speed the look rotation.
    [SerializeField] float movementSpeed = 15.0f; // The speed of positioning via the spherical bounds.
    [SerializeField] float thetaSteps = 2.0f; // The amount of degrees to move via each request.
    [SerializeField] float phiSteps = 10.0f; // the amount of degree to move via each request.
    [SerializeField] float upperBound = 0.0f; // Upper bound of the Phi angle from the Y axis.
    [SerializeField] float lowerBound = 145.0f; // Lower bound of the Phi angle form the Y Axis.
    [SerializeField] float zoomSpeed = 15.0f; // The speed at which the radius will change.


    float r = 1.0f; // Distance from the target.
    float thetaAngle = 0.0f; // Theta angle for horizontal rotations.
    float phiAngle = 0.0f; // Phi angle for vertical rotations

    void Start() {
        this.phiAngle = (this.lowerBound - this.upperBound) / 2.0f; // Set the Phi angle between the lower and upper bound
        this.r = (this.maxDistance - this.minDistance) / 2.0f; // Set the starting radius between the min and max distance.

        // Check if the target is null.
        if(this.target == null) {
            // Check if the target tag is null or empty
            if(string.IsNullOrEmpty(this.targetTag) == true) {
                // If the tag is empty throw a warning and destroy the component.
                UnityEngine.Debug.LogWarning(typeof(SphericalMovement).ToString() + " - Start(): 'targetTag' is empty ensure the field matches the tag of the GameObject you are looking for.");

                Object.Destroy(this);
            } else {
                // Find the target with the given tag.
                this.StartCoroutine(this.FindTarget());
            }
        }
    }

    /// <summary>
    /// Finds the target witht he given tag based on some delay via the inspector.
    /// This perfect when the player has not yet spawned.
    /// </summary>
    IEnumerator FindTarget() {
        // Wait before trying to find the target.
        yield return new WaitForSeconds(this.targetFindDelay);

        // Look for the target.
        GameObject t = GameObject.FindGameObjectWithTag(this.targetTag);

        // Check if the target is null
        if(t == null) {
            // Throw and error, could not find the target with the given tag.
            UnityEngine.Debug.LogError(typeof(SphericalMovement).ToString() + " - FindTarget(): Could not find target with tag '" + this.targetTag + "'!");
        } else {
            // Assign the transform of the found target.
            this.target = t.transform;
            // Set the theta angle to be behind the forward facing of the target.
            this.thetaAngle = this.BehindPosition;
        }
    }

    /// <summary>
    /// Gets the Z position in rectanglular coordinates from spherical coordinates
    /// </summary>
    /// <value>The Z position.</value>
    float ZPosition {
        get {
            return this.r * Mathf.Sin(this.thetaAngle * (Mathf.PI / 180.0f)) * Mathf.Sin(this.phiAngle * (Mathf.PI / 180.0f)) + this.target.position.z;
        }
    }

    /// <summary>
    /// Gets the Y position in rectanglular coordinates from spherical coordinates
    /// </summary>
    /// <value>The Y position.</value>
    float YPosition {
        get {
            return this.r * Mathf.Cos(this.phiAngle * (Mathf.PI / 180.0f)) + this.target.position.y;
        }
    }

    /// <summary>
    /// Gets the X position in rectanglular coordinates from spherical coordinates
    /// </summary>
    /// <value>The X position.</value>
    float XPosition {
        get {
            return this.r * Mathf.Cos(this.thetaAngle * (Mathf.PI / 180.0f)) * Mathf.Sin(this.phiAngle * (Mathf.PI / 180.0f)) + this.target.position.x;
        }
    }

    /// <summary>
    /// Gets the behind positional angle.
    /// </summary>
    /// <value>The behind position.</value>
    float BehindPosition {
        get {
            return (360.0f - this.target.eulerAngles.y) - 90.0f;
        }
    }

    void Update() {
        if(this.target == null) return;

        this.transform.position = Vector3.MoveTowards(this.transform.position, this.TargetPosition, this.movementSpeed * Time.deltaTime);

        this.transform.rotation = Quaternion.Slerp(this.transform.rotation, Quaternion.LookRotation(this.target.position - this.transform.position), this.rotateSpeed * Time.deltaTime);
    }

    /// <summary>
    /// Sets this gameObject behind the forward facing of the target.
    /// </summary>
    public void SetBehindTarget() {
        this.thetaAngle = this.BehindPosition;
    }

    /// <summary>
    /// Zoom in.
    /// </summary>
    public void ZoomIn() {
        this.r -= this.zoomSpeed * Time.deltaTime;

        this.r = Mathf.Clamp(this.r, this.minDistance, this.maxDistance);
    }

    /// <summary>
    /// Zoom out.
    /// </summary>
    public void ZoomOut() {
        this.r += this.zoomSpeed * Time.deltaTime;

        this.r = Mathf.Clamp(this.r, this.minDistance, this.maxDistance);
    }

    /// <summary>
    /// Reset zoom.
    /// </summary>
    public void ResetZoom() {
        this.r = (this.maxDistance - this.minDistance) / 2.0f;
    }

    /// <summary>
    /// Moves the gameObject upward bounded by the sphereical coordinate system.
    /// </summary>
    public void MoveUp() {
        this.phiAngle -= this.phiSteps;

        this.phiAngle = Mathf.Clamp(this.phiAngle, this.upperBound, this.lowerBound);
        this.phiAngle = Mathf.Clamp(this.phiAngle, 0.1f, 179.9f);
    }

    /// <summary>
    /// Moves the gameObject downward bounded by the sphereical coordinate system.
    /// </summary>
    public void MoveDown() {
        this.phiAngle += this.phiSteps;

        this.phiAngle = Mathf.Clamp(this.phiAngle, this.upperBound, this.lowerBound);
        this.phiAngle = Mathf.Clamp(this.phiAngle, 0.1f, 179.9f);
    }

    /// <summary>
    /// Move the gameObject counter clockwise.
    /// Reference Vector <1, 0, 1>
    /// </summary>
    public void CounterClockWise() {
        this.thetaAngle += this.thetaSteps;

        if(this.thetaAngle >= 360.0f) {
            this.thetaAngle = 0.0f;
        }
    }

    /// <summary>
    /// Move the gameObject clockwise.
    /// Reference Vector <1, 0, 1>
    /// </summary>
    public void ClockWise() {
        this.thetaAngle -= this.thetaSteps;

        if(this.thetaAngle < 0.0f) {
            this.thetaAngle = 360.0f;
        }
    }

    /// <summary>
    /// Gets the target position.
    /// </summary>
    /// <value>The target position.</value>
    public Vector3 TargetPosition {
        get {
            return new Vector3(this.XPosition, this.YPosition, this.ZPosition);
        }
    }
}

Mouse.cs

using UnityEngine;
using System.Collections;

[RequireComponent(typeof(SphericalMovement))]
public class Mouse : MonoBehaviour {
    SphericalMovement sphericalMovement;

    void Start() {
        this.sphericalMovement = this.GetComponent<SphericalMovement>();
    }

    void Update() {

        if(Input.GetAxis("Mouse X") < -0.1f) {
            this.sphericalMovement.CounterClockWise();
        }

        if(Input.GetAxis("Mouse X") > 0.1f) {
            this.sphericalMovement.ClockWise();
        }

        if(Input.GetAxis("Mouse Y") > 0.1f) {
            this.sphericalMovement.MoveDown();
        }

        if(Input.GetAxis("Mouse Y") < -0.1f) {
            this.sphericalMovement.MoveUp();
        }

        if(Input.GetAxis("Mouse ScrollWheel") > 0.1f) {
            this.sphericalMovement.ZoomIn();
        }

        if(Input.GetAxis("Mouse ScrollWheel") < -0.1f) {
            this.sphericalMovement.ZoomOut();
        }

        if(Input.GetKeyDown(KeyCode.Mouse2) == true) {
            this.sphericalMovement.ResetZoom();
            this.sphericalMovement.SetBehindTarget();
        }
    }
}

All you have to do is change the Transform components Rotation (transform.localEulerAngles) value when you move the mouse and set it’s Position (transform.position) to where the ship is.

Make an Empty GameObject called “CameraParent” and make Main Camera the child. Move Main Camera to 0,0,-10 position. Now just rotate CameraParent based on mouse movement and position it where the ship is.

Thanks guys, i didn’t wanted to post my script that i use now because it’s ridiculous and i already deleted it :wink:

I just wanted to say THANK YOU for providing this code for all of us. It works beautifully and you deserve more credit, again, thank you!