Learn JavaScript by building the classic arcade Break Out. You will use vanilla to create this game following the tutorial.
Note! This tutorial is not the best use of JS. Think of this as a naive application of code. You will update and rewrite this code to improve it and learn more JS along the way! The first step is to complete the tutorial.
This assignment includes a wide range of features from the JavaScript language. Including functions, variables, arrays, objects, and if-else, and loops. You need to understand these becaus they are the basic building blocks of the JS language.
Understanding the concepts used in this project will take you a long way to being able to understand and answer technical questions at interviews.
The start of this project is to complete the tutorial here:
https://developer.mozilla.org/en-US/docs/Games/Tutorials/2D_Breakout_game_pure_JavaScript
Follow these steps:
- Create a new GitHub repo
- Follow the tutorial here: https://developer.mozilla.org/en-US/docs/Games/Tutorials/2D_Breakout_game_pure_JavaScript
- Create a commit at the end of each step of the tutorial
- There are 10 steps to the tutorial you should have a commit for each step.
- After completing the tutorial try the stretch challenges below.
You can follow the me building the tutorial in video here:
https://www.youtube.com/playlist?list=PLoN_ejT35AEiSYr-OhYV-C6uWZgPLBMZM
This video playlist covers the basic tutorial and goes into the following assignments also.
The code in this tutorial is not particularly well written the code structures are not well thought out! There are even a few things that I would call errors, even though the code functions without throwing any errors.
Keep your eyes on the code! Ask yourself what is going on? It is important for you to understand how the code functions! You can copy and paste the code from the tutorial and it will work but if you do not understand the code you need to stop and read the code carfully to figure out how it works and what it is trying to do. Only by doing this will you be able to spot the "errors" and solve the stretch goals below!
Submit your work on GradeScope.
Use this rubric to measure the success of your work against the expectations of the assignment. You should be striving for an average score of 1 or greater.
Aspect | Does not meet (0) | Meets (1) | Exceeds (2) |
---|---|---|---|
Completion | The tutorial is not been completed | Tutorial completed (all 10 steps) | You have tried the stretch challenges |
Functionality | The game is not functioning or partially functional | The game is functional | You have successfully implemented some or all of the stretch challenges |
Work Ethic | < 3 commits. | Commits show consistent work | commits show full 3 hours of work |
Use this rubric to assess how your understanding of the learning objectives. You should be striving for an average score of 1 or greater
Expectations | Does not meet (0) | Meets (1) | Exceeds (2) |
---|---|---|---|
Writing JS | Can not write simple programs with JS without a tutorial | Can write simple programs in JS without tutorial | Could write a JS tutorial that teaches simple programming concepts |
Code Flow | Can not evaluate and explain the flow of code in the tutorial | Can explain and follow the flow of code in the tutorial program | Could make improvements, evaluate, and optimize the flow of code in the tutorial program |
Variables | Could not define variables without reference | Can define and use variables without a reference | Could easily define variables of any type without reference |
Functions | Could not write a function without reference | Can write functions from memory | Could use functions to organize code in any new program |
Loops | Could not write a loop without reference | Can write a for loop without reference | Could write a loop that iterates from any starting value to any ending value without reference |
Arrays | Could not define and use an array without reference | Can define and use arrays without a reference | Could plan new programs that work with arrays |
Objects | Could not define and use objects without reference | Can define and use objects without a reference | Could plan new programs that work with objects |
Find problems with tutorial code
The tutorial has a couple problems. Examine the code and see how many issues you can find.
Change the colors
Everything is currently blue and gray. Choose some new colors to customize the game. Change the colors of these elements:
- Bricks
- Ball
- Paddle
- Background
Make each row of bricks a different color
A single color is not very interesting. Make each row a different color. Bricks are managed with a two-dimensional array.
The code draws all of the bricks with each call to draw()
, this method calls the drawBricks()
. You'll need to solve this here. In this method, the variables c
and r
hold the number of the column and row for each brick. Change the color by changing the cxt.fillStyle
.
See the image below:
Make each column a different color
You changed the rows try changing the columns to different colors.
Alternate colors of bricks
Alternate the colors of the bricks.
Make more rows
The game might be more fun if there were more bricks. Add more bricks in each row. To do this you'll need to change the number of bricks along with the width of each brick.
Make sure the space between the bricks stays the same.
Make more rows and columns
Offset rows
Different sized bricks
Make colored bricks worth points
Make each row of bricks worth a different number of points. The first row is worth 10. The second row is worth 20 and the top row is worth 30 for each brick.
Custom Background
Write a function to draw the background for the game. Currently the draw()
function clears the canvas on it's first line with:
ctx.clearRect(0, 0, canvas.width, canvas.height);
Add a function called drawBackground()
. Call this on the first line of draw()
.
Try these challenges:
- Fill the background with a color other than the default color. Do this by drawing a rectangle that starts at x 0, y 0 with a width and height that match your canvas. Do all of this in the
drawBackground()
function. - Draw some concetric circles each larger than the last. You could autmate this with a loop. Give each circle a different color. These circles will be the new background to the game.
- Draw a gradient to fill the background. Read up on using gradients with canvas here.