gpt4 book ai didi

C++ - OpenGL 在 glDrawElements() 上崩溃

转载 作者:行者123 更新时间:2023-11-28 00:21:27 24 4
gpt4 key购买 nike

因此,在我的程序中,我有许多要显示的纹理。在我的代码前面,我为纹理生成了 VAO,为每个纹理生成了 ibo(或索引缓冲区)。但是当我运行我的代码时,它在 glDrawElements() 调用和 nvoglv32.dll 中崩溃。我读到 nvidia 驱动程序中的一个错误可能会导致它,但我对此表示怀疑。当我生成或绑定(bind) VAO 或 ibo 时,可能出了点问题,但我不知道在哪里。这是发生错误的代码部分:

for (int i = 0; i < NUM_TEXTURES; i++){

glBindVertexArray(VAO_T[i]);
glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, ibo[i]);
glBindTexture(GL_TEXTURE_2D, texture[i]);

//error here
glDrawElements(GL_TRIANGLES, 6, GL_UNSIGNED_INT, BUFFER_OFFSET(0));//error right here

}

这是我在调试中运行时遇到的错误:

Comp465.exe 中 0x0263FE4A 处未处理的异常:0xC0000005:访问冲突读取位置 0x00000000。

这是我生成 VAO、ibo 和纹理的代码:

glGenVertexArrays(NUM_TEXTURES, VAO_T);
glGenBuffers(NUM_TEXTURES, VBO_T);
glGenBuffers(NUM_TEXTURES, ibo);
glGenTextures(NUM_TEXTURES, texture);

...

for (int i = 0; i < NUM_TEXTURES; i++){

//Tel GL which VAO we are using
glBindVertexArray(VAO_T[i]);

glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, ibo[i]);
glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices[i]), indices[i], GL_STATIC_DRAW);

//initialize a buffer object
glEnableVertexAttribArray(VBO_T[i]);
glBindBuffer(GL_ARRAY_BUFFER, VBO_T[i]);
glBufferData(GL_ARRAY_BUFFER, sizeof(point[i]) + sizeof(texCoords), NULL, GL_STATIC_DRAW);
glBufferSubData(GL_ARRAY_BUFFER, 0, sizeof(point[i]), point[i]);
glBufferSubData(GL_ARRAY_BUFFER, sizeof(point[i]), sizeof(texCoords), texCoords);

GLuint vPosition = glGetAttribLocation(textureShader, "vPosition");
glVertexAttribPointer(vPosition, 4, GL_FLOAT, GL_FALSE, 0, BUFFER_OFFSET(0));
glEnableVertexAttribArray(vPosition);

GLuint vTexCoord = glGetAttribLocation(textureShader, "vTexCoord");
glVertexAttribPointer(vTexCoord, 2, GL_FLOAT, GL_FALSE, 0, BUFFER_OFFSET(sizeof(point[i])));
glEnableVertexAttribArray(vTexCoord);

//Get handles for the uniform structures in the texture shader program
VP = glGetUniformLocation(textureShader, "ViewProjection");

//Bind the texture that we want to use
glBindTexture(GL_TEXTURE_2D, texture[i]);

glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
// set texture parameters
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP);
glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP);

//Load texture
texture[i] = loadRawTexture(texture[i], TEX_FILE_NAME[i], PixelSizes[i][0], PixelSizes[i][1]);
if (texture[i] != 0) {
printf("texture loaded \n");
}
else
printf("Error loading texture \n");
}

最佳答案

这个声明肯定看起来是错误的:

glEnableVertexAttribArray(VBO_T[i]);

glEnableVertexAttribArray() 将属性位置作为其参数,而不是缓冲区 ID。稍后您实际上会正确使用它:

GLuint vPosition = glGetAttribLocation(textureShader, "vPosition");
...
glEnableVertexAttribArray(vPosition);

GLuint vTexCoord = glGetAttribLocation(textureShader, "vTexCoord");
...
glEnableVertexAttribArray(vTexCoord);

因此您应该能够简单地删除带有无效参数的额外调用。

除此之外,我注意到一些看起来有点不对劲,或者至少是可疑的东西:

  • 如果您使用可编程管道,则以下调用毫无意义,您基于其余代码中显示的内容。可以删除。

    glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
  • 这可能只是一个命名问题,但是 textureShader 需要是一个 program 对象,即 glCreateProgram()< 的返回值,不是着色器对象。

  • 虽然没有看到声明还没有定论,但我对此有一种不好的预感,还有其他一些类似的呼吁:

    glBufferData(GL_ELEMENT_ARRAY_BUFFER, sizeof(indices[i]), indices[i], GL_STATIC_DRAW);

    如果 indices[i] 是一个数组,即声明看起来像这样:

    indices[NUM_TEXTURES][INDEX_COUNT];

    那么就可以了。但是,如果 indices[i] 是一个指针,或者当它作为函数参数传递时退化为指针,则 sizeof(indices[i]) 将是一个指针。您可能需要仔细检查它是否给出了索引数组的实际大小。其他类似情况也是如此。

关于C++ - OpenGL 在 glDrawElements() 上崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27288451/

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