Layer With Geometry Mask

Hot
class Example extends Phaser.Scene
{
    constructor ()
    {
        super();
    }

    preload ()
    {
        this.load.setBaseURL('https://cdn.phaserfiles.com/v355');
        this.load.image('elephant', 'assets/sprites/elephant.png');
    }

    create ()
    {
        const elephantLayer = this.add.layer();

        const graphics = this.make.graphics();

        graphics.fillStyle(0xffffff);
        graphics.fillCircle(400, 300, 300);

        const mask = graphics.createGeometryMask();

        elephantLayer.setMask(mask);

        for (let i = 0; i < 32; i++)
        {
            let x = Phaser.Math.Between(600, 800);
            let y = Phaser.Math.Between(0, 600);

            let sprite = elephantLayer.add(this.make.sprite({ x, y, key: 'elephant' }));

            let dx = x - 600;

            this.tweens.add({
                targets: sprite,
                x: dx,
                ease: 'Sine.inOut',
                duration: 4000,
                delay: (i * 250),
                yoyo: true,
                repeat: -1
            });
        }
    }
}

const config = {
    type: Phaser.AUTO,
    width: 800,
    height: 600,
    backgroundColor: '#2d2d2d',
    parent: 'phaser-example',
    scene: Example
};

const game = new Phaser.Game(config);