Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jamesseanwright/glitch-hunt
A HTML5 Canvas game for js13kGames 2016. Uses OscillatorNode for audio and music
https://github.com/jamesseanwright/glitch-hunt
canvas entity-component-system game html5 js13kgames web-audio
Last synced: 3 months ago
JSON representation
A HTML5 Canvas game for js13kGames 2016. Uses OscillatorNode for audio and music
- Host: GitHub
- URL: https://github.com/jamesseanwright/glitch-hunt
- Owner: jamesseanwright
- Created: 2016-09-11T15:23:52.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2016-12-01T19:48:30.000Z (about 8 years ago)
- Last Synced: 2024-10-01T03:23:24.290Z (3 months ago)
- Topics: canvas, entity-component-system, game, html5, js13kgames, web-audio
- Language: JavaScript
- Size: 696 KB
- Stars: 6
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Glitch Hunt
![Preview](https://raw.githubusercontent.com/jamesseanwright/glitch-hunt/master/preview.gif)
A HTML5 Canvas game for [js13kGames 2016](http://js13kgames.com/). Uses OscillatorNode for audio and music.
Patch the glitches in the system by pressing the keys on your keyboard as they enter the capture zone. Sometimes, a glitch will be so severe that you must enter the system and fight it!
## Play Online
Play via [Glitch Hunt](http://js13kgames.com/entries/glitch-hunt)'s entry page on the js13kGames website.
## Supported Browsers
* Chrome
* Firefox## Controls
### Hacking
Press the keys that appear on screen as they enter the capture zone.
### Boss Battle
* Arrow keys - move
* A - jump
* S - shoot## Making Of
I wrote a [blog entry](https://jamesswright.co.uk/blog/1474997-glitch-hunt-js13kgames-2016) detailing the motivation and technology behind my game, as well as what could have gone better.
## Judges' Feedback
> A cool mix of guitar hero/DDR and a metroidvania. Nice idea, fun!
-Christer Kaitila
> I really liked that this game was not just a typing game but also had some fighting in it. It was very smart to make the typing part only use keys you would need for fighting, so your hand would always be ready for the challenge. Overall, the game is well made.
-Jupiter Hadley
## Local Development
Once you've cloned this repository, you'll need to run the install script. This cURLs the [NanoTunes](https://github.com/jamesseanwright/nanotunes) library into the `lib` directory.
You'll also need to install [Closure Compiler](https://developers.google.com/closure/compiler/) and ensure that it is available on your path; you could write a [shell wrapper](https://gist.github.com/jamesseanwright/4b8e4c907c231a0f7ee71e01f5a33163) to achieve this. I haven't tested this with the version on npm, but theoretically this should work.
The project follows the Entity Component System design pattern, which in this case takes inspiration from [Richard Lord](http://www.richardlord.net/blog/what-is-an-entity-framework)'s implementation:
* Entity - a grouping of components
* Component - Attaches properties to an entity and registers it with the underlying system
* System - contains the logic for a particular type of componentThe codebase isn't perfect and definitely needs some work!
### Tasks
* `./tasks/install.sh` - cURLs NanoTunes into the `lib` directory. Run this before building
* `./tasks/build.sh` - bundles and minifies the source with Closure Compiler, and creates a ZIP of the output