summaryrefslogtreecommitdiff
path: root/core/image.cpp
diff options
context:
space:
mode:
authorRĂ©mi Verschelde <rverschelde@gmail.com>2018-01-03 10:17:48 +0100
committerGitHub <noreply@github.com>2018-01-03 10:17:48 +0100
commit6d812ad27f1578efbfe70b0234a05afd3e4728c9 (patch)
treee24a8242406aac301dc5159b5bf99cc83d8f2a4d /core/image.cpp
parenta24dd678fdef632300347df6e32b5b5b687b0e30 (diff)
parent267bad6b4c3485e12939a0e914d45319b66f67df (diff)
Merge pull request #15051 from binbitten/bug-fixes
Add missing image format RGB10A2. Fixes #14964
Diffstat (limited to 'core/image.cpp')
-rw-r--r--core/image.cpp24
1 files changed, 24 insertions, 0 deletions
diff --git a/core/image.cpp b/core/image.cpp
index 11429b8782..2f2d7efd7c 100644
--- a/core/image.cpp
+++ b/core/image.cpp
@@ -47,6 +47,7 @@ const char *Image::format_names[Image::FORMAT_MAX] = {
"RGBA8",
"RGBA4444",
"RGBA5551",
+ "RGB10A2",
"RFloat", //float
"RGFloat",
"RGBFloat",
@@ -112,6 +113,7 @@ int Image::get_format_pixel_size(Format p_format) {
case FORMAT_RGBA8: return 4;
case FORMAT_RGBA4444: return 2;
case FORMAT_RGBA5551: return 2;
+ case FORMAT_RGB10A2: return 4;
case FORMAT_RF:
return 4; //float
case FORMAT_RGF: return 8;
@@ -1978,6 +1980,15 @@ Color Image::get_pixel(int p_x, int p_y) const {
float a = ((u >> 15) & 0x1) / 1.0;
return Color(r, g, b, a);
} break;
+ case FORMAT_RGB10A2: {
+
+ uint32_t u = ((uint32_t *)ptr)[ofs];
+ float r = (u & 0x3FF) / 1023.0;
+ float g = ((u >> 10) & 0x3FF) / 1023.0;
+ float b = ((u >> 20) & 0x3FF) / 1023.0;
+ float a = ((u >> 30) & 0x3) / 3.0;
+ return Color(r, g, b, a);
+ } break;
case FORMAT_RF: {
float r = ((float *)ptr)[ofs];
@@ -2123,6 +2134,18 @@ void Image::set_pixel(int p_x, int p_y, const Color &p_color) {
((uint16_t *)ptr)[ofs] = rgba;
} break;
+ case FORMAT_RGB10A2: {
+
+ uint32_t rgba = 0;
+
+ rgba = uint32_t(CLAMP(p_color.r * 1023.0, 0, 1023));
+ rgba |= uint32_t(CLAMP(p_color.g * 1023.0, 0, 1023)) << 10;
+ rgba |= uint32_t(CLAMP(p_color.b * 1023.0, 0, 1023)) << 20;
+ rgba |= uint32_t(CLAMP(p_color.a * 3.0, 0, 3)) << 30;
+
+ ((uint32_t *)ptr)[ofs] = rgba;
+
+ } break;
case FORMAT_RF: {
((float *)ptr)[ofs] = p_color.r;
@@ -2300,6 +2323,7 @@ void Image::_bind_methods() {
BIND_ENUM_CONSTANT(FORMAT_RGBA8);
BIND_ENUM_CONSTANT(FORMAT_RGBA4444);
BIND_ENUM_CONSTANT(FORMAT_RGBA5551);
+ BIND_ENUM_CONSTANT(FORMAT_RGB10A2);
BIND_ENUM_CONSTANT(FORMAT_RF); //float
BIND_ENUM_CONSTANT(FORMAT_RGF);
BIND_ENUM_CONSTANT(FORMAT_RGBF);