1. <legend id='01pko'><style id='01pko'><dir id='01pko'><q id='01pko'></q></dir></style></legend>

    <tfoot id='01pko'></tfoot>

  2. <i id='01pko'><tr id='01pko'><dt id='01pko'><q id='01pko'><span id='01pko'><b id='01pko'><form id='01pko'><ins id='01pko'></ins><ul id='01pko'></ul><sub id='01pko'></sub></form><legend id='01pko'></legend><bdo id='01pko'><pre id='01pko'><center id='01pko'></center></pre></bdo></b><th id='01pko'></th></span></q></dt></tr></i><div id='01pko'><tfoot id='01pko'></tfoot><dl id='01pko'><fieldset id='01pko'></fieldset></dl></div>

    <small id='01pko'></small><noframes id='01pko'>

    • <bdo id='01pko'></bdo><ul id='01pko'></ul>

      使用 requestAnimationFrame 在 Canvas 中计算 FPS

      Calculate FPS in Canvas using requestAnimationFrame(使用 requestAnimationFrame 在 Canvas 中计算 FPS)
          <bdo id='4sNpB'></bdo><ul id='4sNpB'></ul>
        • <legend id='4sNpB'><style id='4sNpB'><dir id='4sNpB'><q id='4sNpB'></q></dir></style></legend>
            <tbody id='4sNpB'></tbody>
          1. <i id='4sNpB'><tr id='4sNpB'><dt id='4sNpB'><q id='4sNpB'><span id='4sNpB'><b id='4sNpB'><form id='4sNpB'><ins id='4sNpB'></ins><ul id='4sNpB'></ul><sub id='4sNpB'></sub></form><legend id='4sNpB'></legend><bdo id='4sNpB'><pre id='4sNpB'><center id='4sNpB'></center></pre></bdo></b><th id='4sNpB'></th></span></q></dt></tr></i><div id='4sNpB'><tfoot id='4sNpB'></tfoot><dl id='4sNpB'><fieldset id='4sNpB'></fieldset></dl></div>
            <tfoot id='4sNpB'></tfoot>

              1. <small id='4sNpB'></small><noframes id='4sNpB'>

                本文介绍了使用 requestAnimationFrame 在 Canvas 中计算 FPS的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                问题描述

                如何计算画布游戏应用程序的 FPS?我看过一些例子,但没有一个使用 requestAnimationFrame,我不确定如何在那里应用他们的解决方案.这是我的代码:

                How could I calculate the FPS of a canvas game application? I've seen some examples, but none of them use requestAnimationFrame, and im not sure how to apply their solutions there. This is my code:

                (function(window, document, undefined){
                
                    var canvas       = document.getElementById("mycanvas"),
                        context      = canvas.getContext("2d"),
                        width        = canvas.width,
                        height       = canvas.height,
                        fps          = 0,
                        game_running = true,
                        show_fps     = true;
                
                    function showFPS(){
                        context.fillStyle = "Black";
                        context.font      = "normal 16pt Arial";
                
                        context.fillText(fps + " fps", 10, 26);
                    }
                    function gameLoop(){
                
                        //Clear screen
                        context.clearRect(0, 0, width, height);
                
                        if (show_fps) showFPS();
                
                        if (game_running) requestAnimationFrame(gameLoop);
                
                    }
                    
                    gameLoop();
                
                }(this, this.document))

                canvas{
                    border: 3px solid #fd3300;
                }

                <canvas id="mycanvas" width="300" height="150"></canvas>

                顺便问一下,我可以添加任何库来监控性能吗?

                By the way, is there any library I could add to surpervise performance?

                推荐答案

                不要使用 new Date()

                此 API 有几个缺陷,仅对获取当前日期 + 时间有用.不适用于测量时间跨度.

                Do not use new Date()

                This API has several flaws and is only useful for getting the current date + time. Not for measuring timespans.

                Date-API 使用操作系统的内部时钟,该时钟不断更新并与 NTP 时间服务器同步.这意味着,这个时钟的速度/频率有时比实际时间快,有时慢 - 因此不能用于测量持续时间和帧速率.

                The Date-API uses the operating system's internal clock, which is constantly updated and synchronized with NTP time servers. This means, that the speed / frequency of this clock is sometimes faster and sometimes slower than the actual time - and therefore not useable for measuring durations and framerates.

                如果有人更改系统时间(手动或由于 DST),如果单帧突然需要一个小时,您至少可以看到问题.或者是消极时期.但如果系统时钟与世界时间同步的速度快 20%,则几乎无法检测到.

                If someone changes the system time (either manually or due to DST), you could at least see the problem if a single frame suddenly needed an hour. Or a negative time. But if the system clock ticks 20% faster to synchronize with world-time, it is practically impossible to detect.

                此外,Date-API 非常不精确 - 通常远小于 1 毫秒.这使得它对于帧率测量尤其无用,其中一个 60Hz 帧需要约 17 毫秒.

                Also, the Date-API is very imprecise - often much less than 1ms. This makes it especially useless for framerate measurements, where one 60Hz frame needs ~17ms.

                Performance API 专为此类用例而设计,可等效于 new Date().只需选择其他答案之一并将 new Date() 替换为 performance.now(),就可以开始了.

                The Performance API has been specificly made for such use cases and can be used equivalently to new Date(). Just take one of the other answers and replace new Date() with performance.now(), and you are ready to go.

                来源:

                与 Date.now() 不同的是,Performance.now() 返回的值始终以恒定速率增加,与系统时钟无关(可以手动调整或通过 NTP 等软件进行调整).否则,performance.timing.navigationStart + performance.now() 将大约等于 Date.now().

                Also unlike Date.now(), the values returned by Performance.now() always increase at a constant rate, independent of the system clock (which might be adjusted manually or skewed by software like NTP). Otherwise, performance.timing.navigationStart + performance.now() will be approximately equal to Date.now().

                https://developer.mozilla.org/en-US/docs/Web/API/Performance/now

                对于窗户:

                [时间服务] 调整本地时钟频率以使其能够收敛到正确的时间.如果本地时钟与【准确时间样本】的时间差太大,无法通过调整本地时钟来校正时钟频率,时间服务将本地时钟设置为正确的时间.

                [The time service] adjusts the local clock rate to allow it to converge toward the correct time. If the time difference between the local clock and the [accurate time sample] is too large to correct by adjusting the local clock rate, the time service sets the local clock to the correct time.

                https://technet.microsoft.com/en-us/library/cc773013(v=ws.10).aspx

                这篇关于使用 requestAnimationFrame 在 Canvas 中计算 FPS的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                相关文档推荐

                How to make rooftext effect and valley text effect in HTML5 (or Fabric.js)(如何在 HTML5(或 Fabric.js)中制作屋顶文字效果和山谷文字效果)
                Draw border around nontransparent part of image on canvas(在画布上的图像不透明部分周围绘制边框)
                dragging and resizing an image on html5 canvas(在 html5 画布上拖动图像并调整其大小)
                What#39;s the difference between a boolean as primitive and a boolean as property of an object?(作为原始对象的布尔值和作为对象属性的布尔值有什么区别?)
                I want to do animation of an object along a particular path(我想沿特定路径对对象进行动画处理)
                How to upload image into HTML5 canvas(如何将图像上传到 HTML5 画布中)
                  <tbody id='YGB1A'></tbody>

                  <legend id='YGB1A'><style id='YGB1A'><dir id='YGB1A'><q id='YGB1A'></q></dir></style></legend>

                    • <bdo id='YGB1A'></bdo><ul id='YGB1A'></ul>

                      <tfoot id='YGB1A'></tfoot>
                      <i id='YGB1A'><tr id='YGB1A'><dt id='YGB1A'><q id='YGB1A'><span id='YGB1A'><b id='YGB1A'><form id='YGB1A'><ins id='YGB1A'></ins><ul id='YGB1A'></ul><sub id='YGB1A'></sub></form><legend id='YGB1A'></legend><bdo id='YGB1A'><pre id='YGB1A'><center id='YGB1A'></center></pre></bdo></b><th id='YGB1A'></th></span></q></dt></tr></i><div id='YGB1A'><tfoot id='YGB1A'></tfoot><dl id='YGB1A'><fieldset id='YGB1A'></fieldset></dl></div>
                        1. <small id='YGB1A'></small><noframes id='YGB1A'>