- 
                Notifications
    You must be signed in to change notification settings 
- Fork 462
Compress
Compresses an image or set of images to a block-compressed (BC) format.
HRESULT Compress( const Image& srcImage, DXGI_FORMAT format,
    DWORD compress, float alphaRef,
    ScratchImage& cImage );
HRESULT Compress( const Image* srcImages, size_t nimages,
    const TexMetadata& metadata,
    DXGI_FORMAT format, DWORD compress, float alphaRef,
    ScratchImage& cImages );
HRESULT Compress( ID3D11Device* pDevice, const Image& srcImage,
    DXGI_FORMAT format, DWORD compress, float alphaWeight,
    ScratchImage& image );
HRESULT Compress( ID3D11Device* pDevice,
    const Image* srcImages, size_t nimages,
    const TexMetadata& metadata,
    DXGI_FORMAT format, DWORD compress, float alphaWeight,
    ScratchImage& cImages );
device: The DirectCompute based versions of Compress require a Direct3D 11 device with Feature Level 10.0 or greater that supports DirectCompute.
format: Format to compress to. Must be a BC compressed format (i.e. DXGI_FORMAT_BC1_UNORM, DXGI_FORMAT_BC1_UNORM_SRGB - DXGI_FORMAT_BC7_UNORM, DXGI_FORMAT_BC7_UNORM_SRGB)
Note that the DirectCompute based versions of Compress only support DXGI_FORMAT_BC6H_UF16, DXGI_FORMAT_BC6H_SF16, DXGI_FORMAT_BC7_UNORM, and DXGI_FORMAT_BC7_UNORM_SRGB
compress: Compress control flags
- 
TEX_COMPRESS_DEFAULTDefault flags.
- 
TEX_COMPRESS_RGB_DITHEREnables dithering RGB colors for BC1-3 compression
- 
TEX_COMPRESS_A_DITHEREnables dithering alpha channel for BC1-3 compression
- 
TEX_COMPRESS_DITHERSame asTEX_COMPRESS_RGB_DITHERandTEX_COMPRESS_A_DITHER
- 
TEX_COMPRESS_UNIFORMBy default, BC1-3 uses a perceptual weighting. By using this flag, the perceptual weighting is disabled which can be useful when using the RGB channels for other data.
- 
TEX_COMPRESS_PARALLELThis opts-in to multi-threaded compression if enabled.
- 
TEX_COMPRESS_SRGB_INIndicates the input format is the sRGB format. This is implied if using aDXGI_FORMAT_*_SRGBformat
- 
TEX_COMPRESS_SRGB_OUTIndicates the output format is the sRGB format. This is implied if using aDXGI_FORMAT_*_SRGBformat
- 
TEX_COMPRESS_SRGBThis is the same as setting bothTEX_COMPRESS_SRGB_INandTEX_COMPRESS_SRGB_OUT
The sRGB color space overall is approximately equivalent to gamma 2.2. It's actually linear below a threshold, and gamma 2.4 beyond that.
alphaRef: Threshold reference value when compressing an alpha channel for BC1 formats which support 1-bit transparency. (0 to 1 range)
alphaWeight: Used to weight the error metric's alpha computation for the BC7 GPU compressor. Use 1.0 for default, or a larger number to improve alpha accuracy potentially at the expense of the color channels.
ScratchImage srcImage;
...
ScratchImage bcImage;
hr = Compress( srcImage.GetImages(), srcImage.GetImageCount(), srcImage.GetMetadata(), DXGI_FORMAT_BC3_UNORM, TEX_COMPRESS_DEFAULT, 0.5f, bcImage );
if ( FAILED(hr) )
    ...
By default, the BC1 - BC3 color encoding algorithms will use a perceptual weighting of the Red and Blue channels which usually gives better visual results for standard color textures. For textures that do not contain color data, you will likely want to use TEX_COMPRESS_UNIFORM to disable the perceptual weighting.
When compressing for BC4, only the RED channel in the original image is used. When compressing for BC5, only the RED and GREEN channels are used.
The DirectXTex library functions allow arbitrary sized images to handle non-power-of-2 mipmapped BC textures. Note that Direct3D will not allow a resource to be created using BC format with the top-level size set to something other than a multiple of 4 in width and height, even though it does allow the mipchain below it to not meet that requirement. In other words, the library allows some textures to be compressed that are not actually valid on Direct3D 11.
This function cannot operate directly on a planar format image. See ConvertToSinglePlane for a method for converting planar data to a format that is supported by this routine.
The software based encoder for BC6H and BC7 is computationally expensive and can be quite slow. The DirectCompute based encoder which is much faster has been integrated into the DirectXTex library, but the standalone version is also available [url:http://code.msdn.microsoft.com/BC6HBC7-DirectCompute-35e8884a]
The CPU-based compressor will use all cores on a system if given TEX_COMPRESS_PARALLEL for the BC6H / BC7 codec.
The DirectCompute GPU-based compressor makes use of the device's immediate context.
Compressed Texture Resources (Direct3D 9)
Block Compression (Direct3D 10)
Texture Block Compression in Direct3D 11
S3 Texture Compress
3Dc
OpenGL ARB BPTC
All content and source code for this package are subject to the terms of the MIT License.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.
- Universal Windows Platform apps
- Windows desktop apps
- Windows 11
- Windows 10
- Windows 8.1
- Xbox One
- Xbox Series X|S
- Windows Subsystem for Linux
- x86
- x64
- ARM64
- Visual Studio 2022
- Visual Studio 2019 (16.11)
- clang/LLVM v12 - v20
- GCC 10.5, 11.4, 12.3, 13.3, 14.2
- MinGW 12.2, 13.2
- CMake 3.21
DirectX Tool Kit for DirectX 11