Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(49)

Side by Side Diff: src/utils/SkTextureCompressor.h

Issue 1273103002: Port SkTextureCompression opts to SkOpts (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: update include_dirs Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/opts/SkTextureCompressor_opts.h ('k') | src/utils/SkTextureCompressor.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
OLDNEW
« no previous file with comments | « src/opts/SkTextureCompressor_opts.h ('k') | src/utils/SkTextureCompressor.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698