| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 "gm.h" | 8 #include "gm.h" |
| 9 #include "SkGradientShader.h" | 9 #include "SkGradientShader.h" |
| 10 #include "SkLinearGradient.h" | 10 #include "SkLinearGradient.h" |
| 11 | 11 |
| 12 namespace skiagm { | 12 namespace skiagm { |
| 13 | 13 |
| 14 struct GradData { | 14 struct GradData { |
| 15 int fCount; | 15 int fCount; |
| 16 const SkColor* fColors; | 16 const SkColor* fColors; |
| 17 const SkScalar* fPos; | 17 const SkScalar* fPos; |
| 18 }; | 18 }; |
| 19 | 19 |
| 20 static const SkColor gColors[] = { | 20 constexpr SkColor gColors[] = { |
| 21 SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK | 21 SK_ColorRED, SK_ColorGREEN, SK_ColorBLUE, SK_ColorWHITE, SK_ColorBLACK |
| 22 }; | 22 }; |
| 23 static const SkScalar gPos0[] = { 0, SK_Scalar1 }; | 23 constexpr SkScalar gPos0[] = { 0, SK_Scalar1 }; |
| 24 static const SkScalar gPos1[] = { SK_Scalar1/4, SK_Scalar1*3/4 }; | 24 constexpr SkScalar gPos1[] = { SK_Scalar1/4, SK_Scalar1*3/4 }; |
| 25 static const SkScalar gPos2[] = { | 25 constexpr SkScalar gPos2[] = { |
| 26 0, SK_Scalar1/8, SK_Scalar1/2, SK_Scalar1*7/8, SK_Scalar1 | 26 0, SK_Scalar1/8, SK_Scalar1/2, SK_Scalar1*7/8, SK_Scalar1 |
| 27 }; | 27 }; |
| 28 | 28 |
| 29 static const SkScalar gPosClamp[] = {0.0f, 0.0f, 1.0f, 1.0f}; | 29 constexpr SkScalar gPosClamp[] = {0.0f, 0.0f, 1.0f, 1.0f}; |
| 30 static const SkColor gColorClamp[] = { | 30 constexpr SkColor gColorClamp[] = { |
| 31 SK_ColorRED, SK_ColorGREEN, SK_ColorGREEN, SK_ColorBLUE | 31 SK_ColorRED, SK_ColorGREEN, SK_ColorGREEN, SK_ColorBLUE |
| 32 }; | 32 }; |
| 33 | 33 |
| 34 static const GradData gGradData[] = { | 34 constexpr GradData gGradData[] = { |
| 35 { 2, gColors, nullptr }, | 35 { 2, gColors, nullptr }, |
| 36 { 2, gColors, gPos0 }, | 36 { 2, gColors, gPos0 }, |
| 37 { 2, gColors, gPos1 }, | 37 { 2, gColors, gPos1 }, |
| 38 { 5, gColors, nullptr }, | 38 { 5, gColors, nullptr }, |
| 39 { 5, gColors, gPos2 }, | 39 { 5, gColors, gPos2 }, |
| 40 { 4, gColorClamp, gPosClamp } | 40 { 4, gColorClamp, gPosClamp } |
| 41 }; | 41 }; |
| 42 | 42 |
| 43 static sk_sp<SkShader> MakeLinear(const SkPoint pts[2], const GradData& data, | 43 static sk_sp<SkShader> MakeLinear(const SkPoint pts[2], const GradData& data, |
| 44 SkShader::TileMode tm, const SkMatrix& localMa
trix) { | 44 SkShader::TileMode tm, const SkMatrix& localMa
trix) { |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 84 SkScalar radius1 = (pts[1].fX - pts[0].fX) / 3; | 84 SkScalar radius1 = (pts[1].fX - pts[0].fX) / 3; |
| 85 center0.set(pts[0].fX + radius0, pts[0].fY + radius0); | 85 center0.set(pts[0].fX + radius0, pts[0].fY + radius0); |
| 86 center1.set(pts[1].fX - radius1, pts[1].fY - radius1); | 86 center1.set(pts[1].fX - radius1, pts[1].fY - radius1); |
| 87 return SkGradientShader::MakeTwoPointConical(center1, radius1, center0, radi
us0, | 87 return SkGradientShader::MakeTwoPointConical(center1, radius1, center0, radi
us0, |
| 88 data.fColors, data.fPos, | 88 data.fColors, data.fPos, |
| 89 data.fCount, tm, 0, &localMatri
x); | 89 data.fCount, tm, 0, &localMatri
x); |
| 90 } | 90 } |
| 91 | 91 |
| 92 typedef sk_sp<SkShader> (*GradMaker)(const SkPoint pts[2], const GradData& data, | 92 typedef sk_sp<SkShader> (*GradMaker)(const SkPoint pts[2], const GradData& data, |
| 93 SkShader::TileMode tm, const SkMatrix& loca
lMatrix); | 93 SkShader::TileMode tm, const SkMatrix& loca
lMatrix); |
| 94 static const GradMaker gGradMakers[] = { | 94 constexpr GradMaker gGradMakers[] = { |
| 95 MakeLinear, MakeRadial, MakeSweep, Make2Radial, Make2Conical | 95 MakeLinear, MakeRadial, MakeSweep, Make2Radial, Make2Conical |
| 96 }; | 96 }; |
| 97 | 97 |
| 98 /////////////////////////////////////////////////////////////////////////////// | 98 /////////////////////////////////////////////////////////////////////////////// |
| 99 | 99 |
| 100 class GradientsGM : public GM { | 100 class GradientsGM : public GM { |
| 101 public: | 101 public: |
| 102 GradientsGM(bool dither) : fDither(dither) { | 102 GradientsGM(bool dither) : fDither(dither) { |
| 103 this->setBGColor(sk_tool_utils::color_to_565(0xFFDDDDDD)); | 103 this->setBGColor(sk_tool_utils::color_to_565(0xFFDDDDDD)); |
| 104 } | 104 } |
| (...skipping 681 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 786 canvas->drawRect(SkRect::MakeXYWH(0, 0, 500, 500), p); | 786 canvas->drawRect(SkRect::MakeXYWH(0, 0, 500, 500), p); |
| 787 } | 787 } |
| 788 | 788 |
| 789 DEF_SIMPLE_GM(gradient_many_stops, canvas, 500, 500) { | 789 DEF_SIMPLE_GM(gradient_many_stops, canvas, 500, 500) { |
| 790 draw_many_stops(canvas, 0); | 790 draw_many_stops(canvas, 0); |
| 791 } | 791 } |
| 792 | 792 |
| 793 DEF_SIMPLE_GM(gradient_many_stops_4f, canvas, 500, 500) { | 793 DEF_SIMPLE_GM(gradient_many_stops_4f, canvas, 500, 500) { |
| 794 draw_many_stops(canvas, SkLinearGradient::kForce4fContext_PrivateFlag); | 794 draw_many_stops(canvas, SkLinearGradient::kForce4fContext_PrivateFlag); |
| 795 } | 795 } |
| OLD | NEW |