summaryrefslogtreecommitdiffstats
path: root/drivers/gles3
diff options
context:
space:
mode:
authorChristopheClaustre <christophe.claustre.31@gmail.com>2024-07-10 12:54:25 +0200
committerChristopheClaustre <christophe.claustre.31@gmail.com>2024-07-11 21:47:18 +0200
commit626106da006dcc9d10a590504ed31ad69505ccc5 (patch)
treea6abdfb9ef023351680e18aa559acea18836d38c /drivers/gles3
parent383a6e4ef285fddcb0e1cbe28a20332c7e5a815b (diff)
downloadredot-engine-626106da006dcc9d10a590504ed31ad69505ccc5.tar.gz
gl_type_cache is used mainly for texture to image conversion need to be adjusted for when HDR format is activated
Diffstat (limited to 'drivers/gles3')
-rw-r--r--drivers/gles3/storage/texture_storage.cpp4
1 files changed, 1 insertions, 3 deletions
diff --git a/drivers/gles3/storage/texture_storage.cpp b/drivers/gles3/storage/texture_storage.cpp
index 2dcf623995..9138045653 100644
--- a/drivers/gles3/storage/texture_storage.cpp
+++ b/drivers/gles3/storage/texture_storage.cpp
@@ -1030,10 +1030,8 @@ Ref<Image> TextureStorage::texture_2d_get(RID p_texture) const {
if (texture->compressed) {
glPixelStorei(GL_PACK_ALIGNMENT, 4);
glGetCompressedTexImage(texture->target, i, &w[ofs]);
-
} else {
glPixelStorei(GL_PACK_ALIGNMENT, 1);
-
glGetTexImage(texture->target, i, texture->gl_format_cache, texture->gl_type_cache, &w[ofs]);
}
}
@@ -2123,7 +2121,7 @@ void TextureStorage::_update_render_target(RenderTarget *rt) {
texture->layers = 1;
}
texture->gl_format_cache = rt->color_format;
- texture->gl_type_cache = GL_UNSIGNED_BYTE;
+ texture->gl_type_cache = !rt->hdr ? GL_UNSIGNED_BYTE : GL_FLOAT; // to set HDR format size to 8 and keep 4 for LDR format
texture->gl_internal_format_cache = rt->color_internal_format;
texture->tex_id = rt->color;
texture->width = rt->size.x;