// Difference is Canvas Blend Modes class Example extends Phaser.Scene { constructor () { super(); this.sprites = []; } preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.image('bg', 'assets/skies/space1.png'); this.load.image('particle', 'assets/particles/yellow.png'); this.load.image('logo', 'assets/sprites/phaser2.png'); } create () { this.add.image(400, 300, 'bg'); // Create the particles for (var i = 0; i < 300; i++) { const x = Phaser.Math.Between(-64, 800); const y = Phaser.Math.Between(-64, 600); const image = this.add.image(x, y, 'particle'); // Canvas and WebGL: // NORMAL // ADD // MULTIPLY // SCREEN // Canvas only: // OVERLAY // DARKEN // LIGHTEN // COLOR_DODGE // COLOR_BURN // HARD_LIGHT // SOFT_LIGHT // DIFFERENCE // EXCLUSION // HUE // SATURATION // COLOR // LUMINOSITY // image.setBlendMode(Phaser.BlendModes.OVERLAY); image.setBlendMode(Phaser.BlendModes.ADD); this.sprites.push({ s: image, r: 2 + Math.random() * 6 }); } this.add.image(400, 300, 'logo').setBlendMode(Phaser.BlendModes.DIFFERENCE); } update () { for (var i = 0; i < this.sprites.length; i++) { const sprite = this.sprites[i].s; sprite.y -= this.sprites[i].r; if (sprite.y < -256) { sprite.y = 700; } } } } const config = { type: Phaser.CANVAS, width: 800, height: 600, parent: 'phaser-example', scene: Example }; const game = new Phaser.Game(config);
Scan to open on your mobile device
// Difference is Canvas Blend Modes class Example extends Phaser.Scene { constructor () { super(); this.sprites = []; } preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.image('bg', 'assets/skies/space1.png'); this.load.image('particle', 'assets/particles/yellow.png'); this.load.image('logo', 'assets/sprites/phaser2.png'); } create () { this.add.image(400, 300, 'bg'); // Create the particles for (var i = 0; i < 300; i++) { const x = Phaser.Math.Between(-64, 800); const y = Phaser.Math.Between(-64, 600); const image = this.add.image(x, y, 'particle'); // Canvas and WebGL: // NORMAL // ADD // MULTIPLY // SCREEN // Canvas only: // OVERLAY // DARKEN // LIGHTEN // COLOR_DODGE // COLOR_BURN // HARD_LIGHT // SOFT_LIGHT // DIFFERENCE // EXCLUSION // HUE // SATURATION // COLOR // LUMINOSITY // image.setBlendMode(Phaser.BlendModes.OVERLAY); image.setBlendMode(Phaser.BlendModes.ADD); this.sprites.push({ s: image, r: 2 + Math.random() * 6 }); } this.add.image(400, 300, 'logo').setBlendMode(Phaser.BlendModes.DIFFERENCE); } update () { for (var i = 0; i < this.sprites.length; i++) { const sprite = this.sprites[i].s; sprite.y -= this.sprites[i].r; if (sprite.y < -256) { sprite.y = 700; } } } } const config = { type: Phaser.CANVAS, width: 800, height: 600, parent: 'phaser-example', scene: Example }; const game = new Phaser.Game(config);