以下是代码的一部分。编译时没有问题,但执行时崩溃。它突破了glTexImage3D的界限。 Qt版本4.5.3,类“opengl”继承自QGLWidget。
void opengl::initializeGL()
{
GLenum err = glewInit();
create_volumetexture();
}
void opengl::create_volumetexture()
{
int w = 256, h = 256, d = 225;
size_t size = w * h * d;
if (dataRGBA)
{
delete dataRGBA;
dataRGBA=NULL;
}
dataRGBA=new GLubyte[4*size];
for (int i=0; i<size; i++)
{
dataRGBA[4*i]=200;
dataRGBA[4*i+1]=0;
dataRGBA[4*i+2]=0;
dataRGBA[4*i+3]=100;
}
glGenTextures(1, &volume_texture);
// bind 3D texture target
glBindTexture(GL_TEXTURE_3D, volume_texture);
glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
glTexParameteri(GL_TEXTURE_3D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
glTexParameteri(GL_TEXTURE_3D, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
glTexParameteri(GL_TEXTURE_3D, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_BORDER);
glTexParameteri(GL_TEXTURE_3D, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_BORDER);
glTexParameteri(GL_TEXTURE_3D, GL_TEXTURE_WRAP_R, GL_CLAMP_TO_BORDER);
glPixelStorei(GL_UNPACK_ALIGNMENT,1);
glTexImage3D(GL_TEXTURE_3D_EXT, 0, GL_RGBA, w, h, d, 1, /*GL_LUMINANCE*/GL_RGBA, GL_UNSIGNED_BYTE,dataRGBA);
}
答案 0 :(得分:3)
你给border参数赋了一个非零值,但是为它分配的缓冲区没有考虑到它,所以glTexImage3D执行缓冲区读取溢出。
d 也不是两个人的力量,所以你有另一个问题。您可以使用带有空指针的glTexImage3D来初始化纹理,使用glTexSubImage3D来填充实际内容 - 传递给glTexSubImage的数据也可以是非格式的2格式(但是纹理本身必须使用还有2个维度......和边界。