stats.js随时查看fps

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
	<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
	<title>Document</title>
	<script type="text/javascript" src="./libs/stats.js"></script>
</head>
<body>
	<div id="Stats-output">
	</div>
	<script type="text/javascript">
		var stats = initStats();
		function initStats() {
	            var stats = new Stats();
	            stats.setMode(0); // 0: fps, 1: ms
	            // Align top-left
	            stats.domElement.style.position = ‘absolute‘;
	            stats.domElement.style.left = ‘0px‘;
	            stats.domElement.style.top = ‘0px‘;

	            document.getElementById("Stats-output").appendChild(stats.domElement);

	            return stats;
	        }
	        setInterval(function(){
	        	stats.update();
	        },500);
	</script>
</body>
</html>

 源码:

/**
 * @author mrdoob / http://mrdoob.com/
 */

var Stats = function () {

    var startTime = Date.now(), prevTime = startTime;
    var ms = 0, msMin = Infinity, msMax = 0;
    var fps = 0, fpsMin = Infinity, fpsMax = 0;
    var frames = 0, mode = 0;

    var container = document.createElement( ‘div‘ );
    container.id = ‘stats‘;
    container.addEventListener( ‘mousedown‘, function ( event ) { event.preventDefault(); setMode( ++ mode % 2 ) }, false );
    container.style.cssText = ‘width:80px;opacity:0.9;cursor:pointer‘;

    var fpsDiv = document.createElement( ‘div‘ );
    fpsDiv.id = ‘fps‘;
    fpsDiv.style.cssText = ‘padding:0 0 3px 3px;text-align:left;background-color:#002‘;
    container.appendChild( fpsDiv );

    var fpsText = document.createElement( ‘div‘ );
    fpsText.id = ‘fpsText‘;
    fpsText.style.cssText = ‘color:#0ff;font-family:Helvetica,Arial,sans-serif;font-size:9px;font-weight:bold;line-height:15px‘;
    fpsText.innerHTML = ‘FPS‘;
    fpsDiv.appendChild( fpsText );

    var fpsGraph = document.createElement( ‘div‘ );
    fpsGraph.id = ‘fpsGraph‘;
    fpsGraph.style.cssText = ‘position:relative;width:74px;height:30px;background-color:#0ff‘;
    fpsDiv.appendChild( fpsGraph );

    while ( fpsGraph.children.length < 74 ) {

        var bar = document.createElement( ‘span‘ );
        bar.style.cssText = ‘width:1px;height:30px;float:left;background-color:#113‘;
        fpsGraph.appendChild( bar );

    }

    var msDiv = document.createElement( ‘div‘ );
    msDiv.id = ‘ms‘;
    msDiv.style.cssText = ‘padding:0 0 3px 3px;text-align:left;background-color:#020;display:none‘;
    container.appendChild( msDiv );

    var msText = document.createElement( ‘div‘ );
    msText.id = ‘msText‘;
    msText.style.cssText = ‘color:#0f0;font-family:Helvetica,Arial,sans-serif;font-size:9px;font-weight:bold;line-height:15px‘;
    msText.innerHTML = ‘MS‘;
    msDiv.appendChild( msText );

    var msGraph = document.createElement( ‘div‘ );
    msGraph.id = ‘msGraph‘;
    msGraph.style.cssText = ‘position:relative;width:74px;height:30px;background-color:#0f0‘;
    msDiv.appendChild( msGraph );

    while ( msGraph.children.length < 74 ) {

        var bar = document.createElement( ‘span‘ );
        bar.style.cssText = ‘width:1px;height:30px;float:left;background-color:#131‘;
        msGraph.appendChild( bar );

    }

    var setMode = function ( value ) {

        mode = value;

        switch ( mode ) {

            case 0:
                fpsDiv.style.display = ‘block‘;
                msDiv.style.display = ‘none‘;
                break;
            case 1:
                fpsDiv.style.display = ‘none‘;
                msDiv.style.display = ‘block‘;
                break;
        }

    }

    var updateGraph = function ( dom, value ) {

        var child = dom.appendChild( dom.firstChild );
        child.style.height = value + ‘px‘;

    }

    return {

        REVISION: 11,

        domElement: container,

        setMode: setMode,

        begin: function () {

            startTime = Date.now();

        },

        end: function () {

            var time = Date.now();

            ms = time - startTime;
            msMin = Math.min( msMin, ms );
            msMax = Math.max( msMax, ms );

            msText.textContent = ms + ‘ MS (‘ + msMin + ‘-‘ + msMax + ‘)‘;
            updateGraph( msGraph, Math.min( 30, 30 - ( ms / 200 ) * 30 ) );

            frames ++;

            if ( time > prevTime + 1000 ) {

                fps = Math.round( ( frames * 1000 ) / ( time - prevTime ) );
                fpsMin = Math.min( fpsMin, fps );
                fpsMax = Math.max( fpsMax, fps );

                fpsText.textContent = fps + ‘ FPS (‘ + fpsMin + ‘-‘ + fpsMax + ‘)‘;
                updateGraph( fpsGraph, Math.min( 30, 30 - ( fps / 100 ) * 30 ) );

                prevTime = time;
                frames = 0;

            }

            return time;

        },

        update: function () {

            startTime = this.end();

        }

    }

};

时间: 2024-10-25 17:37:23

stats.js随时查看fps的相关文章

JS:指定FPS帧频,requestAnimationFrame播放动画

Flash制作动画,最基础的概念就是帧,但在Flash中,帧频的控制比较简单,只需要编译前指定一下目标帧频就可以了. 实际运行时,不需要我们关心定时器的问题,flash player会定时触发EnterFrame消息,推动Movieclip播放. 在js这一侧,需要我们设定一个定时器,并推动相应的绘制逻辑执行. 最简单: var FPS = 60; setInterval(draw, 1000/FPS); 这个简单做法,如果draw带有大量逻辑计算,导致计算时间超过帧等待时间时,将会出现丢帧.除

dat.gui stats.js 通用参数配置及图像统计工具

在网上看到了一个非常好的JS烟雾效果 https://paveldogreat.github.io/WebGL-Fluid-Simulation/看源码时发现了dat.gui很好用. dat.gui 快速参数配置生成源码地址:https://github.com/dataarts/dat.gui stats.js 图形化统计性能及计数源码地址:https://github.com/mrdoob/stats.js 效果如下: 代码如下: <!DOCTYPE html> <html lang

使用PDF.JS在线查看PDF

过程简单粗暴. 第一步:下载源码https://github.com/mozilla/pdf.js 第二步:将源码拷贝进项目中,可以新建一个PDFShow文件夹存放代码 第三步:修改viewer.js var DEFAULT_URL = 'compressed.tracemonkey-pldi-09.pdf'  里面是PDF的路径 修改为:var DEFAULT_URL = ''; 发布IIS后访问localhost:8080/PDFShow/web/viewer.html?file=09.pd

hlConsole – 手机网页JS日志查看工具

前端的同学都知道,在开发PC页面的时候,经常用到F12的Console,来查看日志.调试.定位问题.但是在手机环境下,看不到Console,最笨的方法就是用alert代替,但是调试起来十分的不方便. hlConsole,是一款网页版的Console,可以方便的看到手机网页里,js输出的各种日志.而且使用非常简单,只需要引用一个JS即可.第一步:用PC浏览器打开http://console.hongliang.org/.如图: 第二步:登录(如果不想注册,可以使用Guest用户).如图: 第三步:

JS图片查看器

<html> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>JS网页图片查看器-可控制图片放大缩小还原移动效果</title> <META HTTP-EQUIV="imagetoolbar" CONTENT="no"> <style type="t

js图片查看器 - 灵感来自于picasa

本功能是为了解决运营对后台管理系统中用户上传的各种角度和尺寸的图片难以浏览的问题,于是花了两天时间写了这个插件,给大家分享. 兼容现代浏览器,不兼容ie678,主要是一些效果无法实现. 带有图片查看器的常用功能,UI设计和交互灵感来源于google的picasa. 为了保证整体的清洁,界面没有使用任何图标,有需要的可以自行修改css. 不知道什么原因插不了iframe,DEMO. 效果图: 代码如下: js /** * 照片浏览 * -- * @author Lianer * @version

离线同步 — 没网也可以随时查看笔记

你可以利用为知笔记随时随地记录和查看有价值的信息,所有数据在电脑.手机.平板.网页可通过同步保持一致. 有用信息同步到云端,安全又省事 你是不是偶尔会遇到下面一些情况: 手机意外重启,写了好久的内容还没来得及保存? 手机丢失,各种照片和信息没有备份,无法找回? 更换手机或电脑,各种信息还需要来来回回 copy 才能继续使用? 无需费劲的备份或拷贝,利用为知笔记,数据都保存到云端,再也不用担心数据丢失. 离线同步,无网也可以顺畅阅读 等地铁公交,排队买东西时常常会有很多零碎时间,有时想利用这些时间

JS jQuery查看系统中安装的字体

1.下载插件:FontDetect插件  地址:http://www.lalit.org/lab/javascript-css-font-detect/ 或者复制以下代码到fontdetect.js: var Detector = function() {    // a font will be compared against all the three default fonts.    // and if it doesn't match all 3 then that font is

java 使用 pdf.js 在线查看 pdf 文档

1. 下载对应的 pdf.js 文件: 推荐地址:             https://github.com/mozilla/pdf.js/            http://mozilla.github.io/pdf.js/ 2. 下载完成后打开对应的 viewer.js 文件. 可以看到,默认打开的是 compressed.tracemonkey-pldi-09.pd f文件,如果后面我们需要打开我们指定的地址,于是清空默认地址. 3. 这样,我们就可以使用传递 file 形参来动态指