stats.js 显示 FPS 0~2,渲染动作太慢
stats.js shows FPS 0~2, render movement too slow
我是 three.js 的初学者,也将其用于 BIM 项目,
当我加载 ~25mb 的 gltf 文件时,我几乎无法移动整个对象并且 stats.js 监视器显示 fps 为 0~2最大限度
gltf 文件:https://github.com/xeolabs/xeogl/tree/master/examples/models/gltf/schependomlaan
我正在使用 三个 js 和 vuejs
//package.json
"stats.js": "^0.17.0",
"three": "^0.109.0",
import * as THREE from 'three';
import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader.js';
import { DRACOLoader } from 'three/examples/jsm/loaders/DRACOLoader.js';
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js';
this.scene = new THREE.Scene();
this.stats = new Stats();
this.stats.showPanel( 0, 1, 2 ); // 0: fps, 1: ms, 2: mb, 3+: custom
let div = document.createElement('div')
div.appendChild(this.stats.dom)
div.style.position = 'absolute';
div.style.top = 0;
div.style.left = 0;
document.getElementsByClassName('gltfViewer')[0].appendChild( div );
// Camera
this.camera = new THREE.PerspectiveCamera( 45, window.innerWidth / window.innerHeight, 1, 1500 );
this.camera.position.set( this.pos, this.pos, this.pos );
// renderer
this.raycaster = new THREE.Raycaster();
this.renderer = new THREE.WebGLRenderer({ canvas: document.getElementById('gltfViewerCanvas'), alpha: false });
this.renderer.setClearColor( 0xefefef );
this.renderer.setPixelRatio( window.devicePixelRatio );
this.renderer.setSize(window.innerWidth, window.innerHeight);
// adding controls
this.controls = new OrbitControls( this.camera, this.renderer.domElement );
this.controls.dampingFactor = 0.1;
this.controls.rotateSpeed = 0.12;
this.controls.enableDamping = true;
this.controls.update();
window.addEventListener('resize', _ => this.render());
this.controls.addEventListener('change', _ => this.render());
// light
var ambientLight = new THREE.AmbientLight( 0xcccccc );
this.scene.add( ambientLight );
var directionalLight = new THREE.DirectionalLight( 0xffffff );
directionalLight.position.set( 0, 1, 1 ).normalize();
this.scene.add( directionalLight );
// loading gltf file
// Instantiate a loader
this.gltfLoader = new GLTFLoader();
// Optional: Provide a DRACOLoader instance to decode compressed mesh data
this.dracoLoader = new DRACOLoader();
this.dracoLoader.setDecoderPath( 'three/examples/js/libs/draco' );
this.gltfLoader.setDRACOLoader( this.dracoLoader );
// Load a glTF resource
this.gltfLoader.load( this.src, this.onGLTFLoaded, this.onGLTFLoading, this.onGLTFLoadingError );
//onGLTFLoaded()
this.scene.add( optimizedGltf.scene );
// gltf.scene.getObjectById(404).visible = false;
this.listGltfObjects(gltf);
this.render();
// render ()
this.renderer.render( this.scene, this.camera );
this.stats.update();
// on mounted component :
animate()
// animate()
this.stats.begin()
this.render();
this.stats.end();
即使在使用 https://github.com/AnalyticalGraphicsInc/gltf-pipeline 应用 Draco 压缩后也没有任何变化。
谢谢
关于文件大小 —
Draco 压缩会减少网络大小,但不会减少必须发送到 GPU 并呈现的未压缩数据的最终数量。如果你的原始网格是 100mb,你将它压缩到 25mb,你仍然会得到原始 100mb 网格的帧率。旁白:使用 glTF-Pipeline 的 -b 选项会将大小再减少 50%,达到 13MB,但同样不会影响 FPS。
帧率 —
此模型包含 4280 个网格1,每个网格都需要一个 GPU 绘制调用。这是您低 QPS 的根源,不幸的是,这是 BIM 模型中的常见问题。您需要合并这些网格(在像 Blender 这样的程序中,或在 three.js 中加载后)尽可能少。像这样的模型应该需要 < 100 次绘制调用,甚至只有 1 次。
1 要查看此内容,请尝试在 https://gltf-viewer.donmccurdy.com/ 上打开模型并打开 JavaScript 控制台。您应该会看到场景图的打印输出,其中将包含许多不同的网格。
我是 three.js 的初学者,也将其用于 BIM 项目, 当我加载 ~25mb 的 gltf 文件时,我几乎无法移动整个对象并且 stats.js 监视器显示 fps 为 0~2最大限度 gltf 文件:https://github.com/xeolabs/xeogl/tree/master/examples/models/gltf/schependomlaan 我正在使用 三个 js 和 vuejs
//package.json
"stats.js": "^0.17.0",
"three": "^0.109.0",
import * as THREE from 'three';
import { GLTFLoader } from 'three/examples/jsm/loaders/GLTFLoader.js';
import { DRACOLoader } from 'three/examples/jsm/loaders/DRACOLoader.js';
import { OrbitControls } from 'three/examples/jsm/controls/OrbitControls.js';
this.scene = new THREE.Scene();
this.stats = new Stats();
this.stats.showPanel( 0, 1, 2 ); // 0: fps, 1: ms, 2: mb, 3+: custom
let div = document.createElement('div')
div.appendChild(this.stats.dom)
div.style.position = 'absolute';
div.style.top = 0;
div.style.left = 0;
document.getElementsByClassName('gltfViewer')[0].appendChild( div );
// Camera
this.camera = new THREE.PerspectiveCamera( 45, window.innerWidth / window.innerHeight, 1, 1500 );
this.camera.position.set( this.pos, this.pos, this.pos );
// renderer
this.raycaster = new THREE.Raycaster();
this.renderer = new THREE.WebGLRenderer({ canvas: document.getElementById('gltfViewerCanvas'), alpha: false });
this.renderer.setClearColor( 0xefefef );
this.renderer.setPixelRatio( window.devicePixelRatio );
this.renderer.setSize(window.innerWidth, window.innerHeight);
// adding controls
this.controls = new OrbitControls( this.camera, this.renderer.domElement );
this.controls.dampingFactor = 0.1;
this.controls.rotateSpeed = 0.12;
this.controls.enableDamping = true;
this.controls.update();
window.addEventListener('resize', _ => this.render());
this.controls.addEventListener('change', _ => this.render());
// light
var ambientLight = new THREE.AmbientLight( 0xcccccc );
this.scene.add( ambientLight );
var directionalLight = new THREE.DirectionalLight( 0xffffff );
directionalLight.position.set( 0, 1, 1 ).normalize();
this.scene.add( directionalLight );
// loading gltf file
// Instantiate a loader
this.gltfLoader = new GLTFLoader();
// Optional: Provide a DRACOLoader instance to decode compressed mesh data
this.dracoLoader = new DRACOLoader();
this.dracoLoader.setDecoderPath( 'three/examples/js/libs/draco' );
this.gltfLoader.setDRACOLoader( this.dracoLoader );
// Load a glTF resource
this.gltfLoader.load( this.src, this.onGLTFLoaded, this.onGLTFLoading, this.onGLTFLoadingError );
//onGLTFLoaded()
this.scene.add( optimizedGltf.scene );
// gltf.scene.getObjectById(404).visible = false;
this.listGltfObjects(gltf);
this.render();
// render ()
this.renderer.render( this.scene, this.camera );
this.stats.update();
// on mounted component :
animate()
// animate()
this.stats.begin()
this.render();
this.stats.end();
即使在使用 https://github.com/AnalyticalGraphicsInc/gltf-pipeline 应用 Draco 压缩后也没有任何变化。
谢谢
关于文件大小 —
Draco 压缩会减少网络大小,但不会减少必须发送到 GPU 并呈现的未压缩数据的最终数量。如果你的原始网格是 100mb,你将它压缩到 25mb,你仍然会得到原始 100mb 网格的帧率。旁白:使用 glTF-Pipeline 的 -b 选项会将大小再减少 50%,达到 13MB,但同样不会影响 FPS。
帧率 —
此模型包含 4280 个网格1,每个网格都需要一个 GPU 绘制调用。这是您低 QPS 的根源,不幸的是,这是 BIM 模型中的常见问题。您需要合并这些网格(在像 Blender 这样的程序中,或在 three.js 中加载后)尽可能少。像这样的模型应该需要 < 100 次绘制调用,甚至只有 1 次。
1 要查看此内容,请尝试在 https://gltf-viewer.donmccurdy.com/ 上打开模型并打开 JavaScript 控制台。您应该会看到场景图的打印输出,其中将包含许多不同的网格。