diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/effects/gradients/SkGradientShader.cpp | 27 | ||||
-rw-r--r-- | src/effects/gradients/SkGradientShaderPriv.h | 13 | ||||
-rw-r--r-- | src/effects/gradients/SkLinearGradient.cpp | 9 | ||||
-rw-r--r-- | src/effects/gradients/SkRadialGradient.cpp | 9 | ||||
-rw-r--r-- | src/effects/gradients/SkSweepGradient.cpp | 10 | ||||
-rw-r--r-- | src/effects/gradients/SkTwoPointConicalGradient_gpu.cpp | 56 |
6 files changed, 51 insertions, 73 deletions
diff --git a/src/effects/gradients/SkGradientShader.cpp b/src/effects/gradients/SkGradientShader.cpp index 17302d9d4f..bedc6e8868 100644 --- a/src/effects/gradients/SkGradientShader.cpp +++ b/src/effects/gradients/SkGradientShader.cpp @@ -1723,28 +1723,25 @@ void GrGradientEffect::onComputeInvariantOutput(GrInvariantOutput* inout) const } } -int GrGradientEffect::RandomGradientParams(SkRandom* random, - SkColor colors[], - SkScalar** stops, - SkShader::TileMode* tm) { - int outColors = random->nextRangeU(1, kMaxRandomGradientColors); +GrGradientEffect::RandomGradientParams::RandomGradientParams(SkRandom* random) { + fColorCount = random->nextRangeU(1, kMaxRandomGradientColors); // if one color, omit stops, otherwise randomly decide whether or not to - if (outColors == 1 || (outColors >= 2 && random->nextBool())) { - *stops = nullptr; + if (fColorCount == 1 || (fColorCount >= 2 && random->nextBool())) { + fStops = nullptr; + } else { + fStops = fStopStorage; } SkScalar stop = 0.f; - for (int i = 0; i < outColors; ++i) { - colors[i] = random->nextU(); - if (*stops) { - (*stops)[i] = stop; - stop = i < outColors - 1 ? stop + random->nextUScalar1() * (1.f - stop) : 1.f; + for (int i = 0; i < fColorCount; ++i) { + fColors[i] = random->nextU(); + if (fStops) { + fStops[i] = stop; + stop = i < fColorCount - 1 ? stop + random->nextUScalar1() * (1.f - stop) : 1.f; } } - *tm = static_cast<SkShader::TileMode>(random->nextULessThan(SkShader::kTileModeCount)); - - return outColors; + fTileMode = static_cast<SkShader::TileMode>(random->nextULessThan(SkShader::kTileModeCount)); } #endif diff --git a/src/effects/gradients/SkGradientShaderPriv.h b/src/effects/gradients/SkGradientShaderPriv.h index 61a44184ff..bbc94907d8 100644 --- a/src/effects/gradients/SkGradientShaderPriv.h +++ b/src/effects/gradients/SkGradientShaderPriv.h @@ -408,10 +408,15 @@ protected: be passed to the gradient factory rather than the array. */ static const int kMaxRandomGradientColors = 4; - static int RandomGradientParams(SkRandom* r, - SkColor colors[kMaxRandomGradientColors], - SkScalar** stops, - SkShader::TileMode* tm); + struct RandomGradientParams { + RandomGradientParams(SkRandom* r); + + SkColor fColors[kMaxRandomGradientColors]; + SkScalar fStopStorage[kMaxRandomGradientColors]; + SkShader::TileMode fTileMode; + int fColorCount; + SkScalar* fStops; + }; bool onIsEqual(const GrFragmentProcessor&) const override; diff --git a/src/effects/gradients/SkLinearGradient.cpp b/src/effects/gradients/SkLinearGradient.cpp index a249ae4ac8..2fcaae1ca9 100644 --- a/src/effects/gradients/SkLinearGradient.cpp +++ b/src/effects/gradients/SkLinearGradient.cpp @@ -414,12 +414,9 @@ sk_sp<GrFragmentProcessor> GrLinearGradient::TestCreate(GrProcessorTestData* d) SkPoint points[] = {{d->fRandom->nextUScalar1(), d->fRandom->nextUScalar1()}, {d->fRandom->nextUScalar1(), d->fRandom->nextUScalar1()}}; - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tm; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tm); - auto shader = SkGradientShader::MakeLinear(points, colors, stops, colorCount, tm); + RandomGradientParams params(d->fRandom); + auto shader = SkGradientShader::MakeLinear(points, params.fColors, params.fStops, + params.fColorCount, params.fTileMode); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( diff --git a/src/effects/gradients/SkRadialGradient.cpp b/src/effects/gradients/SkRadialGradient.cpp index 18ef376862..f13deb1cdb 100644 --- a/src/effects/gradients/SkRadialGradient.cpp +++ b/src/effects/gradients/SkRadialGradient.cpp @@ -308,12 +308,9 @@ sk_sp<GrFragmentProcessor> GrRadialGradient::TestCreate(GrProcessorTestData* d) SkPoint center = {d->fRandom->nextUScalar1(), d->fRandom->nextUScalar1()}; SkScalar radius = d->fRandom->nextUScalar1(); - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tm; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tm); - auto shader = SkGradientShader::MakeRadial(center, radius, colors, stops, colorCount, tm); + RandomGradientParams params(d->fRandom); + auto shader = SkGradientShader::MakeRadial(center, radius, params.fColors, params.fStops, + params.fColorCount, params.fTileMode); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( diff --git a/src/effects/gradients/SkSweepGradient.cpp b/src/effects/gradients/SkSweepGradient.cpp index d1fe269b9c..f4ef8ab41f 100644 --- a/src/effects/gradients/SkSweepGradient.cpp +++ b/src/effects/gradients/SkSweepGradient.cpp @@ -190,13 +190,9 @@ GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrSweepGradient); sk_sp<GrFragmentProcessor> GrSweepGradient::TestCreate(GrProcessorTestData* d) { SkPoint center = {d->fRandom->nextUScalar1(), d->fRandom->nextUScalar1()}; - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tmIgnored; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tmIgnored); - sk_sp<SkShader> shader(SkGradientShader::MakeSweep(center.fX, center.fY, colors, stops, - colorCount)); + RandomGradientParams params(d->fRandom); + sk_sp<SkShader> shader(SkGradientShader::MakeSweep(center.fX, center.fY, params.fColors, + params.fStops, params.fColorCount)); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( diff --git a/src/effects/gradients/SkTwoPointConicalGradient_gpu.cpp b/src/effects/gradients/SkTwoPointConicalGradient_gpu.cpp index a8df3b50c3..00d8fac73f 100644 --- a/src/effects/gradients/SkTwoPointConicalGradient_gpu.cpp +++ b/src/effects/gradients/SkTwoPointConicalGradient_gpu.cpp @@ -199,13 +199,10 @@ sk_sp<GrFragmentProcessor> Edge2PtConicalEffect::TestCreate(GrProcessorTestData* SkScalar diffLen = diff.length(); radius2 = radius1 + diffLen; - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tm; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tm); + RandomGradientParams params(d->fRandom); auto shader = SkGradientShader::MakeTwoPointConical(center1, radius1, center2, radius2, - colors, stops, colorCount, tm); + params.fColors, params.fStops, + params.fColorCount, params.fTileMode); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( @@ -470,18 +467,16 @@ sk_sp<GrFragmentProcessor> FocalOutside2PtConicalEffect::TestCreate(GrProcessorT center2.set(d->fRandom->nextUScalar1(), d->fRandom->nextUScalar1()); // Need to make sure the centers are not the same or else focal point will be inside } while (center1 == center2); - SkPoint diff = center2 - center1; - SkScalar diffLen = diff.length(); - // Below makes sure that the focal point is not contained within circle two - radius2 = d->fRandom->nextRangeF(0.f, diffLen); - - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tm; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tm); + + SkPoint diff = center2 - center1; + SkScalar diffLen = diff.length(); + // Below makes sure that the focal point is not contained within circle two + radius2 = d->fRandom->nextRangeF(0.f, diffLen); + + RandomGradientParams params(d->fRandom); auto shader = SkGradientShader::MakeTwoPointConical(center1, radius1, center2, radius2, - colors, stops, colorCount, tm); + params.fColors, params.fStops, + params.fColorCount, params.fTileMode); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( @@ -680,13 +675,10 @@ sk_sp<GrFragmentProcessor> FocalInside2PtConicalEffect::TestCreate(GrProcessorTe // If the circles are identical the factory will give us an empty shader. } while (radius1 == radius2 && center1 == center2); - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tm; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tm); + RandomGradientParams params(d->fRandom); auto shader = SkGradientShader::MakeTwoPointConical(center1, radius1, center2, radius2, - colors, stops, colorCount, tm); + params.fColors, params.fStops, + params.fColorCount, params.fTileMode); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( @@ -927,13 +919,10 @@ sk_sp<GrFragmentProcessor> CircleInside2PtConicalEffect::TestCreate(GrProcessorT // If the circles are identical the factory will give us an empty shader. } while (radius1 == radius2 && center1 == center2); - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tm; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tm); + RandomGradientParams params(d->fRandom); auto shader = SkGradientShader::MakeTwoPointConical(center1, radius1, center2, radius2, - colors, stops, colorCount, tm); + params.fColors, params.fStops, + params.fColorCount, params.fTileMode); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( @@ -1161,13 +1150,10 @@ sk_sp<GrFragmentProcessor> CircleOutside2PtConicalEffect::TestCreate(GrProcessor // and have radius2 >= radius to match sorting on cpu side radius2 = radius1 + d->fRandom->nextRangeF(0.f, diffLen); - SkColor colors[kMaxRandomGradientColors]; - SkScalar stopsArray[kMaxRandomGradientColors]; - SkScalar* stops = stopsArray; - SkShader::TileMode tm; - int colorCount = RandomGradientParams(d->fRandom, colors, &stops, &tm); + RandomGradientParams params(d->fRandom); auto shader = SkGradientShader::MakeTwoPointConical(center1, radius1, center2, radius2, - colors, stops, colorCount, tm); + params.fColors, params.fStops, + params.fColorCount, params.fTileMode); SkMatrix viewMatrix = GrTest::TestMatrix(d->fRandom); auto dstColorSpace = GrTest::TestColorSpace(d->fRandom); sk_sp<GrFragmentProcessor> fp = shader->asFragmentProcessor(SkShader::AsFPArgs( |