首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Canvas requestAnimationFrame暂停

Canvas requestAnimationFrame暂停
EN

Stack Overflow用户
提问于 2013-05-15 06:49:10
回答 1查看 11.2K关注 0票数 13

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

代码:

代码语言:javascript
复制
window.requestAnimFrame = (function() {
    return  window.requestAnimationFrame       ||
            window.webkitRequestAnimationFrame ||
            window.mozRequestAnimationFrame    ||
            function(callback) {
                window.setTimeout(callback, 1000 / 60);
            };
})();

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

Start();

现在我想在keydown之后添加pause选项。有什么简单的方法可以做到吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-05-15 08:42:28

您可以创建一个变量来存储动画的状态:已暂停或未暂停。每次单击按钮时都会更改该状态。像这样的东西应该是有效的:

代码语言:javascript
复制
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();
票数 13
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16554094

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档