Search
 
SCRIPT & CODE EXAMPLE
 

JAVASCRIPT

phaser reverse animation

 preload ()
    {
        this.load.spritesheet('mummy', 'assets/animations/mummy37x45.png', { frameWidth: 37, frameHeight: 45 });
    }

    create ()
    {
        //  Frame debug view
        this.frameView = this.add.graphics({ fillStyle: { color: 0xff00ff }, x: 32, y: 32 });

        //  Show the whole animation sheet
        this.add.image(32, 32, 'mummy', '__BASE').setOrigin(0);

        const config = {
            key: 'walk',
            frames: this.anims.generateFrameNumbers('mummy'),
            frameRate: 6,
            yoyo: false,
            repeat: -1
        };

        this.anim = this.anims.create(config);

        this.sprite = this.add.sprite(400, 250, 'mummy').setScale(4);

        //  Debug text
        this.progress = this.add.text(100, 420, 'Progress: 0%', { color: '#00ff00' });

        this.input.keyboard.on('keydown-SPACE', function (event) {
            this.sprite.play('walk');
        }, this);

        this.input.keyboard.on('keydown-Y', function (event) {
            this.sprite.anims.yoyo = !this.sprite.anims.yoyo;
        }, this);

        this.input.keyboard.on('keydown-Q', function (event) {
            this.sprite.playReverse('walk');
        }, this);

        this.input.keyboard.on('keydown-R', function (event) {
            this.sprite.anims.reverse();
        }, this);

        this.input.keyboard.on('keydown-P', function (event) {

            if (this.sprite.anims.isPaused)
            {
                this.sprite.anims.resume();
            }
            else
            {
                this.sprite.anims.pause();
            }
        }, this);
    }

    update ()
    {
        this.updateFrameView();

        const debug = [
            'SPACE to play the animation, Q to play reverse,',
            'R to revert at any time, P to pause/resume,',
            'Y to toggle yoyo',
            '',
            'Yoyo: ' + this.sprite.anims.yoyo,
            'Reverse: ' + this.sprite.anims.inReverse,
            'Progress: ' + this.sprite.anims.getProgress() * 100 + '%',
            'Accumulator: ' + this.sprite.anims.accumulator,
            'NextTick: ' + this.sprite.anims.nextTick
        ];

        this.progress.setText(debug);
    }

    updateFrameView ()
    {
        if (this.sprite.anims.isPlaying)
        {
            this.frameView.clear();
            this.frameView.fillRect(this.sprite.frame.cutX, 0, 37, 45);
        }
    }
Comment

PREVIOUS NEXT
Code Example
Javascript :: phaser stagger play 1 
Javascript :: Counting Duplicates 
Javascript :: append input using js 
Javascript :: Horizontal scroll to anchor 
Javascript :: swr vs axios 
Javascript :: permissions in chrome extension javascript 
Javascript :: npm deploy next js with tailwind 
Javascript :: Datatable js Search Server side after time or word length 
Javascript :: get random item in array 
Javascript :: how to change name on tab when user goes to another tab 
Javascript :: rxact 6 number long in yup validation 
Javascript :: change on id 
Javascript :: Self Invoking Functions Can Also be Used To Make Variables Global In JavaScript 
Javascript :: what is computed property in vue js 
Javascript :: delete parent js 
Javascript :: mongoose schema example 
Javascript :: add google map in react js 
Javascript :: google places API details JS 
Javascript :: vue sidebar 
Javascript :: ternary operator in javascript 
Javascript :: How to acces props of a functional component 
Javascript :: is javascript an object oriented language 
Javascript :: type conversion in javascript 
Javascript :: for loop in react native 
Javascript :: javascript eliminar saltos de linea textarea 
Javascript :: call c# function from javascript 
Javascript :: for in in javascript 
Javascript :: how to get length in js without using .length method 
Javascript :: close browser tab using jquery 
Javascript :: javascript array methods cheat sheet 
ADD CONTENT
Topic
Content
Source link
Name
6+8 =