Limiting framerate in Three.js to increase performance, requestAnimationFrame?

后端 未结 5 2020
终归单人心
终归单人心 2020-12-24 03:26

I was thinking that for some projects I do 60fps is not totally needed. I figured I could have more objects and things that ran at 30fps if I could get it to run smoothly at

相关标签:
5条回答
  • 2020-12-24 03:41

    This approach could also work, using the THREE.Clock to measure the delta.

    let clock = new THREE.Clock();
    let delta = 0;
    // 30 fps
    let interval = 1 / 30;
    
    function update() {
      requestAnimationFrame(update);
      delta += clock.getDelta();
    
       if (delta  > interval) {
           // The draw or time dependent code are here
           render();
    
           delta = delta % interval;
       }
    }
    
    0 讨论(0)
  • 2020-12-24 03:44

    What about something like this:

    function animate() {
    
        setTimeout( function() {
    
            requestAnimationFrame( animate );
    
        }, 1000 / 30 );
    
        renderer.render();
    
    }
    
    0 讨论(0)
  • 2020-12-24 03:51

    I came across this article which gives two ways of solving the custom frame rate issue.

    http://codetheory.in/controlling-the-frame-rate-with-requestanimationframe/

    I think this way is more robust, as it will have a steady animation speed even on computers that do not render the canvas consistently at 60 fps. Below is an example

    var now,delta,then = Date.now();
    var interval = 1000/30;
    
    function animate() {
        requestAnimationFrame (animate);
        now = Date.now();
        delta = now - then;
        //update time dependent animations here at 30 fps
        if (delta > interval) {
            sphereMesh.quaternion.multiplyQuaternions(autoRotationQuaternion, sphereMesh.quaternion);
            then = now - (delta % interval);
        }
        render();
    }
    
    0 讨论(0)
  • 2020-12-24 03:51

    The accepted answer has a problem and gives up to -10fps on slow computers compared to not limiting the fps, so for example without limiting 36pfs, with the accepted solution 26fps (for a 60fps, 1000/60 setTimeout).

    Instead you can do this:

    var dt=1000/60;
    var timeTarget=0;
    function render(){
      if(Date.now()>=timeTarget){
    
        gameLogic();
        renderer.render();
    
        timeTarget+=dt;
        if(Date.now()>=timeTarget){
          timeTarget=Date.now();
        }
      }
      requestAnimationFrame(render);
    }
    

    That way is not going to wait if its already behind.

    0 讨论(0)
  • 2020-12-24 04:02

    The amount of work your CPU and GPU needs to do depend on the workload and they set the upper limit of smooth framerate.

    • GPU works mostly linearly and can always push out the same count of polygons to screen.

    • However, if you have doubled the number of objects CPU must work harder to animate these all objects (matrix transformationsn and such). It depends on your world model and other work Javascript does how much extra overhead is given. Also the conditions like the number of visible objects is important.

    For simple models where all polygons are on the screen always then it should pretty much follow the rule "half the framerate, double the objects". For 3D shooter like scenes this is definitely not the case.

    0 讨论(0)
提交回复
热议问题