A JavaScript/HTML5 Canvas port of a Processing(Java) project I originally made with Simon Colman and Nathan Hall for a university group project. Based on Missile Command an arcade classic originally developed in 1980 by Atari.
The first 209 commits of this project show the processing project, after which I deleted everything to start with JavaScript and HTM5 Canvas using the old processing project as a reference.
- Six cities that are under attack.
- Ballistic missiles that rain down on the cities.
- Anti-ballistic missile battery that fires counter-missiles.
- A scoring system that rewards the player for shooting the ballistic missiles and any left-over munitions at the end of a given round.
- The game should reset (and potentially move to a harder level) when the player destroys all of the ballistic missiles in a given round.
- Add level and rounds system - finite number of ballistic and counter missiles per round/level
- Add scoring bonus for unused counter missiles
- Add sound
- Ballistic missiles that come into contact with the explosion from a detonating counter missile should be destroyed
- Add display to show missiles left
- Additional types of attackers (e.g. The Smart * Bombs that can be seen in the Atari 2600 Gameplay).
- Multiple missile batteries with different counter missiles (e.g. some might move faster)
- Have the game run on the web using JavaScript and HTML5 Canvas
- Practice using JavScript, HTML5 Canvas, ES6 classes and OOP
- Make use of OOP and ES6 classes - the original project was a mix of classes and files of functions
- Avoid using global variables that are accessible outside of the files they are created in
- If you must use a global variable outside of the file it was created in make sure to explicitly export and import it - in the old project processing allowed the use of global variables without exporting and importing them - making it hard to see where a variable had come from
- Use function, method and class parameters or class fields in preference to exporting and importing globals
- Code should be simple, readable and modular - variable, function, class and method names should be used to make explicit what the code does, magic numbers should be avoided and named variables used instead. Comments should be used when needed to explain anything that might be unclear, or to provide references to sources.