This step by step tutorial will demonstrate how to re-create the game “Flappy Bird” using the online version of Scratch.
Setting up the stage
Start a new project in Scratch and change the stage backdrop to the backdrop called “Blue Sky”
data:image/s3,"s3://crabby-images/3a1f2/3a1f2c00fcfe1bf36948f4678e52c79404772c9c" alt="scratch-add-backdrop"
data:image/s3,"s3://crabby-images/1ecc5/1ecc5ea7d382e0ca48f30e8365da6e3ba1a2076b" alt="scratch-blue-sky-backdrop"
The Parrot Sprite
Next, we will delete the Cat sprite and create a new Parrot sprite:
data:image/s3,"s3://crabby-images/70aeb/70aeb5343d3e815e11d5c55decd57e11d72f6c8d" alt="scratch-remove-sprite-cat"
data:image/s3,"s3://crabby-images/7dc59/7dc5953e474907068800bee286bd1287f5bd9ec2" alt="scratch-parrot-sprite"
We will also resize our Parrot sprite to 25% of its original size:
data:image/s3,"s3://crabby-images/f1f92/f1f92bec0392e6afe75d6c9ce5fb7627b0926326" alt="scracth-parrot-size"
Let’s start coding
Using the Parrot sprite, let’s add some code.
First we will make sure the “Blue Sky” backdrop is always displayed when the game starts:
The let’s animate the parrot to make it flap its wings:
Controlling the Parrot using the space bar
Every time the user presses the space bar, the parrot should fly upwards.
data:image/s3,"s3://crabby-images/76b3a/76b3af6847d31781d5483fd23467ed2e8a689915" alt="scratch-control-flappy-bird"
Adding Gravity
The idea is that the parrot should constantly be pulled down by gravity.
data:image/s3,"s3://crabby-images/1bf30/1bf30e2fda9306d15f3f6ed730eb7043fd35330d" alt="scratch-gravity-algorithm"
Adding a Game Over Screen
The games ends when the parrot hits the ground. To implement this we will first need design a Game Over screen/backdrop:
data:image/s3,"s3://crabby-images/67938/67938a1a0fee69cd811edb4b8f61815ed2ac472c" alt="scratch-game-over-screen"
Then we will add some code to our Parrot sprite to detect when the parrot is hitting the ground. (On our “blue sky” backdrop, the ground has a brown color, you will need to use the color picker to retrieve this color):
Step 4: Adding a score variable
Let’s make a new variable called score. We will use this variable to score 1 point when the bird flies through as set of pipes. To do so we will need to go to the variable section:
data:image/s3,"s3://crabby-images/8d845/8d8453013dd1d31d784d1bf225c234be93fedd47" alt="scratch-variables-section"
Then you will click on the “Make a Variable button”.
data:image/s3,"s3://crabby-images/982d7/982d726702a968ea9439d27ac8cdc70b9d8a4136" alt="scratch-make-variable"
Give a name to your variable: score and tick the option “For all sprites”
data:image/s3,"s3://crabby-images/1b4e7/1b4e7642e98972bdd6722c0a4817d4104fd30ee1" alt="scratch-ball-bouncing-code-complete"
Make sure your variable is visible (Tick the checkbox next to the variable itself):
data:image/s3,"s3://crabby-images/2506f/2506f84f241b96a634c93851016b42ef87c78854" alt="scratch-make-variable-visible"
Let’s add the pipes
We will need to “paint” a new sprite for the pipe:
data:image/s3,"s3://crabby-images/9d370/9d37024752ac2efe997f0348b50949665c59eaad" alt="scratch-paint-new-sprite"
data:image/s3,"s3://crabby-images/ef67e/ef67e7aa198444c033dc5692637ec63133802274" alt="scratch-paint-pipes"
For our Parrot sprite we will edit our code as follows to reset the score to 0 when the game starts:
Now let’s add some code to our pipes sprite:
Finally, we will duplicate our pipes sprite:
And delay the second set of pipes by a few seconds:
You can also edit the costume for the second set of pipes to have a different “gap”.
Extension Task
Add a “splash screen” with basic instructions on how to play the game. The splash screen should include a start button to start the game.
The “Game Over” screen should only be displayed for a few seconds and then switch back to the start screen to let the player play again. In this case the score should automatically be reset to 0.