-
Notifications
You must be signed in to change notification settings - Fork 6
WhyS2TC
S2TC's format specification is very easy to implement, so it is not hard to make a working compressor or decompressor for it.
S2TC is especially well suited for runtime (on-load) compression of textures, as it is - in low quality settings - way faster than any other texture compressors out there.
S2TC is based on Color Cell Compression[1] from 1986, and decoding is done entirely using the methods from there. Encoding is done using a search and refinement method that is derived from the methods on that paper.
The compressor and decompressor here is of course licensed under a license that gives you all freedoms you will ever need (namely, the MIT license).
The S2TC reference compressor has special modes to support compressing normalmaps, and can set specific color distance metrics both for sRGB and for regular RGB. In many cases, this allows better encoding quality than the colorspace-ignorant existing S3TC compressors out there. This does not mean S2TC is better quality than S3TC - in fact, any S3TC compressor could implement these methods just as well, and get better quality out of it. However, currently no S3TC compressor supports that fully (but AMD Compressonator has some settings in that direction, which allow changing the relative color component weights, but this doesn't suffice to properly encode sRGB or normalmap textures).
[1]: Graham Campbell, Thomas A. DeFanti, Jeff Frederiksen, Stephen A. Joyce, and Lawrence A. Leske. 1986. Two bit/pixel full color encoding. SIGGRAPH Comput. Graph. 20, 4 (August 1986), 215-223.