【问题标题】:WebGL: INVALID_OPERATION: vertexAttribPointer: stride or offset not valid for typeWebGL:INVALID_OPERATION:vertexAttribPointer:步幅或偏移对类型无效
【发布时间】:2015-02-26 16:19:47
【问题描述】:

我学习 WebGL。

当我尝试绘制三个点时,当每个点都有自己的位置、大小和颜色时,我遇到了一些错误。我尝试通过同一个缓冲区来完成。

// To draw three points. Each of this has own location, size and color.
function start(gl){
  if(!initShaders(gl, VSHADER_SOURCE, FSHADER_SOURCE)){
    console.log('Failes shaders initialization.');
    return;
  }
  var a_Position = gl.getAttribLocation(gl.program, 'a_Position');
  if(a_Position < 0){
    console.log('The "a_Position" variable was not found in the shader code.');
    return;
  }
  var a_PointSize = gl.getAttribLocation(gl.program, 'a_PointSize');
  if(a_PointSize < 0){
    console.log('The "a_PointSize" variable was not found in the shader code.');
    return;
  }

  var a_FragColor = gl.getAttribLocation(gl.program, 'a_FragColor');
  if(a_FragColor < 0){
    console.log('The "a_FragColor" variable was not found in the shader code.');
    return;
  }

  var data = new Float32Array([
     // a_Position, a_PointSize and a_FragColor in the each record:
    -0.25, -0.25, 10.0, 1.0, 0.0, 0.0, 1.0,
     0.00,  0.25, 20.0, 0.0, 1.0, 0.0, 1.0,
     0.25, -0.25, 30.0, 0.0, 0.0, 1.0, 1.0
  ]);

  var buffer = gl.createBuffer();
  if(!buffer){
    console.log('Can not create a buffer.');
    return;
  }
  gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
  gl.bufferData(gl.ARRAY_BUFFER, data, gl.STATIC_DRAW);

  var FSIZE = data.BYTES_PER_ELEMENT;  
  var RECORDSIZE = 7;

  gl.vertexAttribPointer(a_Position,  2, gl.FLOAT, false, FSIZE * RECORDSIZE, 0);
  gl.vertexAttribPointer(a_PointSize, 1, gl.FLOAT, false, FSIZE * RECORDSIZE, 2);
  gl.vertexAttribPointer(a_FragColor, 4, gl.FLOAT, false, FSIZE * RECORDSIZE, 3);

  gl.enableVertexAttribArray(a_Position);
  gl.enableVertexAttribArray(a_PointSize);
  gl.enableVertexAttribArray(a_FragColor);

  gl.clearColor(0.0,0.0,0.0,1.0);
  gl.clear(gl.COLOR_BUFFER_BIT);

  gl.drawArrays(gl.POINTS, 0, 3);
}

但我得到一些错误:

我不清楚。我做错了什么?

【问题讨论】:

    标签: opengl-es webgl opengl-es-2.0


    【解决方案1】:

    正如documentation 中所写,抛出一个 INVALID_OPERATION:

    • 如果步幅或偏移量不是类型的倍数。

    由于您使用 GL_FLOAT 作为类型,其大小为 4 个字节,因此偏移量只允许为 4 的倍数。此代码中使用的 2 和 3 不是。

                                                                               ||
                                                                               \/
    gl.vertexAttribPointer(a_PointSize, 1, gl.FLOAT, false, FSIZE * RECORDSIZE, 2);
    gl.vertexAttribPointer(a_FragColor, 4, gl.FLOAT, false, FSIZE * RECORDSIZE, 3);
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2022-06-10
      • 2013-05-07
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-01-12
      • 2013-03-24
      • 2019-11-28
      相关资源
      最近更新 更多