Container Batch Test

Hot
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/3.8.95/SpinePluginDebug.js', sceneKey: 'spine' }
            ]
        }
    }
};

var controls;

var game = new Phaser.Game(config);

function preload ()
{
        this.load.setBaseURL('https://cdn.phaserfiles.com/v355');
    this.load.setPath('assets/spine/3.8/spineboy');

    this.load.spine('boy', 'spineboy-ess.json', 'spineboy-ess.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.spineContainer();

    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.spineContainer();

    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.spineContainer();

    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.spineContainer();

    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);
}