gpt4 book ai didi

javascript - WebGL:优化每帧更改值和顶点计数的顶点缓冲区

转载 作者:数据小太阳 更新时间:2023-10-29 05:30:01 28 4
gpt4 key购买 nike

我想实现一个带有顶点缓冲区的渲染器,每帧都会在应用程序端更新。此外,顶点的数量(即三 Angular 形的数量)也会在每一帧发生变化。

我的方法是将所需的最大值预先分配为 Float32Array,然后仅更新更改的值,并使用 bufferSubData 更新缓冲区数据。然后通过从索引缓冲区发送一个范围来绘制我想要的。

作为一个最小的例子,假设我已经为 Float32Array 中的 2 个单独的三 Angular 形分配了位置顶点,对于这个帧,我只想移动并绘制第二个三 Angular 形。我想我会这样做:

arrPos[9] += 1.0; // move the X coordinates in the Float32Array
arrPos[12] += 1.0;
arrPos[15] += 1.0;
gl.bindBuffer(gl.ARRAY_BUFFER, bufPos); // tell GL which buffer to use
gl.bufferSubData( gl.ARRAY_BUFFER, 3 * 3 * 4, arrPos ); // update the vertices - ERROR

// then just draw the 2nd traingle by sending its indices only
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, bufId); // tell GL which buffer to use
gl.drawElements(gl.TRIANGLES, 3, gl.UNSIGNED_SHORT, 3 * 2); // draw just this range

问题是,bufferSubData 抛出错误:“GL ERROR :GL_INVALID_VALUE : glBufferSubData: out of range”

我试过使用偏移量 3、9、12 为 bufferSubData 只是为了它,但它们都给我同样的错误。

另一个注意事项:如果我能让这个工作,在我看来,如果我想在重新使用这个预分配的 Float32Array 的同时每帧绘制可变数量的三 Angular 形,我将需要更新值在数组的末尾,而不是开始,因为我只能指定 bufferSubData 的偏移量,而不是起始索引。我希望有人能告诉我这种方法是否可行,或者我是否完全偏离了轨道并且应该停止浪费我的时间。

最佳答案

好吧,我想我刚刚意识到问题所在。我认为您不能将 Float32Array 的范围指定到 bufferSubData;相反,它必须采用整个数组。 (可以使用小于缓冲区的 Float32Array 来更新缓冲区的范围。)

换句话说,我认为每次要更新的顶点数发生变化时都必须创建一个新的 Float32Array。这对我来说似乎很低效,但我想这就是它的方式。 IMO 应该在 OpenGL 文档中更好地解释这种区别。

david van brink 建议使用 ArrayBufferView 创建 Float32Array 的子数组,从我的初步测试来看它似乎有效。我以前的代码可以简单地通过以下方式修复:

arrPos[9] += 1.0; // move the X coordinates in the Float32Array
arrPos[12] += 1.0;
arrPos[15] += 1.0;
var arrView = arrPos.subarray(9); // specify a range of the Float32Array
gl.bindBuffer(gl.ARRAY_BUFFER, bufPos); // tell GL which buffer to use
gl.bufferSubData( gl.ARRAY_BUFFER, 3 * 3 * 4, arrView ); // update the vertices

// then just draw the 2nd traingle by sending its indices only
gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, bufId); // tell GL which buffer to use
gl.drawElements(gl.TRIANGLES, 3, gl.UNSIGNED_SHORT, 3 * 2); // draw just this range

关于javascript - WebGL:优化每帧更改值和顶点计数的顶点缓冲区,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19892022/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com