summaryrefslogtreecommitdiffstats
path: root/modules/basis_universal
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-02-22 11:23:11 +0100
committerRémi Verschelde <rverschelde@gmail.com>2024-02-22 11:23:11 +0100
commitc3de771292da796ce89e1668a96668a197c20a4f (patch)
tree8f721cfdc337dfaa7166e0fa9f2517440e8809cc /modules/basis_universal
parent0550abf225da1ff56944cf1b8f28841b564e6cd2 (diff)
parent0afee63712cef54b108ff5a5176df5783a10b13f (diff)
downloadredot-engine-c3de771292da796ce89e1668a96668a197c20a4f.tar.gz
Merge pull request #88485 from BlueCube3310/basisu-astc-v2
Add ASTC support to BasisUniversal
Diffstat (limited to 'modules/basis_universal')
-rw-r--r--modules/basis_universal/image_compress_basisu.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/modules/basis_universal/image_compress_basisu.cpp b/modules/basis_universal/image_compress_basisu.cpp
index 41de62b20b..12856f33c1 100644
--- a/modules/basis_universal/image_compress_basisu.cpp
+++ b/modules/basis_universal/image_compress_basisu.cpp
@@ -154,6 +154,7 @@ Ref<Image> basis_universal_unpacker_ptr(const uint8_t *p_data, int p_size) {
// Get supported compression formats.
bool bptc_supported = RS::get_singleton()->has_os_feature("bptc");
+ bool astc_supported = RS::get_singleton()->has_os_feature("astc");
bool s3tc_supported = RS::get_singleton()->has_os_feature("s3tc");
bool etc2_supported = RS::get_singleton()->has_os_feature("etc2");
@@ -166,6 +167,9 @@ Ref<Image> basis_universal_unpacker_ptr(const uint8_t *p_data, int p_size) {
if (bptc_supported) {
basisu_format = basist::transcoder_texture_format::cTFBC7_M6_OPAQUE_ONLY;
image_format = Image::FORMAT_BPTC_RGBA;
+ } else if (astc_supported) {
+ basisu_format = basist::transcoder_texture_format::cTFASTC_4x4_RGBA;
+ image_format = Image::FORMAT_ASTC_4x4;
} else if (s3tc_supported) {
basisu_format = basist::transcoder_texture_format::cTFBC1;
image_format = Image::FORMAT_DXT1;
@@ -183,6 +187,9 @@ Ref<Image> basis_universal_unpacker_ptr(const uint8_t *p_data, int p_size) {
if (bptc_supported) {
basisu_format = basist::transcoder_texture_format::cTFBC7_M5;
image_format = Image::FORMAT_BPTC_RGBA;
+ } else if (astc_supported) {
+ basisu_format = basist::transcoder_texture_format::cTFASTC_4x4_RGBA;
+ image_format = Image::FORMAT_ASTC_4x4;
} else if (s3tc_supported) {
basisu_format = basist::transcoder_texture_format::cTFBC3;
image_format = Image::FORMAT_DXT5;