【问题标题】:Textures only work in compat and glGetError Always INVALID_ENUM as soon as context is open纹理仅适用于 compat 和 glGetError 始终 INVALID_ENUM 只要上下文打开
【发布时间】:2013-02-03 02:54:33
【问题描述】:

我在使用 OpenGL 3.3 Core 时遇到了一些纹理问题。

如果我使用兼容配置文件,它会完美呈现。我尝试使用 glGetError() 进行调试

它在获得 vao 后返回一个无效的枚举。并在主循环期间返回相同的值。但这肯定不是问题吗? - 到那时就不可能有错误了。

我印象深刻的是调用 glGetError() 会清除错误,所以下一次调用只会显示两者之间的错误?

我的平台是带有驱动程序版本 310.70 的 nVidia GTX580 的 Windows7 64。

对于我的加载库,我正在使用 glload,但我也使用了 GLEW。 我正在使用 GLFW 来管理 OpenGL 上下文和 DevIL 来加载纹理。我正在VS2010中构建。

这是我完整来源的链接。 (我已经将主程序中的所有内容都成熟了,并尽可能合理地命名变量)

full source code

最有可能导致问题的代码。

使用 devIL 加载图像并缓冲到 GPU。

void loadImage(const char* imageFile)
{
    ILuint texid; 
    ilGenImages(1, &texid); 
    ilBindImage(texid); 

    ilLoadImage(imageFile);

    int size = ilGetInteger( IL_IMAGE_SIZE_OF_DATA ) ;
    ilConvertImage(IL_RGBA, IL_UNSIGNED_BYTE); 


    glActiveTexture(GL_TEXTURE0);
    glGenTextures(1,&textureBuffer);
    glBindTexture(GL_TEXTURE_2D, textureBuffer);

    glTexImage2D(GL_TEXTURE_2D, 
         0, 
         ilGetInteger(IL_IMAGE_BPP), 
         ilGetInteger(IL_IMAGE_WIDTH),
         ilGetInteger(IL_IMAGE_HEIGHT), 
         0, 
         ilGetInteger(IL_IMAGE_FORMAT),
         GL_UNSIGNED_BYTE,
         ilGetData());

    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
    glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);

    ilDeleteImages(1, &texid);


}

从主循环调用的渲染函数。

void render()
{
    glUseProgram(program);
    glBindVertexArray(vao);

    glBindBuffer(GL_ARRAY_BUFFER, dataBuffer);
    glBindBuffer(GL_ELEMENT_ARRAY_BUFFER, elementObject);
    glEnableVertexAttribArray(0);
    glEnableVertexAttribArray(1);
    glActiveTexture(GL_TEXTURE0);
    glBindTexture(GL_TEXTURE_2D,textureBuffer);

    glPixelStorei(GL_UNPACK_ALIGNMENT, 1);

    glVertexAttribPointer(0, 2, GL_FLOAT, GL_FALSE, 0, 0);
    glVertexAttribPointer(1, 2, GL_FLOAT, GL_FALSE, 0, (void*)(8*4));
    glDrawElements(GL_TRIANGLES,6,GL_UNSIGNED_INT,0); 

    glDisableVertexAttribArray(0);
    glDisableVertexAttribArray(1);
    glUseProgram(0);
}

顶点着色器

#version 330

layout(location = 0) in vec2 position;
layout(location = 1) in vec2 coords;
smooth out vec2 textureCO;
void main()
{
    gl_Position = vec4(position.x,position.y,0.0,1.0);
    textureCO = coords;

}

片段着色器

#version 330

out vec4 outputColor;
smooth in vec2 textureCO;
uniform sampler2D texture1;
void main()
{
    vec4 textureColor = texture(texture1, textureCO);
    outputColor = textureColor;
}

【问题讨论】:

  • glEnable(GL_TEXTURE_2D) 在核心配置文件上下文中无效。事实上,它应该设置错误标志。
  • 好的,用他们把纹理渲染器全黑了。
  • 源现在有 glEnable(GL_TEXTURE_2D) 和禁用删除。问题依然存在

标签: c++ opengl glsl glfw


【解决方案1】:

关于获取GL_INVALID_ENUM 的问题,这是 GLEW 库的常见问题。它记录在 opengl.org 上的 here。只需清除错误(通过调用glGetError,就像你说的那样),然后 OpenGL 错误报告就会正常运行(或者更准确地说,正如你所期望的那样)。

至于纹理问题,可能与调用ilGetInteger(IL_IMAGE_BPP)有关。在核心配置文件中,内部格式可能只是指定的图像格式之一,而根据 DevIL 文档,ilGetInteger(IL_IMAGE_BPP) 返回每​​个像素字节数的整数值。 glTexImage*D 在兼容模式下将接受值 1、2、3 或 4 作为内部格式,但这些值也会在核心配置文件下生成 GL_INVALID_VALUE 错误。

【讨论】:

  • 感谢您的回答。今天下午我会在我的主机上,我会回复你的。 +1
  • 仍有问题。目前 glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, ilGetInteger(IL_IMAGE_WIDTH), ilGetInteger(IL_IMAGE_HEIGHT), 0, GL_RGBA, GL_UNSIGNED_BYTE, ilGetData());什么是纹素? opengl 文档说宽度和高度应该是 1024 + 从我如何阅读它。
  • 现在工作。仍然收到枚举错误,但核心工作!谢谢
  • @Andrew 乐于助人。为了回答您关于“纹素”的问题,它是“纹理元素”的缩写,就像“像素”是“图片元素”一样。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-01-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-06-18
  • 2017-07-09
相关资源
最近更新 更多