1 | /* |
2 | * Copyright 2019 Google Inc. |
3 | * |
4 | * Use of this source code is governed by a BSD-style license that can be |
5 | * found in the LICENSE file. |
6 | */ |
7 | |
8 | #ifndef GrDataUtils_DEFINED |
9 | #define GrDataUtils_DEFINED |
10 | |
11 | #include "include/core/SkColor.h" |
12 | #include "include/private/GrTypesPriv.h" |
13 | #include "src/gpu/GrColorInfo.h" |
14 | #include "src/gpu/GrSwizzle.h" |
15 | |
16 | class GrImageInfo; |
17 | |
18 | // Returns a value that can be used to set rowBytes for a transfer function. |
19 | size_t GrCompressedRowBytes(SkImage::CompressionType, int w); |
20 | |
21 | // Return the pixel dimensions of a compressed texture. The topmost levels |
22 | // of a compressed mipmapped texture (i.e., 1x1 or 2x2) still occupy a full |
23 | // block and thus objectively take up more pixels (e.g., 4x4 pixels for ETC1). |
24 | SkISize GrCompressedDimensions(SkImage::CompressionType, SkISize baseDimensions); |
25 | |
26 | // Compute the size of the buffer required to hold all the mipLevels of the specified type |
27 | // of data when all rowBytes are tight. |
28 | // Note there may still be padding between the mipLevels to meet alignment requirements. |
29 | size_t GrComputeTightCombinedBufferSize(size_t bytesPerPixel, SkISize baseDimensions, |
30 | SkTArray<size_t>* individualMipOffsets, int mipLevelCount); |
31 | |
32 | void GrFillInCompressedData(SkImage::CompressionType, SkISize dimensions, GrMipmapped, char* dest, |
33 | const SkColor4f& color); |
34 | |
35 | // Swizzle param is applied after loading and before converting from srcInfo to dstInfo. |
36 | bool GrConvertPixels(const GrImageInfo& dstInfo, void* dst, size_t dstRB, |
37 | const GrImageInfo& srcInfo, const void* src, size_t srcRB, |
38 | bool flipY = false); |
39 | |
40 | /** Clears the dst image to a constant color. */ |
41 | bool GrClearImage(const GrImageInfo& dstInfo, void* dst, size_t dstRB, SkColor4f color); |
42 | |
43 | #if GR_TEST_UTILS |
44 | /** |
45 | * BC1 compress an image that contains only either opaque black or transparent black and one |
46 | * other color. |
47 | * opaque pixmaps -> kBC1_RGB8_UNORM |
48 | * transparent pixmaps -> kBC1_RGBA8_UNORM |
49 | */ |
50 | void GrTwoColorBC1Compress(const SkPixmap& pixmap, SkColor otherColor, char* dstPixels); |
51 | #endif |
52 | |
53 | #endif |
54 | |