reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2013 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 SkImageInfo_DEFINED |
| 9 | #define SkImageInfo_DEFINED |
| 10 | |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 11 | #include "SkMath.h" |
halcanary | f622a6c | 2014-10-24 12:54:53 -0700 | [diff] [blame^] | 12 | #include "SkRect.h" |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 13 | #include "SkSize.h" |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 14 | |
commit-bot@chromium.org | 8b0e8ac | 2014-01-30 18:58:24 +0000 | [diff] [blame] | 15 | class SkReadBuffer; |
halcanary | f622a6c | 2014-10-24 12:54:53 -0700 | [diff] [blame^] | 16 | class SkWriteBuffer; |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 17 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 18 | /** |
| 19 | * Describes how to interpret the alpha compoent of a pixel. |
| 20 | */ |
| 21 | enum SkAlphaType { |
| 22 | /** |
| 23 | * All pixels should be treated as opaque, regardless of the value stored |
| 24 | * in their alpha field. Used for legacy images that wrote 0 or garbarge |
| 25 | * in their alpha field, but intended the RGB to be treated as opaque. |
| 26 | */ |
| 27 | kIgnore_SkAlphaType, |
skia.committer@gmail.com | 73a5d53 | 2013-11-14 07:02:31 +0000 | [diff] [blame] | 28 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 29 | /** |
| 30 | * All pixels are stored as opaque. This differs slightly from kIgnore in |
| 31 | * that kOpaque has correct "opaque" values stored in the pixels, while |
| 32 | * kIgnore may not, but in both cases the caller should treat the pixels |
| 33 | * as opaque. |
| 34 | */ |
| 35 | kOpaque_SkAlphaType, |
skia.committer@gmail.com | 73a5d53 | 2013-11-14 07:02:31 +0000 | [diff] [blame] | 36 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 37 | /** |
| 38 | * All pixels have their alpha premultiplied in their color components. |
| 39 | * This is the natural format for the rendering target pixels. |
| 40 | */ |
| 41 | kPremul_SkAlphaType, |
skia.committer@gmail.com | 73a5d53 | 2013-11-14 07:02:31 +0000 | [diff] [blame] | 42 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 43 | /** |
| 44 | * All pixels have their color components stored without any regard to the |
| 45 | * alpha. e.g. this is the default configuration for PNG images. |
| 46 | * |
| 47 | * This alpha-type is ONLY supported for input images. Rendering cannot |
| 48 | * generate this on output. |
| 49 | */ |
| 50 | kUnpremul_SkAlphaType, |
skia.committer@gmail.com | 73a5d53 | 2013-11-14 07:02:31 +0000 | [diff] [blame] | 51 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 52 | kLastEnum_SkAlphaType = kUnpremul_SkAlphaType |
| 53 | }; |
| 54 | |
| 55 | static inline bool SkAlphaTypeIsOpaque(SkAlphaType at) { |
| 56 | SK_COMPILE_ASSERT(kIgnore_SkAlphaType < kOpaque_SkAlphaType, bad_alphatype_order); |
| 57 | SK_COMPILE_ASSERT(kPremul_SkAlphaType > kOpaque_SkAlphaType, bad_alphatype_order); |
| 58 | SK_COMPILE_ASSERT(kUnpremul_SkAlphaType > kOpaque_SkAlphaType, bad_alphatype_order); |
| 59 | |
| 60 | return (unsigned)at <= kOpaque_SkAlphaType; |
| 61 | } |
| 62 | |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 63 | static inline bool SkAlphaTypeIsValid(unsigned value) { |
| 64 | return value <= kLastEnum_SkAlphaType; |
| 65 | } |
| 66 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 67 | /////////////////////////////////////////////////////////////////////////////// |
| 68 | |
| 69 | /** |
| 70 | * Describes how to interpret the components of a pixel. |
reed | 6c6ddb8 | 2014-06-30 12:44:03 -0700 | [diff] [blame] | 71 | * |
| 72 | * kN32_SkColorType is an alias for whichever 32bit ARGB format is the "native" |
| 73 | * form for skia's blitters. Use this if you don't have a swizzle preference |
| 74 | * for 32bit pixels. |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 75 | */ |
| 76 | enum SkColorType { |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 77 | kUnknown_SkColorType, |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 78 | kAlpha_8_SkColorType, |
| 79 | kRGB_565_SkColorType, |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 80 | kARGB_4444_SkColorType, |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 81 | kRGBA_8888_SkColorType, |
| 82 | kBGRA_8888_SkColorType, |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 83 | kIndex_8_SkColorType, |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 84 | |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 85 | kLastEnum_SkColorType = kIndex_8_SkColorType, |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 86 | |
| 87 | #if SK_PMCOLOR_BYTE_ORDER(B,G,R,A) |
commit-bot@chromium.org | 28fcae2 | 2014-04-11 17:15:40 +0000 | [diff] [blame] | 88 | kN32_SkColorType = kBGRA_8888_SkColorType, |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 89 | #elif SK_PMCOLOR_BYTE_ORDER(R,G,B,A) |
commit-bot@chromium.org | 28fcae2 | 2014-04-11 17:15:40 +0000 | [diff] [blame] | 90 | kN32_SkColorType = kRGBA_8888_SkColorType, |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 91 | #else |
| 92 | #error "SK_*32_SHFIT values must correspond to BGRA or RGBA byte order" |
| 93 | #endif |
commit-bot@chromium.org | 28fcae2 | 2014-04-11 17:15:40 +0000 | [diff] [blame] | 94 | |
| 95 | #ifdef SK_SUPPORT_LEGACY_N32_NAME |
| 96 | kPMColor_SkColorType = kN32_SkColorType |
| 97 | #endif |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 98 | }; |
| 99 | |
| 100 | static int SkColorTypeBytesPerPixel(SkColorType ct) { |
| 101 | static const uint8_t gSize[] = { |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 102 | 0, // Unknown |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 103 | 1, // Alpha_8 |
| 104 | 2, // RGB_565 |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 105 | 2, // ARGB_4444 |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 106 | 4, // RGBA_8888 |
| 107 | 4, // BGRA_8888 |
| 108 | 1, // kIndex_8 |
| 109 | }; |
| 110 | SK_COMPILE_ASSERT(SK_ARRAY_COUNT(gSize) == (size_t)(kLastEnum_SkColorType + 1), |
| 111 | size_mismatch_with_SkColorType_enum); |
| 112 | |
| 113 | SkASSERT((size_t)ct < SK_ARRAY_COUNT(gSize)); |
| 114 | return gSize[ct]; |
| 115 | } |
| 116 | |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 117 | static inline size_t SkColorTypeMinRowBytes(SkColorType ct, int width) { |
| 118 | return width * SkColorTypeBytesPerPixel(ct); |
| 119 | } |
| 120 | |
| 121 | static inline bool SkColorTypeIsValid(unsigned value) { |
| 122 | return value <= kLastEnum_SkColorType; |
| 123 | } |
| 124 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 125 | /////////////////////////////////////////////////////////////////////////////// |
| 126 | |
| 127 | /** |
scroggo | 2fd0d14 | 2014-07-01 07:08:19 -0700 | [diff] [blame] | 128 | * Return true if alphaType is supported by colorType. If there is a canonical |
| 129 | * alphaType for this colorType, return it in canonical. |
| 130 | */ |
| 131 | bool SkColorTypeValidateAlphaType(SkColorType colorType, SkAlphaType alphaType, |
| 132 | SkAlphaType* canonical = NULL); |
| 133 | |
| 134 | /////////////////////////////////////////////////////////////////////////////// |
| 135 | |
| 136 | /** |
rileya | abaef86 | 2014-09-12 17:45:58 -0700 | [diff] [blame] | 137 | * Describes the color space a YUV pixel. |
| 138 | */ |
| 139 | enum SkYUVColorSpace { |
| 140 | /** Standard JPEG color space. */ |
| 141 | kJPEG_SkYUVColorSpace, |
| 142 | /** SDTV standard Rec. 601 color space. Uses "studio swing" [16, 235] color |
| 143 | range. See http://en.wikipedia.org/wiki/Rec._601 for details. */ |
| 144 | kRec601_SkYUVColorSpace, |
| 145 | |
| 146 | kLastEnum_SkYUVColorSpace = kRec601_SkYUVColorSpace |
| 147 | }; |
| 148 | |
| 149 | /////////////////////////////////////////////////////////////////////////////// |
| 150 | |
| 151 | /** |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 152 | * Describe an image's dimensions and pixel type. |
| 153 | */ |
reed | 2bdf1f5 | 2014-09-03 05:48:56 -0700 | [diff] [blame] | 154 | struct SkImageInfo { |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 155 | public: |
| 156 | SkImageInfo() |
| 157 | : fWidth(0) |
| 158 | , fHeight(0) |
| 159 | , fColorType(kUnknown_SkColorType) |
| 160 | , fAlphaType(kIgnore_SkAlphaType) |
| 161 | {} |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 162 | |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 163 | static SkImageInfo Make(int width, int height, SkColorType ct, SkAlphaType at) { |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 164 | return SkImageInfo(width, height, ct, at); |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 165 | } |
| 166 | |
| 167 | /** |
| 168 | * Sets colortype to the native ARGB32 type. |
| 169 | */ |
| 170 | static SkImageInfo MakeN32(int width, int height, SkAlphaType at) { |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 171 | return SkImageInfo(width, height, kN32_SkColorType, at); |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 172 | } |
| 173 | |
| 174 | /** |
| 175 | * Sets colortype to the native ARGB32 type, and the alphatype to premul. |
| 176 | */ |
| 177 | static SkImageInfo MakeN32Premul(int width, int height) { |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 178 | return SkImageInfo(width, height, kN32_SkColorType, kPremul_SkAlphaType); |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 179 | } |
skia.committer@gmail.com | d77b3ec | 2014-01-15 07:01:43 +0000 | [diff] [blame] | 180 | |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 181 | /** |
| 182 | * Sets colortype to the native ARGB32 type, and the alphatype to premul. |
| 183 | */ |
| 184 | static SkImageInfo MakeN32Premul(const SkISize& size) { |
| 185 | return MakeN32Premul(size.width(), size.height()); |
| 186 | } |
skia.committer@gmail.com | d77b3ec | 2014-01-15 07:01:43 +0000 | [diff] [blame] | 187 | |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 188 | static SkImageInfo MakeA8(int width, int height) { |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 189 | return SkImageInfo(width, height, kAlpha_8_SkColorType, kPremul_SkAlphaType); |
commit-bot@chromium.org | 32678d9 | 2014-01-15 02:38:22 +0000 | [diff] [blame] | 190 | } |
skia.committer@gmail.com | d77b3ec | 2014-01-15 07:01:43 +0000 | [diff] [blame] | 191 | |
reed@google.com | 900ecf2 | 2014-02-20 20:55:37 +0000 | [diff] [blame] | 192 | static SkImageInfo MakeUnknown(int width, int height) { |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 193 | return SkImageInfo(width, height, kUnknown_SkColorType, kIgnore_SkAlphaType); |
reed@google.com | 900ecf2 | 2014-02-20 20:55:37 +0000 | [diff] [blame] | 194 | } |
| 195 | |
reed | f252f64 | 2014-06-14 04:24:56 -0700 | [diff] [blame] | 196 | static SkImageInfo MakeUnknown() { |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 197 | return SkImageInfo(); |
reed | f252f64 | 2014-06-14 04:24:56 -0700 | [diff] [blame] | 198 | } |
| 199 | |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 200 | int width() const { return fWidth; } |
| 201 | int height() const { return fHeight; } |
| 202 | SkColorType colorType() const { return fColorType; } |
| 203 | SkAlphaType alphaType() const { return fAlphaType; } |
| 204 | |
| 205 | bool isEmpty() const { return fWidth <= 0 || fHeight <= 0; } |
| 206 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 207 | bool isOpaque() const { |
| 208 | return SkAlphaTypeIsOpaque(fAlphaType); |
| 209 | } |
| 210 | |
halcanary | f622a6c | 2014-10-24 12:54:53 -0700 | [diff] [blame^] | 211 | SkIRect bounds() const { return SkIRect::MakeWH(fWidth, fHeight); } |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 212 | SkISize dimensions() const { return SkISize::Make(fWidth, fHeight); } |
| 213 | |
reed | c77392e | 2014-06-02 13:07:26 -0700 | [diff] [blame] | 214 | /** |
| 215 | * Return a new ImageInfo with the same colortype and alphatype as this info, |
| 216 | * but with the specified width and height. |
| 217 | */ |
| 218 | SkImageInfo makeWH(int newWidth, int newHeight) const { |
| 219 | return SkImageInfo::Make(newWidth, newHeight, fColorType, fAlphaType); |
| 220 | } |
| 221 | |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 222 | SkImageInfo makeAlphaType(SkAlphaType newAlphaType) const { |
| 223 | return SkImageInfo::Make(fWidth, fHeight, fColorType, newAlphaType); |
| 224 | } |
| 225 | |
| 226 | SkImageInfo makeColorType(SkColorType newColorType) const { |
| 227 | return SkImageInfo::Make(fWidth, fHeight, newColorType, fAlphaType); |
| 228 | } |
| 229 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 230 | int bytesPerPixel() const { |
| 231 | return SkColorTypeBytesPerPixel(fColorType); |
| 232 | } |
| 233 | |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 234 | uint64_t minRowBytes64() const { |
| 235 | return sk_64_mul(fWidth, this->bytesPerPixel()); |
| 236 | } |
| 237 | |
mike@reedtribe.org | 169a0ed | 2014-02-11 02:20:17 +0000 | [diff] [blame] | 238 | size_t minRowBytes() const { |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 239 | return (size_t)this->minRowBytes64(); |
mike@reedtribe.org | 169a0ed | 2014-02-11 02:20:17 +0000 | [diff] [blame] | 240 | } |
skia.committer@gmail.com | 8ed6443 | 2014-02-11 03:02:13 +0000 | [diff] [blame] | 241 | |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 242 | bool operator==(const SkImageInfo& other) const { |
| 243 | return 0 == memcmp(this, &other, sizeof(other)); |
| 244 | } |
| 245 | bool operator!=(const SkImageInfo& other) const { |
| 246 | return 0 != memcmp(this, &other, sizeof(other)); |
| 247 | } |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 248 | |
commit-bot@chromium.org | 8b0e8ac | 2014-01-30 18:58:24 +0000 | [diff] [blame] | 249 | void unflatten(SkReadBuffer&); |
| 250 | void flatten(SkWriteBuffer&) const; |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 251 | |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 252 | int64_t getSafeSize64(size_t rowBytes) const { |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 253 | if (0 == fHeight) { |
| 254 | return 0; |
| 255 | } |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 256 | return sk_64_mul(fHeight - 1, rowBytes) + fWidth * this->bytesPerPixel(); |
reed@google.com | 9230ea2 | 2013-12-09 22:01:03 +0000 | [diff] [blame] | 257 | } |
commit-bot@chromium.org | 61e96cd | 2014-02-11 18:21:45 +0000 | [diff] [blame] | 258 | |
| 259 | size_t getSafeSize(size_t rowBytes) const { |
| 260 | return (size_t)this->getSafeSize64(rowBytes); |
| 261 | } |
| 262 | |
| 263 | bool validRowBytes(size_t rowBytes) const { |
| 264 | uint64_t rb = sk_64_mul(fWidth, this->bytesPerPixel()); |
| 265 | return rowBytes >= rb; |
| 266 | } |
| 267 | |
| 268 | SkDEBUGCODE(void validate() const;) |
reed | e5ea500 | 2014-09-03 11:54:58 -0700 | [diff] [blame] | 269 | |
| 270 | #ifdef SK_SUPPORT_LEGACY_PUBLIC_IMAGEINFO_FIELDS |
| 271 | public: |
| 272 | #else |
| 273 | private: |
| 274 | #endif |
| 275 | int fWidth; |
| 276 | int fHeight; |
| 277 | SkColorType fColorType; |
| 278 | SkAlphaType fAlphaType; |
| 279 | |
| 280 | private: |
| 281 | SkImageInfo(int width, int height, SkColorType ct, SkAlphaType at) |
| 282 | : fWidth(width) |
| 283 | , fHeight(height) |
| 284 | , fColorType(ct) |
| 285 | , fAlphaType(at) |
| 286 | {} |
reed@google.com | 3443fd8 | 2013-11-13 19:09:13 +0000 | [diff] [blame] | 287 | }; |
| 288 | |
| 289 | #endif |