diff options
author | ChristopheClaustre <christophe.claustre.31@gmail.com> | 2024-07-10 12:54:25 +0200 |
---|---|---|
committer | ChristopheClaustre <christophe.claustre.31@gmail.com> | 2024-07-11 21:47:18 +0200 |
commit | 626106da006dcc9d10a590504ed31ad69505ccc5 (patch) | |
tree | a6abdfb9ef023351680e18aa559acea18836d38c /drivers/gles3 | |
parent | 383a6e4ef285fddcb0e1cbe28a20332c7e5a815b (diff) | |
download | redot-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.cpp | 4 |
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; |