var config = { type: Phaser.WEBGL, parent: 'phaser-example', width: 800, height: 600, backgroundColor: '#cdcdcd', scene: { preload: preload, create: create, update: update, pack: { files: [ { type: 'scenePlugin', key: 'SpinePlugin', url: 'https://cdn.phaserfiles.com/v385/plugins/spine4.1/SpinePluginDebug.js', sceneKey: 'spine' } ] } } }; var controls; var game = new Phaser.Game(config); function preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.setPath('assets/spine/4.1/spineboy'); this.load.spine('boy', 'spineboy-pro.json', 'spineboy-pma.atlas', false); } function create () { // Phaser 3.50 // Using `this.add.spineContainer` = 43 GL commands (1 draw call, 1 clear) // Using `this.add.container` = 278 GL commands (4 draw calls, 4 clears) let base = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 100, 'boy', 'idle', true).setScale(0.25); base.add(obj) } let base2 = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 300, 'boy', 'walk', true).setScale(0.25); base2.add(obj) } let base3 = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 500, 'boy', 'run', true).setScale(0.25); base3.add(obj) } let base4 = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 700, 'boy', 'jump', true).setScale(0.25); base4.add(obj) } var cursors = this.input.keyboard.createCursorKeys(); var controlConfig = { camera: this.cameras.main, left: cursors.left, right: cursors.right, up: cursors.up, down: cursors.down, zoomIn: this.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.Q), zoomOut: this.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.E), acceleration: 0.35, drag: 0.01, maxSpeed: 1.2 }; controls = new Phaser.Cameras.Controls.SmoothedKeyControl(controlConfig); } function update (time, delta) { controls.update(delta); }
Scan to open on your mobile device
var config = { type: Phaser.WEBGL, parent: 'phaser-example', width: 800, height: 600, backgroundColor: '#cdcdcd', scene: { preload: preload, create: create, update: update, pack: { files: [ { type: 'scenePlugin', key: 'SpinePlugin', url: 'https://cdn.phaserfiles.com/v385/plugins/spine4.1/SpinePluginDebug.js', sceneKey: 'spine' } ] } } }; var controls; var game = new Phaser.Game(config); function preload () { this.load.setBaseURL('https://cdn.phaserfiles.com/v385'); this.load.setPath('assets/spine/4.1/spineboy'); this.load.spine('boy', 'spineboy-pro.json', 'spineboy-pma.atlas', false); } function create () { // Phaser 3.50 // Using `this.add.spineContainer` = 43 GL commands (1 draw call, 1 clear) // Using `this.add.container` = 278 GL commands (4 draw calls, 4 clears) let base = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 100, 'boy', 'idle', true).setScale(0.25); base.add(obj) } let base2 = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 300, 'boy', 'walk', true).setScale(0.25); base2.add(obj) } let base3 = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 500, 'boy', 'run', true).setScale(0.25); base3.add(obj) } let base4 = this.add.container(); for (var i = 0; i < 32; i++) { let obj = this.add.spine(i * 64, 700, 'boy', 'jump', true).setScale(0.25); base4.add(obj) } var cursors = this.input.keyboard.createCursorKeys(); var controlConfig = { camera: this.cameras.main, left: cursors.left, right: cursors.right, up: cursors.up, down: cursors.down, zoomIn: this.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.Q), zoomOut: this.input.keyboard.addKey(Phaser.Input.Keyboard.KeyCodes.E), acceleration: 0.35, drag: 0.01, maxSpeed: 1.2 }; controls = new Phaser.Cameras.Controls.SmoothedKeyControl(controlConfig); } function update (time, delta) { controls.update(delta); }