glTexImage3D在QT中崩溃

时间:2010-12-11 05:42:01

标签: qt opengl glew

以下是代码的一部分。编译时没有问题,但执行时崩溃。它突破了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);

}

1 个答案:

答案 0 :(得分:3)

你给border参数赋了一个非零值,但是为它分配的缓冲区没有考虑到它,所以glTexImage3D执行缓冲区读取溢出。

d 也不是两个人的力量,所以你有另一个问题。您可以使用带有空指针的glTexImage3D来初始化纹理,使用glTexSubImage3D来填充实际内容 - 传递给glTexSubImage的数据也可以是非格式的2格式(但是纹理本身必须使用还有2个维度......和边界。