Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codenameyau/snake-game
Snake in ES6 JS and canvas with webpack
https://github.com/codenameyau/snake-game
canvas es6 game javascript raw snake
Last synced: 22 days ago
JSON representation
Snake in ES6 JS and canvas with webpack
- Host: GitHub
- URL: https://github.com/codenameyau/snake-game
- Owner: codenameyau
- License: mit
- Created: 2017-06-21T23:45:33.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-01-01T08:57:59.000Z (about 2 years ago)
- Last Synced: 2024-04-14T07:07:27.240Z (9 months ago)
- Topics: canvas, es6, game, javascript, raw, snake
- Language: JavaScript
- Homepage: https://codenameyau.github.io/snake-game/
- Size: 2.08 MB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# snake-game
![Snake Game](https://user-images.githubusercontent.com/3826772/60639920-9ccf7980-9df2-11e9-9b32-7be1e3412a77.png)
## Website
https://codenameyau.github.io/snake-game/## Implementation Details
I implemented the snake using an Array (Queue), where the first element represents
the head of the snake and the last element represents the tail. As the snake
moves, the tail is popped and the new cell position is appended to the front
of the segments as the new head. If the head of the snake collides with a food,
then tail is not popped. If the head collides with another snake segment, then
the game is over.Collision detection is implemented via a matrix that keeps track of all cells
in the game. The snake segments and food are then drawn on the canvas. The
individual matrix cells are not rendered.## Running Instructions
```bash
# Running game with Webpack.
npm install
npm start# Running tests.
npm test
```Then visit http://localhost:8080
## Tasks
These are the steps I took when creating this game.
```
[+] Setup Webpack for ES6
[+] Setup ES6 tests with Mocha and Chai
[+] Design and create the HTML / CSS game layout
[+] Design and create Game class
[+] Design and create Snake class
[+] Design and create Food class
[+] Implement and render snake
[+] Implement and render food
[+] Spawn randomly generated snake on canvas
[+] Spawn randomly generated food on canvas
[+] Implement collision detection matrix
[+] Handle user input
[+] Implement game status
[+] Implement score
[+] Implement start/pause/restart game
[+] Implement game loop and rendering animation frames
[+] Implement snake movement
[+] Implement snake and food collision events
[+] Fix bug with snake colliding with itself when moving backwards
[+] Implement wall collision
[+] Implement top 5 high scores
```### Future Enhancements
```
[ ] Add mobile touch support
[ ] Revisit collision detection algorithm with sparse matrix
[ ] Add animations
[ ] Add music and sound effects
[ ] Implement no walls option
[ ] Implement options UI
[ ] Multiplayer (separate repo)
```