diff options
author | krajcevski <krajcevski@google.com> | 2014-08-05 07:37:26 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2014-08-05 07:37:27 -0700 |
commit | e90c900ed7b2be3d0f9c7134d7fcd5f820b0464c (patch) | |
tree | dfb26735c967ec8763b50b9ed5e7a83889cd0970 /src/utils | |
parent | 72336ed7e16d2672543e0ceca9ddb843c63c8df6 (diff) |
Add ETC1 format to SkTextureCompressor
R=robertphillips@google.com
Author: krajcevski@google.com
Review URL: https://codereview.chromium.org/432143002
Diffstat (limited to 'src/utils')
-rw-r--r-- | src/utils/SkTextureCompressor.cpp | 41 | ||||
-rw-r--r-- | src/utils/SkTextureCompressor.h | 21 |
2 files changed, 52 insertions, 10 deletions
diff --git a/src/utils/SkTextureCompressor.cpp b/src/utils/SkTextureCompressor.cpp index 801328642f..4034615b37 100644 --- a/src/utils/SkTextureCompressor.cpp +++ b/src/utils/SkTextureCompressor.cpp @@ -16,6 +16,20 @@ #include "SkTextureCompression_opts.h" +#ifndef SK_IGNORE_ETC1_SUPPORT +# include "etc1.h" +#endif + +// Convert ETC1 functions to our function signatures +static bool compress_etc1_565(uint8_t* dst, const uint8_t* src, + int width, int height, int rowBytes) { +#ifndef SK_IGNORE_ETC1_SUPPORT + return 0 == etc1_encode_image(src, width, height, 2, rowBytes, dst); +#else + return false; +#endif +} + //////////////////////////////////////////////////////////////////////////////// namespace SkTextureCompressor { @@ -35,8 +49,9 @@ void GetBlockDimensions(Format format, int* dimX, int* dimY, bool matchSpec) { default: SkDEBUGFAIL("Unknown compression format!"); // fall through - case kR11_EAC_Format: case kLATC_Format: + case kR11_EAC_Format: + case kETC1_Format: *dimX = 4; *dimY = 4; break; @@ -57,8 +72,9 @@ int GetCompressedDataSize(Format fmt, int width, int height) { switch (fmt) { // These formats are 64 bits per 4x4 block. - case kR11_EAC_Format: case kLATC_Format: + case kR11_EAC_Format: + case kETC1_Format: encodedBlockSize = 8; break; @@ -110,6 +126,19 @@ bool CompressBufferToFormat(uint8_t* dst, const uint8_t* src, SkColorType srcCol } break; + case kRGB_565_SkColorType: + { + switch (format) { + case kETC1_Format: + proc = compress_etc1_565; + break; + default: + // Do nothing... + break; + } + } + break; + default: // Do nothing... break; @@ -179,9 +208,17 @@ bool DecompressBufferFromFormat(uint8_t* dst, int dstRowBytes, const uint8_t* sr DecompressR11EAC(dst, dstRowBytes, src, width, height); return true; +#ifndef SK_IGNORE_ETC1_SUPPORT + case kETC1_Format: + return 0 == etc1_decode_image(src, dst, width, height, 3, dstRowBytes); +#endif case kASTC_12x12_Format: // TODO(krajcevski) .. right now just fall through and return false. return false; + + default: + // Do nothing... + break; } return false; diff --git a/src/utils/SkTextureCompressor.h b/src/utils/SkTextureCompressor.h index eac8c5eea3..4254ae76fb 100644 --- a/src/utils/SkTextureCompressor.h +++ b/src/utils/SkTextureCompressor.h @@ -18,9 +18,18 @@ namespace SkTextureCompressor { // Various texture compression formats that we support. enum Format { // Alpha only formats. - kLATC_Format, // 4x4 blocks, compresses A8 - kR11_EAC_Format, // 4x4 blocks, compresses A8 - kASTC_12x12_Format, // 12x12 blocks, compresses A8 + kLATC_Format, // 4x4 blocks, (de)compresses A8 + kR11_EAC_Format, // 4x4 blocks, (de)compresses A8 + + // RGB only formats + kETC1_Format, // 4x4 blocks, compresses RGB 565, decompresses 8-bit RGB + // NOTE: ETC1 supports 8-bit RGB compression, but we + // currently don't have any RGB8 SkColorTypes. We could + // support 8-bit RGBA but we would have to preprocess the + // bitmap to insert alphas. + + // Multi-purpose formats + kASTC_12x12_Format, // 12x12 blocks, compresses A8, decompresses RGBA kLast_Format = kASTC_12x12_Format }; @@ -48,11 +57,7 @@ namespace SkTextureCompressor { // destination buffer. The width and height of the data passed corresponds // to the width and height of the uncompressed image. The destination buffer (dst) // is assumed to be large enough to hold the entire decompressed image. The - // decompressed image colors are determined based on the passed format: - // - // LATC -> Alpha 8 - // R11_EAC -> Alpha 8 - // ASTC -> RGBA + // decompressed image colors are determined based on the passed format. // // Note, CompressBufferToFormat compresses A8 data into ASTC. However, // general ASTC data encodes RGBA data, so that is what the decompressor |