OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2010 Google Inc. | 2 * Copyright 2010 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 #include "SkImageInfo.h" | 8 #include "SkImageInfo.h" |
9 #include "SkImageInfoPriv.h" | 9 #include "SkImageInfoPriv.h" |
10 #include "SkReadBuffer.h" | 10 #include "SkReadBuffer.h" |
11 #include "SkWriteBuffer.h" | 11 #include "SkWriteBuffer.h" |
12 | 12 |
| 13 /* |
| 14 * We store this as a byte in the ImageInfo flatten buffer. |
| 15 */ |
| 16 enum class SkFlattenColorSpaceEnum { |
| 17 kUnspecified, |
| 18 kSRGB, |
| 19 kAdobe1998, |
| 20 // ... add more here |
| 21 kLastEnum = kAdobe1998, |
| 22 // final value means the actual profile data follows the info |
| 23 kICCProfile = 0xFF, |
| 24 }; |
| 25 |
| 26 static sk_sp<SkColorSpace> make_from_enum(SkFlattenColorSpaceEnum value) { |
| 27 switch (value) { |
| 28 case SkFlattenColorSpaceEnum::kSRGB: |
| 29 return SkColorSpace::NewNamed(SkColorSpace::kSRGB_Named); |
| 30 case SkFlattenColorSpaceEnum::kAdobe1998: |
| 31 return SkColorSpace::NewNamed(SkColorSpace::kAdobeRGB_Named); |
| 32 default: |
| 33 return nullptr; |
| 34 } |
| 35 } |
| 36 |
| 37 SkColorSpace::Named sk_deduce_named_from_colorspace(SkColorSpace* cs) { |
| 38 return cs->fNamed; |
| 39 } |
| 40 |
| 41 static SkFlattenColorSpaceEnum deduce_from_colorspace(SkColorSpace* cs) { |
| 42 if (!cs) { |
| 43 return SkFlattenColorSpaceEnum::kUnspecified; |
| 44 } |
| 45 switch (sk_deduce_named_from_colorspace(cs)) { |
| 46 case SkColorSpace::kSRGB_Named: |
| 47 return SkFlattenColorSpaceEnum::kSRGB; |
| 48 case SkColorSpace::kAdobeRGB_Named: |
| 49 return SkFlattenColorSpaceEnum::kAdobe1998; |
| 50 default: |
| 51 return SkFlattenColorSpaceEnum::kICCProfile; |
| 52 } |
| 53 } |
| 54 |
| 55 ////////////////////////////////////////////////////////////////////////////////
/////////////////// |
| 56 |
| 57 #ifdef SK_SUPPORT_LEGACY_COLORPROFILETYPE |
| 58 SkColorProfileType SkImageInfo::profileType() const { |
| 59 return fColorSpace && fColorSpace->gammaCloseToSRGB() |
| 60 ? kSRGB_SkColorProfileType : kLinear_SkColorProfileType; |
| 61 } |
| 62 #endif |
| 63 |
13 // Indicate how images and gradients should interpret colors by default. | 64 // Indicate how images and gradients should interpret colors by default. |
14 bool gDefaultProfileIsSRGB; | 65 bool gDefaultProfileIsSRGB; |
15 | 66 |
16 SkColorProfileType SkDefaultColorProfile() { | 67 SkColorProfileType SkDefaultColorProfile() { |
17 return gDefaultProfileIsSRGB ? kSRGB_SkColorProfileType | 68 return gDefaultProfileIsSRGB ? kSRGB_SkColorProfileType |
18 : kLinear_SkColorProfileType; | 69 : kLinear_SkColorProfileType; |
19 } | 70 } |
20 | 71 |
21 static bool profile_type_is_valid(SkColorProfileType profileType) { | |
22 return (profileType >= 0) && (profileType <= kLastEnum_SkColorProfileType); | |
23 } | |
24 | |
25 static bool alpha_type_is_valid(SkAlphaType alphaType) { | 72 static bool alpha_type_is_valid(SkAlphaType alphaType) { |
26 return (alphaType >= 0) && (alphaType <= kLastEnum_SkAlphaType); | 73 return (alphaType >= 0) && (alphaType <= kLastEnum_SkAlphaType); |
27 } | 74 } |
28 | 75 |
29 static bool color_type_is_valid(SkColorType colorType) { | 76 static bool color_type_is_valid(SkColorType colorType) { |
30 return (colorType >= 0) && (colorType <= kLastEnum_SkColorType); | 77 return (colorType >= 0) && (colorType <= kLastEnum_SkColorType); |
31 } | 78 } |
32 | 79 |
33 SkImageInfo SkImageInfo::Make(int width, int height, SkColorType ct, SkAlphaType
at, | |
34 sk_sp<SkColorSpace> cs) { | |
35 SkColorProfileType pt = SkDefaultColorProfile(); | |
36 // try to keep the enum and the colorspace in sync. | |
37 // TODO: eliminate the enum entirely, now that we have colorspace objects | |
38 if (cs && (SkColorSpace::kLinear_GammaNamed != cs->gammaNamed())) { | |
39 pt = kSRGB_SkColorProfileType; | |
40 } | |
41 return SkImageInfo(width, height, ct, at, pt, std::move(cs)); | |
42 } | |
43 | |
44 SkImageInfo SkImageInfo::MakeS32(int width, int height, SkAlphaType at) { | 80 SkImageInfo SkImageInfo::MakeS32(int width, int height, SkAlphaType at) { |
45 return SkImageInfo(width, height, kN32_SkColorType, at, kSRGB_SkColorProfile
Type, | 81 return SkImageInfo(width, height, kN32_SkColorType, at, |
46 SkColorSpace::NewNamed(SkColorSpace::kSRGB_Named)); | 82 SkColorSpace::NewNamed(SkColorSpace::kSRGB_Named)); |
47 } | 83 } |
48 | 84 |
49 void SkImageInfo::unflatten(SkReadBuffer& buffer) { | 85 void SkImageInfo::unflatten(SkReadBuffer& buffer) { |
50 fWidth = buffer.read32(); | 86 fWidth = buffer.read32(); |
51 fHeight = buffer.read32(); | 87 fHeight = buffer.read32(); |
52 | 88 |
53 uint32_t packed = buffer.read32(); | 89 uint32_t packed = buffer.read32(); |
54 SkASSERT(0 == (packed >> 24)); | 90 SkASSERT(0 == (packed >> 24)); |
55 fProfileType = (SkColorProfileType)((packed >> 16) & 0xFF); | 91 fColorType = (SkColorType)((packed >> 0) & 0xFF); |
56 fAlphaType = (SkAlphaType)((packed >> 8) & 0xFF); | 92 fAlphaType = (SkAlphaType)((packed >> 8) & 0xFF); |
57 fColorType = (SkColorType)((packed >> 0) & 0xFF); | 93 SkFlattenColorSpaceEnum csenum = (SkFlattenColorSpaceEnum)((packed >> 16) &
0xFF); |
58 buffer.validate(profile_type_is_valid(fProfileType) && | 94 buffer.validate(alpha_type_is_valid(fAlphaType) && color_type_is_valid(fColo
rType)); |
59 alpha_type_is_valid(fAlphaType) && | 95 |
60 color_type_is_valid(fColorType)); | 96 if (SkFlattenColorSpaceEnum::kICCProfile == csenum) { |
| 97 SkASSERT(false); // we shouldn't hit this yet, as we don't write thes
e yet |
| 98 fColorSpace.reset(); |
| 99 } else { |
| 100 if (csenum > SkFlattenColorSpaceEnum::kLastEnum) { |
| 101 csenum = SkFlattenColorSpaceEnum::kUnspecified; |
| 102 } |
| 103 fColorSpace = make_from_enum(csenum); |
| 104 } |
61 } | 105 } |
62 | 106 |
63 void SkImageInfo::flatten(SkWriteBuffer& buffer) const { | 107 void SkImageInfo::flatten(SkWriteBuffer& buffer) const { |
64 buffer.write32(fWidth); | 108 buffer.write32(fWidth); |
65 buffer.write32(fHeight); | 109 buffer.write32(fHeight); |
66 | 110 |
67 SkASSERT(0 == (fProfileType & ~0xFF)); | 111 SkFlattenColorSpaceEnum csenum = deduce_from_colorspace(fColorSpace.get()); |
| 112 |
| 113 // TODO: when we actually support flattening the colorspace to a profile blo
b, remove this |
| 114 // hack (and write the blob after we write packed. |
| 115 if (SkFlattenColorSpaceEnum::kICCProfile == csenum) { |
| 116 csenum = SkFlattenColorSpaceEnum::kUnspecified; |
| 117 } |
| 118 |
| 119 SkASSERT(0 == ((int)csenum & ~0xFF)); |
68 SkASSERT(0 == (fAlphaType & ~0xFF)); | 120 SkASSERT(0 == (fAlphaType & ~0xFF)); |
69 SkASSERT(0 == (fColorType & ~0xFF)); | 121 SkASSERT(0 == (fColorType & ~0xFF)); |
70 uint32_t packed = (fProfileType << 16) | (fAlphaType << 8) | fColorType; | 122 uint32_t packed = ((int)csenum << 16) | (fAlphaType << 8) | fColorType; |
71 buffer.write32(packed); | 123 buffer.write32(packed); |
| 124 |
| 125 if (SkFlattenColorSpaceEnum::kICCProfile == csenum) { |
| 126 // TODO: write the ICCProfile blob |
| 127 } |
72 } | 128 } |
73 | 129 |
74 bool SkColorTypeValidateAlphaType(SkColorType colorType, SkAlphaType alphaType, | 130 bool SkColorTypeValidateAlphaType(SkColorType colorType, SkAlphaType alphaType, |
75 SkAlphaType* canonical) { | 131 SkAlphaType* canonical) { |
76 switch (colorType) { | 132 switch (colorType) { |
77 case kUnknown_SkColorType: | 133 case kUnknown_SkColorType: |
78 alphaType = kUnknown_SkAlphaType; | 134 alphaType = kUnknown_SkAlphaType; |
79 break; | 135 break; |
80 case kAlpha_8_SkColorType: | 136 case kAlpha_8_SkColorType: |
81 if (kUnpremul_SkAlphaType == alphaType) { | 137 if (kUnpremul_SkAlphaType == alphaType) { |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
139 } | 195 } |
140 // here x,y are either 0 or negative | 196 // here x,y are either 0 or negative |
141 fPixels = ((char*)fPixels - y * fRowBytes - x * fInfo.bytesPerPixel()); | 197 fPixels = ((char*)fPixels - y * fRowBytes - x * fInfo.bytesPerPixel()); |
142 // the intersect may have shrunk info's logical size | 198 // the intersect may have shrunk info's logical size |
143 fInfo = fInfo.makeWH(srcR.width(), srcR.height()); | 199 fInfo = fInfo.makeWH(srcR.width(), srcR.height()); |
144 fX = srcR.x(); | 200 fX = srcR.x(); |
145 fY = srcR.y(); | 201 fY = srcR.y(); |
146 | 202 |
147 return true; | 203 return true; |
148 } | 204 } |
OLD | NEW |