class Example extends Phaser.Scene { preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.image('crate', 'assets/sprites/crate.png'); this.load.image('crate32', 'assets/sprites/crate32.png'); } create () { this.matter.world.setBounds(); // Increase the solver steps from the default to aid with the stack this.matter.world.engine.positionIterations = 30; this.matter.world.engine.velocityIterations = 30; const stack = this.matter.add.imageStack('crate32', null, 300, 50, 5, 18, 30, 0, { _mass: 0.5 }); this.matter.add.mouseSpring(); } } const config = { type: Phaser.AUTO, width: 800, height: 600, backgroundColor: '#1d1d1d', parent: 'phaser-example', physics: { default: 'matter', matter: { gravity: { y: 0.05 }, debug: true } }, scene: Example }; const game = new Phaser.Game(config);
Scan to open on your mobile device
class Example extends Phaser.Scene { preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.image('crate', 'assets/sprites/crate.png'); this.load.image('crate32', 'assets/sprites/crate32.png'); } create () { this.matter.world.setBounds(); // Increase the solver steps from the default to aid with the stack this.matter.world.engine.positionIterations = 30; this.matter.world.engine.velocityIterations = 30; const stack = this.matter.add.imageStack('crate32', null, 300, 50, 5, 18, 30, 0, { _mass: 0.5 }); this.matter.add.mouseSpring(); } } const config = { type: Phaser.AUTO, width: 800, height: 600, backgroundColor: '#1d1d1d', parent: 'phaser-example', physics: { default: 'matter', matter: { gravity: { y: 0.05 }, debug: true } }, scene: Example }; const game = new Phaser.Game(config);