Phaser is an open source Desktop and Mobile HTML5 game framework primarily.
It includes a robust set of documentation, features and examples to get you moving towards a working game quickly. It supports WebGL, via the Pixi.js rendering engine, and includes a Canvas fallback for support on older devices.
Although the engine is built in JavaScript it also includes TypeScript definitions
There is a new envisioning of the project that is ES6 compliant called Lazer.
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>My Gamer</title>
<script type="text/javascript" src="lib/phaser.js"></script>
<style type="text/css">
body {
margin: 0;
}
</style>
</head>
<body>
<div id="gameContainer"></div>
</body>
</html>
// Phaser instance, width 800px, height 600px render as CANVAS.
// Method signature - preload, create and update
var game = new Phaser.Game(800, 600, Phaser.CANVAS,'gameContainer', { preload: preload, create: create, update: update });
function preload() {
// this method used to load your game assets
}
function create() {
// this method run only once used to create to game world
}
function update() {
// this method loop 60 times in a seconds, used to handle gameplay.
}
mkdir my-new-game cd my-new-game
npm init -y
npm install phaser
npm install -g http-server
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8" /> <title>My Gamer</title> <script type="text/javascript" src="node_modules/phaser/build/phaser.js"></script> <style type="text/css"> body { margin: 0; } </style> </head> <body> <div id="helloWorld"></div> </body> <script> var game = new Phaser.Game(800, 600, Phaser.CANVAS, 'helloWorld', { create: create }); function create() { var text = "Hello World!"; var style = { font: "65px Arial", fill: "#ff0044", align: "center" }; var t = game.add.text(game.world.centerX, 300, text, style); t.anchor.set(0.5); } </script> </html>
hs