微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Three.js 改变顶点位置的最佳方式是什么?

如何解决Three.js 改变顶点位置的最佳方式是什么?

我是 Three.js 的新手,我最终得到了 2 种移动平面顶点的方法。我想知道在性能方面或仅在最佳实践方面我应该使用这两种方法中的哪一种。

在第一个函数中,我使用 vertexShader 更新顶点位置,第二个函数使用 THREE.mesh 的 bufferGeometry 位置属性更新顶点位置。

演示:https://olivierlarose.github.io/Threejs-Wave-Animation/

代码https://github.com/olivierlarose/Threejs-Wave-Animation

  1. 使用顶点着色器:
void main() {
  vUv = uv;
  float calc = height * sin(position.x * 10.0 + time);   
  vec3 newPosition = position;
  newPosition.z = newPosition.z + calc; 
                    
  gl_Position = projectionMatrix * modelViewMatrix * vec4( newPosition,1.0 );
}

  1. 使用 bufferGeometry 属性位置:
animate(){
    const time = this.clock.getelapsedtime() * 3;
    const position = this.cube.geometry.attributes.position;

    for(let i = 0 ; i < position.count ; i++){
        const calc = this.height * Math.sin(position.getX(i) * 10 + time);     
        position.setZ(i,calc);
        position.needsUpdate = true; 
    }

    requestAnimationFrame(this.animate.bind(this));
    this.renderer.render(this.scene,this.camera);
}

谢谢

解决方法

如果您在 JavaScript 中重新计算位置,则需要在每个新帧上将这些新位置上传到 GPU,这会随着顶点数的增加而产生很大的瓶颈。此外,您需要对每个顶点执行一次 Math.sin(),当您有成千上万个顶点时,这可能会在单个线程中变得昂贵。

就性能而言,最好的方法是更新顶点着色器中的位置。这是因为您的几何图形的 position 属性只会上传到 GPU 一次。此外,您还可以通过并行计算 sin() 获得性能提升,与 CPU 相比,这在 GPU 中速度非常快。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。