A logical step forward from interactive animated programs is games. The goal of this assignment is to program the classic computer game, Snake. The goal of Snake is to create a snake as long as possible. This is achieved by guiding the snake to an apple on the game board. The snake cannot stop moving, and dies whenever it hits something (excluding apples). Because the snake is growing longer and longer as the game progresses, it gets increasingly difficult to avoid collisions with the snake itself. The player can change the direction of the head of the snake by using the arrow keys. At step in the game, there is always an apple somewhere on the board. If the snake eats an apple, the snake becomes one cell longer. A new apple is placed on a random location, excluding all places covered by the snake. When the snake reaches a side of the game board, it re-emerges at the opposite end. It is probably easiest to understand the game by playing it yourself. You can find a lot of snake implementations on the web, for example here (Links to an external site.). There are four differences between this implementation and the one you should make. Your implementation should: make the snake should grow block at a time instead of 4. make the snake re-emerge at the other end of the screen when reaching the end of the screen instead of dying. make the snake start at a length of 2, at the top left (instead of a length of 1 at the center). Take the following steps to implement the game: First make a single cell that keeps moving, and of which you can change the direction via the arrow keys. Change the program such that if the cell goes beyond the end of the screen, it reemerges at the other end. For example, if the cell leaves the screen on the right side, it should come out on the left side. Make a snake of length 2 that starts in the top left, and then only grows (as if it eats an apple each step). Keep a list of points in the snake and add a new point to the end after each step. Make a snake that moves and stays of length 2. It moves by adding an extra step to your program: after adding a new point to the end of the list, remove a point at the start of the list. Place the apple using ui.random as described below (at this point you should be able to pass some tests). Allow the snake to eat apples. Do the following steps (afterward you should pass some more tests): If the head of the snake is on the apple: Do not remove a point at the start of the list (this makes the snake grow by 1 cell) Place a new apple as described above Implement game over. If the point where the head of the snake is is also in the body (snake without head), then the game is over. Call ui.set_game_over() to display the game over screen. Afterward, you should be able to pass all tests. Apple placement To ensure reproducible behavior, we specify exactly how a random number generator must be used to place the food. For this, we provide the method ui.random(max) This gives a random integer in the range [0 − max ) (exclusive). During testing, the result of this method will not be random, but will be the number specified as apple_spot in the test files. You might be tempted to randomly place the apple using the following method, which we DO NOT USE: Pick a random horizontal coordinate. Pick a random vertical coordinate. If the resulting coordinate is not free, try again. This method has the downside that it might take a lot of tries before you find a free spot, especially if the board is almost full. Moreover, it requires an arbitrary amount of numbers for placing a single apple, which complicates testing. Instead of the above method, we opt for a method that always succeeds at placing an apple, using only a single number. To see how this works, suppose we have a 5x3 board and the current position of the snake is as follows: ..... .XXX. ..... To determine the position of the apple, we want to pick a random free spot on the board (the apple should not be placed on the snake). We number the free spots on the board from left to right, top to bottom, skipping any spot occupied by the snake. In our example, this means the following numbering: 0 | 1 | 2 | 3 | 4 ---+---+---+---+--- 5 | X | X | X | 6 ---+---+---+---+--- 7 | 8 | 9 | 10| 11 To pick a random spot, first compute the number of free spots and then call ui.random(nrFreeSpots) (in our case nrFreeSpots=12 ). Then place the
A logical step forward from interactive animated programs is games. The goal of this assignment is to program the classic computer game, Snake.
The goal of Snake is to create a snake as long as possible. This is achieved by guiding the snake to an apple on the game board. The snake cannot stop moving, and dies whenever it hits something (excluding apples). Because the snake is growing longer and longer as the game progresses, it gets increasingly difficult to avoid collisions with the snake itself. The player can change the direction of the head of the snake by using the arrow keys. At step in the game, there is always an apple somewhere on the board. If the snake eats an apple, the snake becomes one cell longer. A new apple is placed on a random location, excluding all places covered by the snake. When the snake reaches a side of the game board, it re-emerges at the opposite end.
It is probably easiest to understand the game by playing it yourself. You can find a lot of snake implementations on the web, for example here (Links to an external site.). There are four differences between this implementation and the one you should make. Your implementation should:
- make the snake should grow block at a time instead of 4.
- make the snake re-emerge at the other end of the screen when reaching the end of the screen instead of dying.
- make the snake start at a length of 2, at the top left (instead of a length of 1 at the center).
Take the following steps to implement the game:
- First make a single cell that keeps moving, and of which you can change the direction via the arrow keys.
- Change the program such that if the cell goes beyond the end of the screen, it reemerges at the other end. For example, if the cell leaves the screen on the right side, it should come out on the left side.
- Make a snake of length 2 that starts in the top left, and then only grows (as if it eats an apple each step). Keep a list of points in the snake and add a new point to the end after each step.
- Make a snake that moves and stays of length 2. It moves by adding an extra step to your program: after adding a new point to the end of the list, remove a point at the start of the list.
- Place the apple using ui.random as described below (at this point you should be able to pass some tests).
- Allow the snake to eat apples. Do the following steps (afterward you should pass some more tests):
- If the head of the snake is on the apple:
- Do not remove a point at the start of the list (this makes the snake grow by 1 cell)
- Place a new apple as described above
- If the head of the snake is on the apple:
- Implement game over. If the point where the head of the snake is is also in the body (snake without head), then the game is over. Call ui.set_game_over() to display the game over screen. Afterward, you should be able to pass all tests.
Apple placement
To ensure reproducible behavior, we specify exactly how a random number generator must be used to place the food. For this, we provide the method
ui.random(max)
This gives a random integer in the range [0 − max ) (exclusive). During testing, the result of this method will not be random, but will be the number specified as apple_spot in the test files.
You might be tempted to randomly place the apple using the following method, which we DO NOT USE:
- Pick a random horizontal coordinate.
- Pick a random vertical coordinate.
- If the resulting coordinate is not free, try again.
This method has the downside that it might take a lot of tries before you find a free spot, especially if the board is almost full. Moreover, it requires an arbitrary amount of numbers for placing a single apple, which complicates testing.
Instead of the above method, we opt for a method that always succeeds at placing an apple, using only a single number. To see how this works, suppose we have a 5x3 board and the current position of the snake is as follows:
..... .XXX. .....
To determine the position of the apple, we want to pick a random free spot on the board (the apple should not be placed on the snake). We number the free spots on the board from left to right, top to bottom, skipping any spot occupied by the snake. In our example, this means the following numbering:
0 | 1 | 2 | 3 | 4 ---+---+---+---+--- 5 | X | X | X | 6 ---+---+---+---+--- 7 | 8 | 9 | 10| 11
To pick a random spot, first compute the number of free spots and then call ui.random(nrFreeSpots) (in our case nrFreeSpots=12 ). Then place the apple at the position corresponding to the number you got.
Game over
The game ends when the head of the snake collides with the rest of the body. In that event, you should call ui.set_game_over() to display the game over screen.
You must call ui.show for each frame in the test: once at the start and after each "alarm : refresh". This means you must also call ui.show() after calling ui.set_game_over(). If you call ui.show() less often than described here, you will get an error saying you did not call ui.show() often enough.
Step by step
Solved in 3 steps with 6 images