| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2006 The Android Open Source Project | 2 * Copyright 2006 The Android Open Source Project |
| 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 "SkGradientShaderPriv.h" | 8 #include "SkGradientShaderPriv.h" |
| 9 #include "SkLinearGradient.h" | 9 #include "SkLinearGradient.h" |
| 10 #include "SkRadialGradient.h" | 10 #include "SkRadialGradient.h" |
| (...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 196 if (fColorCount > 2) { | 196 if (fColorCount > 2) { |
| 197 Rec* recs = fRecs; | 197 Rec* recs = fRecs; |
| 198 for (int i = 1; i < fColorCount; i++) { | 198 for (int i = 1; i < fColorCount; i++) { |
| 199 buffer.writeInt(recs[i].fPos); | 199 buffer.writeInt(recs[i].fPos); |
| 200 buffer.writeUInt(recs[i].fScale); | 200 buffer.writeUInt(recs[i].fScale); |
| 201 } | 201 } |
| 202 } | 202 } |
| 203 buffer.writeMatrix(fPtsToUnit); | 203 buffer.writeMatrix(fPtsToUnit); |
| 204 } | 204 } |
| 205 | 205 |
| 206 void SkGradientShaderBase::flipGradientColors() { |
| 207 SkColor colorsTemp[fColorCount]; |
| 208 Rec recsTemp[fColorCount]; |
| 209 for (int i = 0; i < fColorCount; ++i) { |
| 210 int offset = fColorCount - i - 1; |
| 211 colorsTemp[i] = fOrigColors[offset]; |
| 212 recsTemp[i].fPos = 1 - fRecs[offset].fPos; |
| 213 recsTemp[i].fScale = fRecs[offset].fScale; |
| 214 } |
| 215 memcpy(fOrigColors, colorsTemp, fColorCount * sizeof(SkColor)); |
| 216 memcpy(fRecs, recsTemp, fColorCount * sizeof(Rec)); |
| 217 } |
| 218 |
| 206 bool SkGradientShaderBase::isOpaque() const { | 219 bool SkGradientShaderBase::isOpaque() const { |
| 207 return fColorsAreOpaque; | 220 return fColorsAreOpaque; |
| 208 } | 221 } |
| 209 | 222 |
| 210 SkGradientShaderBase::GradientShaderBaseContext::GradientShaderBaseContext( | 223 SkGradientShaderBase::GradientShaderBaseContext::GradientShaderBaseContext( |
| 211 const SkGradientShaderBase& shader, const SkBitmap& device, | 224 const SkGradientShaderBase& shader, const SkBitmap& device, |
| 212 const SkPaint& paint, const SkMatrix& matrix) | 225 const SkPaint& paint, const SkMatrix& matrix) |
| 213 : INHERITED(shader, device, paint, matrix) | 226 : INHERITED(shader, device, paint, matrix) |
| 214 , fCache(shader.getCache(getPaintAlpha())) | 227 , fCache(shader.getCache(getPaintAlpha())) |
| 215 { | 228 { |
| (...skipping 570 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 786 int colorCount, | 799 int colorCount, |
| 787 SkShader::TileMode mode, | 800 SkShader::TileMode mode, |
| 788 SkUnitMapper* mapper, | 801 SkUnitMapper* mapper, |
| 789 uint32_t flags) { | 802 uint32_t flags) { |
| 790 if (startRadius < 0 || endRadius < 0 || NULL == colors || colorCount < 1) { | 803 if (startRadius < 0 || endRadius < 0 || NULL == colors || colorCount < 1) { |
| 791 return NULL; | 804 return NULL; |
| 792 } | 805 } |
| 793 if (start == end && startRadius == endRadius) { | 806 if (start == end && startRadius == endRadius) { |
| 794 return SkNEW(SkEmptyShader); | 807 return SkNEW(SkEmptyShader); |
| 795 } | 808 } |
| 809 |
| 796 EXPAND_1_COLOR(colorCount); | 810 EXPAND_1_COLOR(colorCount); |
| 797 | 811 |
| 812 bool flipGradient = startRadius > endRadius; |
| 813 |
| 798 SkGradientShaderBase::Descriptor desc; | 814 SkGradientShaderBase::Descriptor desc; |
| 799 desc_init(&desc, colors, pos, colorCount, mode, mapper, flags); | 815 |
| 800 return SkNEW_ARGS(SkTwoPointConicalGradient, | 816 if (!flipGradient) { |
| 801 (start, startRadius, end, endRadius, desc)); | 817 desc_init(&desc, colors, pos, colorCount, mode, mapper, flags); |
| 818 return SkNEW_ARGS(SkTwoPointConicalGradient, |
| 819 (start, startRadius, end, endRadius, flipGradient, des
c)); |
| 820 } else { |
| 821 SkColor colorsNew[colorCount]; |
| 822 SkScalar posNew[colorCount]; |
| 823 for (int i = 0; i < colorCount; ++i) { |
| 824 colorsNew[i] = colors[colorCount - i - 1]; |
| 825 } |
| 826 |
| 827 if (pos) { |
| 828 for (int i = 0; i < colorCount; ++i) { |
| 829 posNew[i] = 1 - pos[colorCount - i - 1]; |
| 830 } |
| 831 desc_init(&desc, colorsNew, posNew, colorCount, mode, mapper, flags)
; |
| 832 } else { |
| 833 desc_init(&desc, colorsNew, NULL, colorCount, mode, mapper, flags); |
| 834 } |
| 835 |
| 836 return SkNEW_ARGS(SkTwoPointConicalGradient, |
| 837 (end, endRadius, start, startRadius, flipGradient, des
c)); |
| 838 } |
| 802 } | 839 } |
| 803 | 840 |
| 804 SkShader* SkGradientShader::CreateSweep(SkScalar cx, SkScalar cy, | 841 SkShader* SkGradientShader::CreateSweep(SkScalar cx, SkScalar cy, |
| 805 const SkColor colors[], | 842 const SkColor colors[], |
| 806 const SkScalar pos[], | 843 const SkScalar pos[], |
| 807 int colorCount, SkUnitMapper* mapper, | 844 int colorCount, SkUnitMapper* mapper, |
| 808 uint32_t flags) { | 845 uint32_t flags) { |
| 809 if (NULL == colors || colorCount < 1) { | 846 if (NULL == colors || colorCount < 1) { |
| 810 return NULL; | 847 return NULL; |
| 811 } | 848 } |
| (...skipping 330 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1142 (*stops)[i] = stop; | 1179 (*stops)[i] = stop; |
| 1143 stop = i < outColors - 1 ? stop + random->nextUScalar1() * (1.f - st
op) : 1.f; | 1180 stop = i < outColors - 1 ? stop + random->nextUScalar1() * (1.f - st
op) : 1.f; |
| 1144 } | 1181 } |
| 1145 } | 1182 } |
| 1146 *tm = static_cast<SkShader::TileMode>(random->nextULessThan(SkShader::kTileM
odeCount)); | 1183 *tm = static_cast<SkShader::TileMode>(random->nextULessThan(SkShader::kTileM
odeCount)); |
| 1147 | 1184 |
| 1148 return outColors; | 1185 return outColors; |
| 1149 } | 1186 } |
| 1150 | 1187 |
| 1151 #endif | 1188 #endif |
| OLD | NEW |