summaryrefslogtreecommitdiffstats
path: root/modules/hdr
diff options
context:
space:
mode:
authorBlueCube3310 <53150244+BlueCube3310@users.noreply.github.com>2024-08-08 19:13:00 +0200
committerBlueCube3310 <53150244+BlueCube3310@users.noreply.github.com>2024-08-09 22:39:30 +0200
commit80cf6cbfe9c0611ac649eb0e9cb92d0f5765d220 (patch)
treeebfa8506f92fc1f4138dfa961c7ac66d1f53884d /modules/hdr
parent739019e4e4a6e4763e37adfd9883a1c85d5f6249 (diff)
downloadredot-engine-80cf6cbfe9c0611ac649eb0e9cb92d0f5765d220.tar.gz
Optimize .hdr loading and RGB9E5 conversion
Diffstat (limited to 'modules/hdr')
-rw-r--r--modules/hdr/image_loader_hdr.cpp32
-rw-r--r--modules/hdr/image_loader_hdr.h1
2 files changed, 22 insertions, 11 deletions
diff --git a/modules/hdr/image_loader_hdr.cpp b/modules/hdr/image_loader_hdr.cpp
index c49c62a08b..ba59bb25ee 100644
--- a/modules/hdr/image_loader_hdr.cpp
+++ b/modules/hdr/image_loader_hdr.cpp
@@ -68,9 +68,11 @@ Error ImageLoaderHDR::load_image(Ref<Image> p_image, Ref<FileAccess> f, BitField
imgdata.resize(height * width * (int)sizeof(uint32_t));
{
- uint8_t *w = imgdata.ptrw();
+ uint8_t *ptr = imgdata.ptrw();
- uint8_t *ptr = (uint8_t *)w;
+ Vector<uint8_t> temp_read_data;
+ temp_read_data.resize(128);
+ uint8_t *temp_read_ptr = temp_read_data.ptrw();
if (width < 8 || width >= 32768) {
// Read flat data
@@ -113,8 +115,9 @@ Error ImageLoaderHDR::load_image(Ref<Image> p_image, Ref<FileAccess> f, BitField
}
} else {
// Dump
+ f->get_buffer(temp_read_ptr, count);
for (int z = 0; z < count; ++z) {
- ptr[(j * width + i++) * 4 + k] = f->get_8();
+ ptr[(j * width + i++) * 4 + k] = temp_read_ptr[z];
}
}
}
@@ -122,20 +125,27 @@ Error ImageLoaderHDR::load_image(Ref<Image> p_image, Ref<FileAccess> f, BitField
}
}
+ const bool force_linear = p_flags & FLAG_FORCE_LINEAR;
+
//convert
for (int i = 0; i < width * height; i++) {
- float exp = pow(2.0f, ptr[3] - 128.0f);
+ int e = ptr[3] - 128;
+
+ if (force_linear || (e < -15 || e > 15)) {
+ float exp = pow(2.0f, e);
+ Color c(ptr[0] * exp / 255.0, ptr[1] * exp / 255.0, ptr[2] * exp / 255.0);
- Color c(
- ptr[0] * exp / 255.0,
- ptr[1] * exp / 255.0,
- ptr[2] * exp / 255.0);
+ if (force_linear) {
+ c = c.srgb_to_linear();
+ }
- if (p_flags & FLAG_FORCE_LINEAR) {
- c = c.srgb_to_linear();
+ *(uint32_t *)ptr = c.to_rgbe9995();
+ } else {
+ // https://github.com/george-steel/rgbe-rs/blob/e7cc33b7f42b4eb3272c166dac75385e48687c92/src/types.rs#L123-L129
+ uint32_t e5 = (uint32_t)(e + 15);
+ *(uint32_t *)ptr = ((e5 << 27) | ((uint32_t)ptr[2] << 19) | ((uint32_t)ptr[1] << 10) | ((uint32_t)ptr[0] << 1));
}
- *(uint32_t *)ptr = c.to_rgbe9995();
ptr += 4;
}
}
diff --git a/modules/hdr/image_loader_hdr.h b/modules/hdr/image_loader_hdr.h
index 9821db059e..0a8e91fb9e 100644
--- a/modules/hdr/image_loader_hdr.h
+++ b/modules/hdr/image_loader_hdr.h
@@ -37,6 +37,7 @@ class ImageLoaderHDR : public ImageFormatLoader {
public:
virtual Error load_image(Ref<Image> p_image, Ref<FileAccess> f, BitField<ImageFormatLoader::LoaderFlags> p_flags, float p_scale);
virtual void get_recognized_extensions(List<String> *p_extensions) const;
+
ImageLoaderHDR();
};