javascript - 我如何在 webgl 中使用 stride?

标签 javascript memory 3d floating-point webgl

//Defining geometry
var vertices = [
    +0.0,+0.0,+0.0,
    +0.0,+0.0,+1.0,

    -0.5,+0.0,+0.0,
    +1.0,+0.0,+0.0, 

    -0.5,-0.5,+0.0,
    +0.0,+1.0,+0.0,

    +0.5,+0.5,+0.0,
    +1.0,+0.0,+1.0, 

    +0.5,+0.0,+0.0,
    +1.0,+1.0,+0.0, 

    -0.5,+0.5,+0.0
    +1.0,+0.0,+1.0
];



indices = [3,4,0,0,2,1,5,0,1];

var VextexBuffer = webgl.createBuffer();

webgl.bindBuffer(webgl.ARRAY_BUFFER, VextexBuffer);

webgl.bufferData(webgl.ARRAY_BUFFER, new Float32Array(vertices), webgl.STATIC_DRAW);

var coord = webgl.getAttribLocation(shaderProgram,"coordinates");

webgl.vertexAttribPointer(coord, 3, webgl.FLOAT, false ,6 * 4,0);

webgl.enableVertexAttribArray(coord);

var color = webgl.getAttribLocation(shaderProgram, "color");

webgl.vertexAttribPointer(color, 3, webgl.FLOAT, false ,6 * 4,3 * 4);

webgl.enableVertexAttribArray(color);       


var IndexBuffer = webgl.createBuffer();

webgl.bindBuffer(webgl.ELEMENT_ARRAY_BUFFER, IndexBuffer);

webgl.bufferData(webgl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), webgl.STATIC_DRAW);

我想在 VertexAttribPointer 方法中使用 stride 来为顶点和颜色数据使用单个 VBO,而不是使用 2 个 VBO,但问题是我不知道 javascript 中 float 的大小。所以我假设它是 4。

现在我收到这个错误:-

**[.CommandBufferContext]GL ERROR :GL_INVALID_OPERATION : glDrawElements:        
attempt to access out of range vertices in attribute 1**

我认为问题在于:-

webgl.vertexAttribPointer(coord, 3, webgl.FLOAT, false ,6 * 4,0);

和:-

webgl.vertexAttribPointer(color, 3, webgl.FLOAT, false ,6 * 4,3 * 4);

请问是哪里出了问题? 谢谢。

最佳答案

在 WebGL 中,FLOAT 的大小为 4。它与数字或 float JavaScript 无关。 JavaScript 中的 float /数字与 WebGL 缓冲区中的 float 是分开的。

您的绘图调用在哪里?从上面的代码中看不出哪里出了问题。一看就对了

在下面测试它我发现 1,问题。您在最后一个坐标和最后一个颜色之间缺少一个逗号,这意味着您的 vertices 数组是一个短值

var webgl = document.querySelector("#c").getContext("webgl");
var shaderProgram = twgl.createProgramFromScripts(webgl, ["vs", "fs"]);
webgl.useProgram(shaderProgram);

//Defining geometry
var vertices = [
    +0.0,+0.0,+0.0,
    +0.0,+0.0,+1.0,

    -0.5,+0.0,+0.0,
    +1.0,+0.0,+0.0, 

    -0.5,-0.5,+0.0,
    +0.0,+1.0,+0.0,

    +0.5,+0.5,+0.0,
    +1.0,+0.0,+1.0, 

    +0.5,+0.0,+0.0,
    +1.0,+1.0,+0.0, 

    -0.5,+0.5,+0.0,
    +1.0,+0.0,+1.0
];


indices = [3,4,0,0,2,1,5,0,1];

var VextexBuffer = webgl.createBuffer();

webgl.bindBuffer(webgl.ARRAY_BUFFER, VextexBuffer);

webgl.bufferData(webgl.ARRAY_BUFFER, new Float32Array(vertices), webgl.STATIC_DRAW);

var coord = webgl.getAttribLocation(shaderProgram,"coordinates");

webgl.vertexAttribPointer(coord, 3, webgl.FLOAT, false ,6 * 4,0);

webgl.enableVertexAttribArray(coord);

var color = webgl.getAttribLocation(shaderProgram, "color");

webgl.vertexAttribPointer(color, 3, webgl.FLOAT, false ,6 * 4,3 * 4);

webgl.enableVertexAttribArray(color);       


var IndexBuffer = webgl.createBuffer();

webgl.bindBuffer(webgl.ELEMENT_ARRAY_BUFFER, IndexBuffer);

webgl.bufferData(webgl.ELEMENT_ARRAY_BUFFER, new Uint16Array(indices), webgl.STATIC_DRAW);

webgl.drawElements(webgl.TRIANGLES, 6, webgl.UNSIGNED_SHORT, 0);
<script src="https://twgljs.org/dist/twgl.min.js"></script>
<script id="vs" type="notjs">
attribute vec4 coordinates;
attribute vec4 color;

varying vec4 v_color;

void main() {
  gl_Position = coordinates;
  v_color = color;
}
</script>
<script id="fs" type="notjs">
precision mediump float;
varying vec4 v_color;
void main() {
  gl_FragColor = v_color;
}
</script>
<canvas id="c"></canvas>

关于javascript - 我如何在 webgl 中使用 stride?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36860325/

相关文章:

objective-c - SceneKit 检测给定区域的触摸

javascript - 单击 iframe 内容页面中的显示隐藏按钮时,iframe 高度不会自动增加

javascript - 错误 [ERR_STREAM_WRITE_AFTER_END] : write after end

javascript - 如何设置点以下的所有值(像数组一样的 TileMap)

python - 在 python 中使用组合来处理非常大的序列

r - ggplot map 的奇怪内存问题

Java3D画空白窗(不在小程序中)

math - 投影 3D 网格的 2D 轮廓算法

javascript - Jquery Mobile : getting error with mobile. 页面加载()

android - PhoneStateListener 内存泄漏 - android