3

片段着色器:

out vec4 Color;
uniform samplerBuffer sampler;
uniform int index;
void main() 
{
   Color=normalize(texelFetch(sampler,index));

}

我正在使用 glTexBuffer() 对http://www.opengl.org/sdk/docs/man3/xhtml/glTexBuffer.xml中给出的所有内部格式进行纹理化。以上着色器仅适用于 ubyte、ushort 规范化类型和 float、halffloat 非规范化类型。对于其余的内部格式,它不会在几何体上应用纹理。

我需要改变什么才能达到预期的效果?

代码

GLbyte arr[]={124,5,126};
glGenBuffers(1,&bufferid);

glBindBuffer(GL_TEXTURE_BUFFER,bufferid);

glBufferData(GL_TEXTURE_BUFFER,sizeof(arr),arr,GL_STATIC_DRAW);


glGenTextures(1, &buffer_texture);   

glBindTexture(GL_TEXTURE_BUFFER, buffer_texture);
glTexBuffer(GL_TEXTURE_BUFFER, GL_R8I, bufferid);

glUniform1i(glGetUniformLocation(shader_data.psId,"sampler"),0);
glUniform1i(glGetUniformLocation(shader_data.psId,"index"),0);

glGenBuffers(1,&bufferid1);

glBindBuffer(GL_ARRAY_BUFFER,bufferid1);
glBufferData(GL_ARRAY_BUFFER,sizeof(vertices4),vertices4,GL_STATIC_DRAW);

attr_vertex = glGetAttribLocation(shader_data.psId, "a_position");

glVertexAttribPointer(attr_vertex, 2 , GL_FLOAT, GL_FALSE ,0, 0);

glEnableVertexAttribArray(attr_vertex);

glDrawArrays(GL_TRIANGLE_FAN,0,4);

glUniform1i(glGetUniformLocation(shader_data.psId,"index"),1);

glVertexAttribPointer(attr_vertex, 2 , GL_FLOAT, GL_FALSE ,0,(void *)(32) );

glDrawArrays(GL_TRIANGLE_FAN,0,4);

glUniform1i(glGetUniformLocation(shader_data.psId,"index"),2);

glVertexAttribPointer(attr_vertex, 2 , GL_FLOAT, GL_FALSE ,0,(void *)(64) );

glDrawArrays(GL_TRIANGLE_FAN,0,4);

我必须使用所有内部格式来应用纹理。

4

1 回答 1

2

如果“想要的效果”是拥有一个可以处理任何格式的图像数据的着色器,那么就没有办法做到这一点。或者至少,没有简单的方法。

你可以有三个不同的采样器,绑定到三个不同的纹理图像单元,对应于三种不同的可能格式(float、signed-int、unsigned-int)。您创建 3 个不同的缓冲区纹理(使用相同的缓冲区),并将适当的纹理绑定到适当的采样器,以获得您希望着色器使用的数据类型。然后你传递一个定义应该使用哪个采样器的制服。

但除了这样的条件逻辑之外,没有。采样器的类型用于确定如何解释给着色器的数据,它必须与纹理的格式相匹配。

通常,着色器旨在预期某些特定数据,而不是客户端代码想要扔给它的任何旧的任意东西。从纹理中拉出浮点数的着色器并不关心它是归一化整数还是 16 位浮点数,还是 R11F_G11F_B10F 或其他;着色器只想要浮动。将图像推送到需要浮动的着色器是不合适的。

于 2012-10-11T10:51:41.120 回答