我对stbi库有一个问题,我想,也许你知道为什么这不起作用。我声明了一个这样的函数:
bool LoadTextureFile(std::string file, unsigned char ** pixel_data, int * width, int * height, int * n);
在这个函数中,我得到stbi_load直接保存在*pixel_data变量的结果:
*pixel_data = stbi_load(file.c_str(), width, height, n, 0);
// Do some more stuff till return
return true;
所以,现在我的pixel_data指针指向stbi_load结果的内存。现在我想在前面的函数中使用这个结果和glTexImage2D方法。这个函数在调用OpenGL的glTexImage2D方法之前调用LoadTextureFile方法,如下所示:
bool LoadTexture(...)
{
int tex_width, tex_height, tex_n;
unsigned char * pixel_data = NULL;
LoadTextureFile(filename, &pixel_data, &tex_width, &tex_height, &tex_n);
// Do something special ...
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, tex_width, tex_height, 0, GL_RGB, GL_UNSIGNED_BYTE, &pixel_data);
stbi_image_free(&pixel_data);
// ...
}
但是如果我这样做,那么我在调用glTexImage2D时得到内存冲突消息。如果我将这整个魔法移动到LoadTextureFile中,在用stbi_load加载一个新的纹理文件之后,它就可以工作了:
bool LoadTextureFile(std::string file, unsigned char ** pixel_data, int * width, int * height, int * n)
{
unsigned char * = = stbi_load(file.c_str(), width, height, n, 0);
// Do some magic ...
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 80, 80, 0, GL_RGB, GL_UNSIGNED_BYTE, pixel_data);
stbi_image_free(pixel_data);
return true;
}
谁能告诉我为什么我得到这个消息和如何解决这个问题?
我想,这是一个保持预留内存安全的问题,但我不太确定,如何解决它。我之前在一个简单的控制台应用程序中尝试过,它可以工作。
谢谢你的帮助!
This:
unsigned char * pixel_data = NULL;
[...]
glTexImage2D(..., &pixel_data);
肯定不是你想要的。你正在使用先锋的地址到你的像素数据,而不是指针的值,所以你基本上是告诉GL使用你的堆栈内存的一些随机段作为纹理的源。应该是
glTexImage2D(..., pixel_data);
在第二个变量中,由于
这一行,实际发生了什么是不清楚的unsigned char * = = stbi_load(file.c_str(), width, height, n, 0);
没有意义,也不会编译。所以我认为这是在写问题时复制粘贴错误。但是很难猜测真正的代码会做什么。