Skip to content

Using Basis Universal to decompress any supported GPU texture format

Rich Geldreich edited this page Mar 20, 2020 · 12 revisions

The Basis Universal encoder codebase contains easy to use code to unpack the following compressed GPU texture formats:

  • BC7 - Fully supported
  • ASTC - LDR only (HDR is in the code, but remarked out until we need it) Our high-level helpers only support 4x4 block size, but you can access the low-level ASTC code directly (in basisu_astc_decomp.h) to unpack other ASTC block sizes.
  • BC1-5 - Fully supported
  • ETC1 - Fully supported
  • ETC2 RGBA8 - Only supports ETC1 for color data (no planar, T/H modes), alpha data is fully supported
  • ETC2 EAC R11/RG11 - Fully supported
  • PVRTC1 4bpp RGB/RGBA - Fully supported
  • PVRTC2 - Limited support. Just the non-interpolated mode our transcoders use.
  • ATC RGB/RGBA - Fully supported
  • FXT1 - Limited support (just the mode we use)

Before you can unpack textures, be sure to call basisu_encoder_init() once at startup.

To unpack individual 4x4 (or 8x4 for FXT1) texel blocks to raw RGBA pixels, use this function:

bool basisu::unpack_block(texture_format fmt, const void *pBlock, color_rgba *pPixels);

This doesn't work on PVRTC1 textures, because the decoder needs access to the surrounding blocks. Alternately, you can create a basisu::gpu_image object, then call gpu_image::unpack(). This works on any supported format, including PVRTC1.