Create your own flappy bird game using Unity

How To Make Your Own Flappy Bird Game in 10 Minutes (Unity Tutorial)

If you are a big fan of mobile games then you probably have heard of the game Flappy Bird. Maybe you even have installed it and played it with your mobile phone even just for once.

Flappy Bird is a mobile game for both android and iOS and was developed by a Vietnamese indie game developer Dong Nguyen. It was released initially on May 24, 2013, and was suddenly pulled back from PlayStore somewhere around February of 2014.

Flappy Bird Game

The concept of the game is fairly simple. The player takes control of Faby (The bird) as he scrolls across the horizontal path while a gravity is pulling him down. The player must prevent Faby from hitting the Warp Pipes, and as Faby goes through each pipe, the player will get a point.

According to Dong Nguyen, this game was created in 3 days.

But! We’re going to do better than that because, in this tutorial, we’re going to create a flappy bird game in just 10 minutes using Unity Game Engine.



So without wasting any more time, let’s begin!

Creating Flappy Bird using Unity

Before we begin, it’s crucial that you have all of the tools that is required to start building your own game. Since we are creating a flappy bird clone game using Unity, you will need to have this game engine installed to your computer. If Unity isn’t already installed on your computer, you can download it from the official Unity website. This is a vital step, as Unity’s powerful platform will serve as the canvas and toolkit for your game development journey.

Create Unity Project

Once Unity is installed, create a new Unity project and make sure that you set its template to 2D.

Create new Unity 2022.3.24f1 Project

Downloading Assets

Before we can start creating the game, obviously we need the assets such as the bird, the pipes, the interfaces, and etc.

Flappy Bird Game Sprites

Once you have downloaded the file, go back to Unity and import the image.

Once imported, select the sprite and make sure you set its sprite mode to Multiple and Filter mode to Point and Compression to None. This will make your sprite sharp and high quality.

Don’t forget to click Apply to save changes.

Importing Flappy Bird Sprites to unity

Now, if you have noticed already, our assets are compiled into a PNG file which is then converted into a sprite, once imported in Unity.

We need to slice this sprite using Sprite Editor so we can use the objects such as the bird, the pipes, and etc.

Go ahead and select the sprite once again, and right under the Generate Physics checkbox, click the Sprite Editor button.

This will open the following window.

Unity 2019.1.1.f1 Sprite Editor Window for Flappy Bird

Now to create new sprites, select the objects by dragging inside the Sprite Editor. (Just imagine you’re using Photoshop and you’re select an image)

Flappy Bird Sprite Editor Unity

Once you’re done slicing the sprite, click apply.

Saving Sprites in Unity

Once successful, you should see all the sprites sliced inside your Flappy Bird sprite asset.

Flappy Bird Sprites Import Settings

Setting up the Game

Now that we’re done with our assets, let’s start this tutorial by adjusting our game aspect ratio to 9:16.

Unity Game Aspect Ratio

Then we’ll drop our game background in the hierarchy.

Creating Flappy Bird with Unity

Next, go to your Scene window (CTRL + 1) and click on the Main Camera inside the hierarchy and drag the white dot down until it matches the size of our background.

Next, go to Inspector window and set its Order in Layer value to -1.

Flappy Bird Background Image

That should make your game preview ready for the player.

Creating the Player

Now that we’re done with the background, the next thing we’re going to work on is the bird or our Player.

Let’s go back to our Project files and open our Flappy bird sprite once again and drag the bird sprite with its wing raised up into our hierarchy.

Rename the game object to Player

Flappy Bird Animation Setup

Next, we’re going to create a new animation- so go to your project window and right-click- select Create then choose Animation.

Creating New Animation in Unity

You can name the animation whatever you want. We’ll call it Faby.

Then drag the animation to the Player game object. That will generate a new Animator component for our Player.

Flappy Bird Animation

Next, open the Animation window by pressing CTRL + 6.

With your Player selected, go to your project window, open Flappy Bird sprite, and drag all the three bird sprites in the animation window.

Animating Flappy Bird Sprites with Unity

To make your animation look better, adjust your animation by dragging the last keyframe to 0:10 and the second keyframe to 0:05 and leave the first keyframe to its original place.

Adjusting Flappy Bird Sprite Animation

The Platform

The next game object that we need is the platform.

Go to your Project window once again and drag and drop the platform in the hierarchy.

Flappy Bird Platform

Now, obviously we need to drag this platform down at the bottom of the screen so go to your scene window once again and just drag the platform down.

Let’s also rename this game object to Platform.

Same with the background, let’s rename it to Background.

Now, select your Platform game object and change its Draw Mode to Tiled. We’ll also change its Order in Layer to 1.

Unity 2019 Inspector Window

This will make our platform seamless and be displayed at the top of everything.

Next, we’ll add a box collider to this game object by clicking the Add Component button and searching Box Collider 2D.

Make sure you set its Auto Tiling to true.

Player Physics

For this game to work properly, we need to apply physics to our player.

So with your Player game object selected, go to your inspector window and click Add Component and search for Rigidbody 2D.

Adding Rigidbody 2D to Game Objects Unity

And after that, we’ll add another component which is the capsule collider so click Add Component button once again and search for Capsule Collider 2D.

Then we’ll set Capsule Collider 2D‘s direction to Horizontal.

Next, click the edit collider button and adjust the size of the capsule collider that will fit your player.

Adding Capsule collider 2D to Player

Player Script

We’re going to create a new script to make our player jump as soon as we tap our screen.

So go to your Project window, right-click, select Create, then choose C# Script.

Let’s name our script Player.cs

Once the script is created, drag the script to the player game object and then open that script with Visual Studio.

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Player : MonoBehaviour
{
    public float velocity = 2.4f;
    private Rigidbody2D rigidbody;

    // Start is called before the first frame update
    void Start()
    {
        rigidbody = GetComponent<Rigidbody2D>();
    }

    // Update is called once per frame
    void Update()
    {
        if(Input.GetMouseButtonDown(0))
        {
            rigidbody.velocity = Vector2.up * velocity;
        }
    }
}
Code language: C# (cs)

The Obstacles

Now that our player is done, our platform is done, and our background is done. It’s time for us to create the obstacles (commonly known as the warp pipes).

Let’s open our sprites once again and drag the two warp pipes into our scene.

With our warp pipes selected, add a component by pressing the Add Component button and searching for Box Collider 2D.

Then we’ll align these pipes to one another vertically, just like the game itself. Then we’ll create an Empty Game Object and name it Obstacle pipes, and then, we’ll drag our two warp pipes into that empty game object.

In other words, we’ll make our empty game object the parent of these two warp pipes. Did it sound too complicated? 😉

Also, make sure you place your empty game object between the two warp pipes. So it will look something like below.

Making Warp Pipes for Flappy Bird Game

Next, we’ll create a new C# script but this time it’s obstacle.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class obstacle : MonoBehaviour
{
    public float speed;

    // Update is called once per frame
    void Update()
    {
        transform.position += ((Vector3.left * speed) * Time.deltaTime);
    }
}
Code language: C# (cs)

Make sure to drag this script to the Obstacle Pipes game object.

Now that our obstacle is ready, we can now then create an obstacle spawner so our obstacle will keep on coming endlessly.

To do that, we’ll create another empty game object and we’ll name it Obstacle Spawner.

Then make sure you reset its Transform position and drag it’s X position all the way to the right of the screen.

We’ll create another C# script and we’ll name it spawner.cs.

Make sure you assign this script to Obstacle Spawner game object.

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class spawner : MonoBehaviour
{
    public float queueTime = 1.5;
    private float time = 0;
    public GameObject obstacle;

    public float height;

    // Update is called once per frame
    void Update()
    {
        if(time > queueTime)
        {
            GameObject go = Instantiate(obstacle);
            go.transform.position = transform.position + new Vector3(0, Random.Range(-height, height), 0);

            time = 0;

            Destroy(go, 10);
        }

        time += Time.deltaTime;
    }
}
Code language: C# (cs)

Make sure to save all of your scripts as well as your scene.

Go back to unity and this time, we’ll save our Obstacle Pipes as a Game Object Prefab. To do that, drag the Obstacle Pipes in the Assets.

Next, select the Obstacle Spawner game object, and drag the Obstacle Pipes prefab to the Obstacle variable.

Game Object to Prefab

You should have the following results.

Flappy Bird Gameplay GIF

Scrolling Platform

We’re almost done! However, if you look closely, you will see that our platform is not scrolling horizontally along with our warp pipes. That looks weird.

To fix that, create a new animation and call it platform. Then drag the animation to the platform game object.

Then we’ll increase the horizontal scale of our platform.

Platform of Flappy Bird in Unity

Then open the Animation window by pressing CTRL + 6.

With your platform game object selected, click Add Property button in the Animation window and select Transform then Position.

Add New Property for Unity Animation

To create a keyframe, click the button beside the number input. Then somewhere around 3:00 seconds, we’ll create another keyframe, but this time we’ll adjust the value of x.

Animating Game Objects with Unity

So for example, in the first keyframe, I have 0.59 for the x position and in the second keyframe, I have -0.59. This will make our platform scroll from 0.59 x position to -0.59 x position every 3 seconds.

The User Interface

The game is almost done, but there’s still one thing that we’re not setting up yet, and that is our player death as well as the user interface when the player dies.

To start, let’s create a new Canvas by going to our hierarchy, right-click and select UI, and then Canvas.

Creating a new canvas for UI

Next, right-click on the Canvas game object that you have just created then select UI, then Image.

Creating UI Image for Canvas in Unity

Rename this Image game object to Restart Button.

Next, open your Flappy Bird Sprite asset once again and look for the play button and drag it to the Source image of the Restart Button game object.

Assigning sprite to Image UI Component

Once you have applied the image, proceed by clicking the Set Native Size button.

Resetting UI Image by default native size in Unity

If you want, you may scale up the image to your desired size. In our case, we’ll scale it by 1.85 (X, Y, and Z-axis)

Game Manager

The next thing we’re going to do is to create a script or a game manager where it freezes the game but as soon as you click the start button, the game unfreezes.

Then when the player dies, the game freezes and does a countdown for restarting the game.

Alright, let’s create a new game object and call it GameManager and a new C# script and call it GameManager.cs.

Once the script is created, we’ll assign it to our Game Manager game object.

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEditor.SceneManagement;

public class GameManager : MonoBehaviour
{
    public GameObject startButton;
    public Player player;

    public Text gameOverCountdown;
    public float countTimer = 5;

    // Start is called before the first frame update
    void Start()
    {
        gameOverCountdown.gameObject.SetActive(false);
        Time.timeScale = 0;
    }

    private void Update()
    {
        if( player.isDead )
        {
            gameOverCountdown.gameObject.SetActive(true);
            countTimer -= Time.unscaledDeltaTime;
        }

        gameOverCountdown.text = "Restarting in " + (countTimer).ToString("0");

        if(countTimer < 0)
        {
            RestartGame();
        }
    }

    public void StartGame()
    {
        startButton.SetActive(false);
        Time.timeScale = 1;
    }

    public void GameOver()
    {
        Time.timeScale = 0;
    }


    public void RestartGame()
    {
        EditorSceneManager.LoadScene(0);
    }
}

Code language: C# (cs)

Using the script above, you have to make sure that you have your scene in the Build Settings. Otherwise, you’ll receive an error as soon as you start your game.

Unity Build Settings for Flappy Bird game

Next, we’ll add a button component to our Play button image.

Click the Image game object, Add Component, then search for Button.

Adding Button Component to Image UI

Next, inside the button component, navigate to On Click() and add a new list by clicking on the little plus button located at the bottom-right corner.

Adding a new list in the On Click() Button function in Unity

Next, drag the GameManager game object to the box right under the Runtime Only dropdown.

Runtime Only values for Unity Button UI

Next, click on the No Function dropdown and change it to GameManager then StartGame ().

Button Function on Click to start a game

Next, select the GameManager game object and drag your Image game object to the Start Button.

Dragging Canvas Game Object to a variable

Don’t forget to save your scene.

Player Death

Now that we have a start button, the last thing we need to do is to make our player die as soon as it hits either the floor or the warp pipes.

To do that, we have to go back to our Player.cs script and add the following code.

public GameManager gameManager;
public bool isDead = false;

private void OnCollisionEnter2D(Collision2D collision)
{
    isDead = true;
    gameManager.GameOver();
}Code language: C# (cs)

Save the script, and go back to Unity.

Lastly, we’ll create a Text game object and assign it to our GameManager script.

Right-click in the hierarchy, select UI, then select Text.

Creating a UI Text in Unity

Next, we’ll change it’s alignment to center, we’ll tick the Best Fit checked, and we’ll change its Font Size to 25 and Font Style to bold. Then, we’ll drag this Text all the way to the top by 125.65 on Y-axis.

Then, for the sake of the design, we’ll add a new component, search for Shadow.

Next, select our GameManager game object for the last time and drag the Player game object as well as the Text UI object to the Game Manager script.

Assigning two game objects to a script in Unity

Save all of your scripts, and play your Flappy Bird game!

Flappy Bird Game Tutorial Finished

Conclusion

For the record, we have created this game in just 7 minutes but since you have to read everything to understand what’s going on, then you might take longer than 10 minutes to finish this project. However, once you get everything, you can definitely develop this game in just a short amount of time.

There’s one more missing to this tutorial, and that is the score. We’re going to continue this project in the next tutorial so if you are interested, let us know in the comments below.

Any reactions? Let us know!

4 Comments.

  1. hello, i got as far as to spawning pipes, but whenever i play the new pipes are invisible and aren’t spaced out right wich messes up the game, is there a fix to that?

    1. Hi Mason!

      Thank you so much for reading our articles!

      In regards to your question, yes there is a fix to that! Have you tried checking if your warp pipes are set up properly? Make sure that the parent game object of the warp pipes is between the warp pipes. Also, make sure that your scripts in the inspector have values, especially the velocity. We also recommend checking the spawner’s transform position. Make sure it’s outside the screen area and its transform Y-position must be 0.

      We would love to know more about this issue that you’re encountering so we could help you better.

      Cheers!

Leave a Reply