Three.js利用性能插件stats實(shí)現(xiàn)性能監(jiān)聽的方法
前言
關(guān)于性能:測試一個(gè)程序,性能上是否有瓶頸,在3D世界里,經(jīng)常使用幀數(shù)的概念,首先我們來定義一下幀數(shù)的意義。
幀數(shù):圖形處理器每秒鐘能夠刷新幾次,通常用fps(Frames Per Second)來表示
關(guān)于性能:測試一個(gè)程序,性能上是否有瓶頸,在3D世界里,經(jīng)常使用幀數(shù)的概念,首先我們來定義一下幀數(shù)的意義。
幀數(shù):圖形處理器每秒鐘能夠刷新幾次,通常用fps(Frames Per Second)來表示
stats性能插件添加了以后,會(huì)默認(rèn)在左上角顯示性能幀數(shù),每次刷新所用時(shí)間,占用內(nèi)存。鼠標(biāo)左鍵點(diǎn)擊可進(jìn)行切換,默認(rèn)顯示每秒的幀數(shù)。
首先需要將stats插件引入,地址是官網(wǎng)下載文件里面的examples/js/libs/stats.min.js。
然后需要實(shí)例化一個(gè)組件,然后添加到dom當(dāng)中。
//初始化性能插件
var stats;
function initStats() {
stats = new Stats();
document.body.appendChild(stats.dom);
}
需要在requestAnimationFrame()函數(shù)調(diào)用里面更新stats。
function animate() {
//更新控制器
controls.update();
render();
//更新性能插件
stats.update();
requestAnimationFrame(animate);
}
就這樣,頁面當(dāng)中就會(huì)顯示出來正常插件效果了。
設(shè)置默認(rèn)顯示的監(jiān)聽。
Stats.prototype.setMode()方法可以設(shè)置插件的默認(rèn)監(jiān)聽
stats.setMode(0); //默認(rèn)的監(jiān)聽fps stats.setMode(1); //默認(rèn)的監(jiān)聽畫面渲染時(shí)間 stats.setMode(2); //默認(rèn)的監(jiān)聽當(dāng)前的不知道是啥
案例也是用的上一節(jié)的案例寫的,全部代碼:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style type="text/css">
html, body {
margin: 0;
height: 100%;
}
canvas {
display: block;
}
</style>
</head>
<body onload="draw();">
</body>
<script src="build/three.js"></script>
<script src="examples/js/controls/TrackballControls.js"></script>
<script src="examples/js/libs/stats.min.js"></script>
<script>
var renderer;
function initRender() {
renderer = new THREE.WebGLRenderer({antialias:true});
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);
}
var camera;
function initCamera() {
camera = new THREE.PerspectiveCamera(45, window.innerWidth/window.innerHeight, 1, 10000);
camera.position.set(0, 0, 400);
}
var scene;
function initScene() {
scene = new THREE.Scene();
}
var light;
function initLight() {
scene.add(new THREE.AmbientLight(0x404040));
light = new THREE.DirectionalLight(0xffffff);
light.position.set(1,1,1);
scene.add(light);
}
function initModel() {
var map = new THREE.TextureLoader().load("examples/textures/UV_Grid_Sm.jpg");
var material = new THREE.MeshLambertMaterial({map:map});
var cube = new THREE.Mesh(new THREE.BoxGeometry(100, 200, 100, 1, 1, 1), material);
scene.add(cube);
}
//初始化性能插件
var stats;
function initStats() {
stats = new Stats();
document.body.appendChild(stats.dom);
}
//用戶交互插件 鼠標(biāo)左鍵按住旋轉(zhuǎn),右鍵按住平移,滾輪縮放
var controls;
function initControls() {
controls = new THREE.TrackballControls( camera );
//旋轉(zhuǎn)速度
controls.rotateSpeed = 5;
//變焦速度
controls.zoomSpeed = 3;
//平移速度
controls.panSpeed = 0.8;
//是否不變焦
controls.noZoom = false;
//是否不平移
controls.noPan = false;
//是否開啟移動(dòng)慣性
controls.staticMoving = false;
//動(dòng)態(tài)阻尼系數(shù) 就是靈敏度
controls.dynamicDampingFactor = 0.3;
//未知,占時(shí)先保留
//controls.keys = [ 65, 83, 68 ];
controls.addEventListener( 'change', render );
}
function render() {
renderer.render( scene, camera );
}
//窗口變動(dòng)觸發(fā)的函數(shù)
function onWindowResize() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
controls.handleResize();
render();
renderer.setSize( window.innerWidth, window.innerHeight );
}
function animate() {
//更新控制器
controls.update();
render();
//更新性能插件
stats.update();
requestAnimationFrame(animate);
}
function draw() {
initRender();
initScene();
initCamera();
initLight();
initModel();
initControls();
initStats();
animate();
window.onresize = onWindowResize;
}
</script>
</html>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- Three.js基礎(chǔ)學(xué)習(xí)之場景對(duì)象
- Three.js實(shí)現(xiàn)瀏覽器變動(dòng)時(shí)進(jìn)行自適應(yīng)的方法
- Three.js利用dat.GUI如何簡化試驗(yàn)流程詳解
- 利用Three.js如何實(shí)現(xiàn)陰影效果實(shí)例代碼
- Three.js實(shí)現(xiàn)繪制字體模型示例代碼
- Three.js利用Detector.js插件如何實(shí)現(xiàn)兼容性檢測詳解
- Three.js利用orbit controls插件(軌道控制)控制模型交互動(dòng)作詳解
- Three.js如何用軌跡球插件(trackball)增加對(duì)模型的交互功能詳解
- Three.js入門之hello world以及如何繪制線
- Three.js如何實(shí)現(xiàn)霧化效果示例代碼
相關(guān)文章
對(duì)存在JavaScript隱式類型轉(zhuǎn)換的四種情況的總結(jié)(必看篇)
下面小編就為大家?guī)硪黄獙?duì)存在JavaScript隱式類型轉(zhuǎn)換的四種情況的總結(jié)(必看篇)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
用javascript對(duì)一個(gè)json數(shù)組深度賦值示例
本節(jié)主要介紹了用javascript對(duì)一個(gè)json數(shù)組深度賦值的具體實(shí)現(xiàn),需要的朋友可以參考下2014-07-07
JavaScript顯示當(dāng)前文檔最后修改日期的方法
這篇文章主要介紹了JavaScript顯示當(dāng)前文檔最后修改日期的方法,實(shí)例分析了javascript中document.lastModified的使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
JavaScript利用切片實(shí)現(xiàn)大文件斷點(diǎn)續(xù)傳
斷點(diǎn)續(xù)傳即在文件上傳期間因?yàn)橐恍┰蚨鴮?dǎo)致上傳終止時(shí),下次再次上傳同一個(gè)文件就從上一次上傳到一半的地方繼續(xù)上傳,以節(jié)省上傳時(shí)間。本文將利用切片實(shí)現(xiàn)大文件斷點(diǎn)續(xù)傳功能,快來跟隨小編一起學(xué)一學(xué)吧2022-03-03
JS實(shí)現(xiàn)六邊形3D拖拽翻轉(zhuǎn)效果的方法
這篇文章給大家分享一個(gè)利用javascript實(shí)現(xiàn)3D六邊形拖拽翻轉(zhuǎn)的效果實(shí)例,實(shí)現(xiàn)后的效果很贊,對(duì)大家的學(xué)習(xí)Javascript具有一定的參考借鑒價(jià)值,有需要的朋友們一起去來看看吧。2016-09-09

