0
votes

I'm a bit confused about the internal format, format and type. So what's about the depth attachment point?

If I'm using a RenderBuffer, I think this is the valid code if I don't want to use stencil:

glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH_COMPONENT32F, width, height);
glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, depthRB);

However if I want to be able to read the depth values, I have to attach a texture to the depth attachment point. So I have to call a glTexImage2D function with parameters "internal format", "format" and "type".

In this case which internal format, format and type should I choose? Can I use the following combinations for a depth attachment? (in the order of: internal format, format and type)

  • GL_R32F, GL_RED, GL_FLOAT
  • GL_DEPTH_COMPONENT32, GL_DEPTH_COMPONENT, GL_UNSIGNED_INT
  • GL_DEPTH_COMPONENT32F, GL_DEPTH_COMPONENT, GL_FLOAT

Is the GL_UNSIGNED_INT type valid for the 2nd case? What does that really mean? Will it allocate 4 bytes per fragment? In some tutorials they are using GL_UNSIGNED_BYTE for the type parameter. Which is the correct one?

Thanks

Edit:

Clarified my question about which parameters I'm interested in.

1
What do you mean, "format" and "type"? Renderbuffers have only an internal format, not an external one. Or are you asking which external format you should then use in a glReadPixels call?peppe
According to Khronos Group reference pages You can only use the following as internal format of a render buffer: GL_RGBA4, GL_RGB565, GL_RGB5_A1, GL_DEPTH_COMPONENT16, or GL_STENCIL_INDEX8 glRenderbufferStorage reference pageMatso
@peppe: "What do you mean, "format" and "type"?" He's talking about the pixel transfer parameters. The last three parameters to glTexImage2D.Nicol Bolas
@Matso The link you provide is to OpenGL ES documentation. OpenGL has many more supported formats.Reto Koradi
Reiterating the question from @peppe above: What do you mean by "read the depth values"? You can use glReadPixels() if the attachment is a renderbuffer. Do you mean that you want to sample the depth image in shader code?Reto Koradi

1 Answers

2
votes

Depth values are not color values. As such, if you want to store depth values in a texture, the texture must use an internal format that contains depth information.

The pixel transfer format/type parameters, even if you're not actually passing data, must still be reasonable with respect to the internal format. Since the internal format contains depth information, your pixel transfer format must specify depth information: GL_DEPTH_COMPONENT.

As for the pixel transfer type, you should read 32F back as GL_FLOAT.