mirror of
https://github.com/photonstorm/phaser
synced 2025-01-07 02:38:53 +00:00
53 lines
1.6 KiB
TypeScript
53 lines
1.6 KiB
TypeScript
|
/// <reference path="../../Phaser/Game.ts" />
|
||
|
/// <reference path="../../Phaser/gameobjects/Particle.ts" />
|
||
|
/// <reference path="../../Phaser/gameobjects/Emitter.ts" />
|
||
|
|
||
|
// Actually we could achieve the same result as this by using a sprite sheet and basic Particle
|
||
|
// but it still shows you how to use it properly from TypeScript, so it was worth making
|
||
|
class customParticle extends Phaser.Particle {
|
||
|
|
||
|
constructor(game:Phaser.Game) {
|
||
|
|
||
|
super(game);
|
||
|
|
||
|
var s = ['carrot', 'melon', 'eggplant', 'mushroom', 'pineapple'];
|
||
|
|
||
|
this.loadGraphic(game.math.getRandom(s));
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
(function () {
|
||
|
|
||
|
var myGame = new Phaser.Game(this, 'game', 800, 600, init, create);
|
||
|
|
||
|
var emitter: Phaser.Emitter;
|
||
|
|
||
|
function init() {
|
||
|
|
||
|
myGame.loader.addImageFile('carrot', 'assets/sprites/carrot.png');
|
||
|
myGame.loader.addImageFile('melon', 'assets/sprites/melon.png');
|
||
|
myGame.loader.addImageFile('eggplant', 'assets/sprites/eggplant.png');
|
||
|
myGame.loader.addImageFile('mushroom', 'assets/sprites/mushroom.png');
|
||
|
myGame.loader.addImageFile('pineapple', 'assets/sprites/pineapple.png');
|
||
|
|
||
|
myGame.loader.load();
|
||
|
|
||
|
}
|
||
|
|
||
|
function create() {
|
||
|
|
||
|
emitter = myGame.add.emitter(myGame.stage.centerX, 50);
|
||
|
emitter.gravity = 100;
|
||
|
|
||
|
// Here we tell the emitter to use our customParticle class
|
||
|
// The customParticle needs to extend Particle and must take game:Game as the first constructor parameter, otherwise it's free as a bird
|
||
|
emitter.particleClass = customParticle;
|
||
|
|
||
|
emitter.makeParticles(null, 500, false, 0);
|
||
|
emitter.start(false, 10, 0.05);
|
||
|
|
||
|
}
|
||
|
|
||
|
})();
|