画布requestAnimationFrame暂停

Ama*_*may 12 javascript html5 canvas

如何暂停使用requestAnimationFrame制作的画布动画?我像这样开始动画:

码:

window.requestAnimFrame = (function() {
    return  window.requestAnimationFrame       ||
            window.webkitRequestAnimationFrame ||
            window.mozRequestAnimationFrame    ||
            function(callback) {
                window.setTimeout(callback, 1000 / 60);
            };
})();

function Start() {
    Update();
    requestAnimFrame(Start);
}

Start();
Run Code Online (Sandbox Code Playgroud)

现在我想在keydown之后添加pause选项.有没有简单的方法呢?

Iva*_*hub 12

你可以做的是创建一个存储动画状态的变量:paused或unaused.每次单击按钮时更改该状态.这样的事情应该有效:

var isPaused = false;

window.requestAnimFrame = (function() {
    return  window.requestAnimationFrame       ||
            window.webkitRequestAnimationFrame ||
            window.mozRequestAnimationFrame    ||
            function(callback) {
                window.setTimeout(callback, 1000 / 60);
            };
})();

function Start() {
    if (isPaused) {
        Update();
    }

    requestAnimFrame(Start);
}

window.onkeydown = function() {
    isPaused = !isPaused; // flips the pause state
};

Start();
Run Code Online (Sandbox Code Playgroud)