Office Simulator: The Concept
We're creating an office life simulation game from scratch. Learn how to transform an abstract game idea into a better documented plan. Follow along as we start the development process.
Author
Learn how to breathe life into your Unity projects with parallax effects in this step-by-step tutorial.
Parallax effects breathe life into game environments adding depth and immersion. In this guide, we'll explore creating these effects in Unity. Whether you're new to game development or a Unity pro, this tutorial will elevate your projects.
We used a free asset from the Unity Asset store. If you'd like to use the same background, you can download it here.
Drag and drop the background images into the scene and nest them under the main camera for your game. We’re doing this because our camera follows the player, so having it be the parent for the background objects is ideal. Stack them on top of each other and scale them so that they are the same height as the camera view port.
Sort the layers using the Order in Layer field on the Sprite Renderer. I’m going to set
Now duplicate the backgrounds and place a copy to the left and right of the camera. Be sure to line up the start and stop of each image or else you’ll get a weird jitter on your parallax effect.
Nest the left and right images into the original background object. Here’s what the Scene and Hierarchy should look like now
The script is actually very simple. And here it is!
using UnityEngine;
[RequireComponent(typeof(SpriteRenderer))]
public class Parallax : MonoBehaviour
{
private float length;
private float startpos;
public GameObject cam;
public float parallaxEffect;
void Start()
{
startpos = transform.position.x;
length = GetComponent().bounds.size.x;
}
void Update()
{
float temp = cam.transform.position.x * (1 - parallaxEffect);
float dist = cam.transform.position.x * parallaxEffect;
transform.position = new Vector3(startpos + dist, transform.position.y, transform.position.z);
if (temp > startpos + length)
{
startpos += length;
}
else if (temp < startpos - length)
{
startpos -= length;
}
}
}
Attach the script to each of the main background elements. Then drag the main camera onto the cam property.
The parallaxEffect property can be tweaked to fit your situation.
A value of 1 will move the image with the camera. While 0 will keep it in the same position.
We have similar articles. Keep reading!
We're creating an office life simulation game from scratch. Learn how to transform an abstract game idea into a better documented plan. Follow along as we start the development process.
Author
First announcement that we're going to try making The Venom Event again!
Author
Shaders are a powerful tool in game development, allowing developers to create rich, visually striking effects that can greatly enhance the realism and immersion of a game. However, they can also be complex and difficult to understand.
Author