OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 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 "SkCodecPriv.h" | 8 #include "SkCodecPriv.h" |
9 #include "SkMasks.h" | 9 #include "SkMasks.h" |
10 #include "SkTypes.h" | 10 #include "SkTypes.h" |
(...skipping 29 matching lines...) Expand all Loading... | |
40 173, 175, 177, 179, 181, 183, 185, 187, 189, 191, 193, 195, 197, 199, 201, | 40 173, 175, 177, 179, 181, 183, 185, 187, 189, 191, 193, 195, 197, 199, 201, |
41 203, 205, 207, 209, 211, 213, 215, 217, 219, 221, 223, 225, 227, 229, 231, | 41 203, 205, 207, 209, 211, 213, 215, 217, 219, 221, 223, 225, 227, 229, 231, |
42 233, 235, 237, 239, 241, 243, 245, 247, 249, 251, 253, 255 | 42 233, 235, 237, 239, 241, 243, 245, 247, 249, 251, 253, 255 |
43 }; | 43 }; |
44 | 44 |
45 /* | 45 /* |
46 * | 46 * |
47 * Convert an n bit component to an 8-bit component | 47 * Convert an n bit component to an 8-bit component |
48 * | 48 * |
49 */ | 49 */ |
50 static uint8_t convert_to_8(uint32_t component, uint32_t n) { | 50 static uint8_t convert_to_8(uint8_t component, uint32_t n) { |
msarett
2016/02/10 20:59:28
No reason for "component" to ever be larger than 8
| |
51 if (0 == n) { | 51 if (0 == n) { |
52 return 0; | 52 return 0; |
53 } else if (8 > n) { | 53 } else if (8 > n) { |
54 return n_bit_to_8_bit_lookup_table[(1 << n) - 2 + component]; | 54 return n_bit_to_8_bit_lookup_table[(1 << n) - 2 + component]; |
55 } else { | 55 } else { |
56 SkASSERT(8 == n); | 56 SkASSERT(8 == n); |
57 return component; | 57 return component; |
58 } | 58 } |
59 } | 59 } |
60 | 60 |
(...skipping 19 matching lines...) Expand all Loading... | |
80 uint8_t SkMasks::getAlpha(uint32_t pixel) const { | 80 uint8_t SkMasks::getAlpha(uint32_t pixel) const { |
81 return get_comp(pixel, fAlpha.mask, fAlpha.shift, fAlpha.size); | 81 return get_comp(pixel, fAlpha.mask, fAlpha.shift, fAlpha.size); |
82 } | 82 } |
83 | 83 |
84 /* | 84 /* |
85 * | 85 * |
86 * Process an input mask to obtain the necessary information | 86 * Process an input mask to obtain the necessary information |
87 * | 87 * |
88 */ | 88 */ |
89 const SkMasks::MaskInfo process_mask(uint32_t mask, uint32_t bpp) { | 89 const SkMasks::MaskInfo process_mask(uint32_t mask, uint32_t bpp) { |
90 // Trim the masks to the allowed number of bits | |
msarett
2016/02/10 20:59:28
Unrelated to the bug fix. We do this is CreateMas
| |
91 if (bpp < 32) { | |
92 mask &= (1 << bpp) - 1; | |
93 } | |
94 | |
95 // Determine properties of the mask | 90 // Determine properties of the mask |
96 uint32_t tempMask = mask; | 91 uint32_t tempMask = mask; |
97 uint32_t shift = 0; | 92 uint32_t shift = 0; |
98 uint32_t size = 0; | 93 uint32_t size = 0; |
99 if (tempMask != 0) { | 94 if (tempMask != 0) { |
100 // Count trailing zeros on masks | 95 // Count trailing zeros on masks |
101 for (; (tempMask & 1) == 0; tempMask >>= 1) { | 96 for (; (tempMask & 1) == 0; tempMask >>= 1) { |
102 shift++; | 97 shift++; |
103 } | 98 } |
104 // Count the size of the mask | 99 // Count the size of the mask |
105 for (; tempMask & 1; tempMask >>= 1) { | 100 for (; tempMask & 1; tempMask >>= 1) { |
106 size++; | 101 size++; |
107 } | 102 } |
108 // Check that the mask is continuous | 103 // Verify that the mask is continuous |
109 if (tempMask != 0) { | 104 if (tempMask) { |
110 SkCodecPrintf("Warning: Bit masks is not continuous.\n"); | 105 SkCodecPrintf("Warning: Bit mask is not continuous.\n"); |
106 // Finish processing the mask | |
msarett
2016/02/10 20:59:28
Even if the mask is not continuous, let's count al
| |
107 for (; tempMask; tempMask >>= 1) { | |
108 size++; | |
109 } | |
111 } | 110 } |
112 // Truncate masks greater than 8 bits | 111 // Truncate masks greater than 8 bits |
113 if (size > 8) { | 112 if (size > 8) { |
114 shift += size - 8; | 113 shift += size - 8; |
115 size = 8; | 114 size = 8; |
115 mask &= 0xFF << shift; | |
msarett
2016/02/10 20:59:28
Make sure that the final mask is no larger than 8-
| |
116 } | 116 } |
117 } | 117 } |
118 | 118 |
119 // Save the calculated values | 119 // Save the calculated values |
120 const SkMasks::MaskInfo info = { mask, shift, size }; | 120 const SkMasks::MaskInfo info = { mask, shift, size }; |
121 return info; | 121 return info; |
122 } | 122 } |
123 | 123 |
124 /* | 124 /* |
125 * | 125 * |
(...skipping 26 matching lines...) Expand all Loading... | |
152 } | 152 } |
153 | 153 |
154 | 154 |
155 SkMasks::SkMasks(const MaskInfo& red, const MaskInfo& green, | 155 SkMasks::SkMasks(const MaskInfo& red, const MaskInfo& green, |
156 const MaskInfo& blue, const MaskInfo& alpha) | 156 const MaskInfo& blue, const MaskInfo& alpha) |
157 : fRed(red) | 157 : fRed(red) |
158 , fGreen(green) | 158 , fGreen(green) |
159 , fBlue(blue) | 159 , fBlue(blue) |
160 , fAlpha(alpha) | 160 , fAlpha(alpha) |
161 {} | 161 {} |
OLD | NEW |