| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #ifndef SkTextureCompressor_DEFINED | 8 #ifndef SkTextureCompressor_DEFINED |
| 9 #define SkTextureCompressor_DEFINED | 9 #define SkTextureCompressor_DEFINED |
| 10 | 10 |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 48 kLast_Format = kASTC_12x12_Format | 48 kLast_Format = kASTC_12x12_Format |
| 49 }; | 49 }; |
| 50 static const int kFormatCnt = kLast_Format + 1; | 50 static const int kFormatCnt = kLast_Format + 1; |
| 51 | 51 |
| 52 // Returns the size of the compressed data given the width, height, and | 52 // Returns the size of the compressed data given the width, height, and |
| 53 // desired compression format. If the width and height are not an appropriat
e | 53 // desired compression format. If the width and height are not an appropriat
e |
| 54 // multiple of the block size, then this function returns an error (-1). | 54 // multiple of the block size, then this function returns an error (-1). |
| 55 int GetCompressedDataSize(Format fmt, int width, int height); | 55 int GetCompressedDataSize(Format fmt, int width, int height); |
| 56 | 56 |
| 57 // Returns an SkData holding a blob of compressed data that corresponds | 57 // Returns an SkData holding a blob of compressed data that corresponds |
| 58 // to the pixmap. If the pixmap colorType cannot be compressed using the | 58 // to the pixmap. If the pixmap colorType cannot be compressed using the |
| 59 // associated format, then we return NULL. The caller is responsible for | 59 // associated format, then we return NULL. The caller is responsible for |
| 60 // calling unref() on the returned data. | 60 // calling unref() on the returned data. |
| 61 SkData* CompressBitmapToFormat(const SkPixmap&, Format format); | 61 SkData* CompressBitmapToFormat(const SkPixmap&, Format format); |
| 62 | 62 |
| 63 // Compresses the given src data into dst. The src data is assumed to be | 63 // Compresses the given src data into dst. The src data is assumed to be |
| 64 // large enough to hold width*height pixels. The dst data is expected to | 64 // large enough to hold width*height pixels. The dst data is expected to |
| 65 // be large enough to hold the compressed data according to the format. | 65 // be large enough to hold the compressed data according to the format. |
| 66 bool CompressBufferToFormat(uint8_t* dst, const uint8_t* src, SkColorType sr
cColorType, | 66 bool CompressBufferToFormat(uint8_t* dst, const uint8_t* src, SkColorType sr
cColorType, |
| 67 int width, int height, size_t rowBytes, Format f
ormat, | 67 int width, int height, size_t rowBytes, Format f
ormat); |
| 68 bool opt = true /* Use optimization if available
*/); | |
| 69 | 68 |
| 70 // Decompresses the given src data from the format specified into the | 69 // Decompresses the given src data from the format specified into the |
| 71 // destination buffer. The width and height of the data passed corresponds | 70 // destination buffer. The width and height of the data passed corresponds |
| 72 // to the width and height of the uncompressed image. The destination buffer
(dst) | 71 // to the width and height of the uncompressed image. The destination buffer
(dst) |
| 73 // is assumed to be large enough to hold the entire decompressed image. The | 72 // is assumed to be large enough to hold the entire decompressed image. The |
| 74 // decompressed image colors are determined based on the passed format. | 73 // decompressed image colors are determined based on the passed format. |
| 75 // | 74 // |
| 76 // Note, CompressBufferToFormat compresses A8 data into ASTC. However, | 75 // Note, CompressBufferToFormat compresses A8 data into ASTC. However, |
| 77 // general ASTC data encodes RGBA data, so that is what the decompressor | 76 // general ASTC data encodes RGBA data, so that is what the decompressor |
| 78 // operates on. | 77 // operates on. |
| 79 // | 78 // |
| 80 // Returns true if successfully decompresses the src data. | 79 // Returns true if successfully decompresses the src data. |
| 81 bool DecompressBufferFromFormat(uint8_t* dst, int dstRowBytes, const uint8_t
* src, | 80 bool DecompressBufferFromFormat(uint8_t* dst, int dstRowBytes, const uint8_t
* src, |
| 82 int width, int height, Format format); | 81 int width, int height, Format format); |
| 83 | 82 |
| 84 // This typedef defines what the nominal aspects of a compression function | |
| 85 // are. The typedef is not meant to be used by clients of the API, but rathe
r | |
| 86 // allows SIMD optimized compression functions to be implemented. | |
| 87 typedef bool (*CompressionProc)(uint8_t* dst, const uint8_t* src, | |
| 88 int width, int height, size_t rowBytes); | |
| 89 | |
| 90 // Returns true if there exists a blitter for the specified format. | 83 // Returns true if there exists a blitter for the specified format. |
| 91 inline bool ExistsBlitterForFormat(Format format) { | 84 inline bool ExistsBlitterForFormat(Format format) { |
| 92 switch (format) { | 85 switch (format) { |
| 93 case kLATC_Format: | 86 case kLATC_Format: |
| 94 case kR11_EAC_Format: | 87 case kR11_EAC_Format: |
| 95 case kASTC_12x12_Format: | 88 case kASTC_12x12_Format: |
| 96 return true; | 89 return true; |
| 97 | 90 |
| 98 default: | 91 default: |
| 99 return false; | 92 return false; |
| 100 } | 93 } |
| 101 } | 94 } |
| 102 | 95 |
| 103 // Returns the blitter for the given compression format. Note, the blitter | 96 // Returns the blitter for the given compression format. Note, the blitter |
| 104 // is intended to be used with the proper input. I.e. if you try to blit | 97 // is intended to be used with the proper input. I.e. if you try to blit |
| 105 // RGB source data into an R11 EAC texture, you're gonna have a bad time. | 98 // RGB source data into an R11 EAC texture, you're gonna have a bad time. |
| 106 SkBlitter* CreateBlitterForFormat(int width, int height, void* compressedBuf
fer, | 99 SkBlitter* CreateBlitterForFormat(int width, int height, void* compressedBuf
fer, |
| 107 SkTBlitterAllocator *allocator, Format for
mat); | 100 SkTBlitterAllocator *allocator, Format for
mat); |
| 108 | 101 |
| 109 // Returns the desired dimensions of the block size for the given format. Th
ese dimensions | 102 // Returns the desired dimensions of the block size for the given format. Th
ese dimensions |
| 110 // don't necessarily correspond to the specification's dimensions, since the
re may | 103 // don't necessarily correspond to the specification's dimensions, since the
re may |
| 111 // be specialized algorithms that operate on multiple blocks at once. If the | 104 // be specialized algorithms that operate on multiple blocks at once. If the |
| 112 // flag 'matchSpec' is true, then the actual dimensions from the specificati
on are | 105 // flag 'matchSpec' is true, then the actual dimensions from the specificati
on are |
| 113 // returned. If the flag is false, then these dimensions reflect the appropr
iate operable | 106 // returned. If the flag is false, then these dimensions reflect the appropr
iate operable |
| 114 // dimensions of the compression functions. | 107 // dimensions of the compression functions. |
| 115 void GetBlockDimensions(Format format, int* dimX, int* dimY, bool matchSpec
= false); | 108 void GetBlockDimensions(Format format, int* dimX, int* dimY, bool matchSpec
= false); |
| 116 } | 109 } |
| 117 | 110 |
| 118 #endif | 111 #endif |
| OLD | NEW |