Remove GrColorSpaceXform from GrGradientEffect
Use a local xform to convert color stops for analytic gradients.
For texture-based gradients, wrap the FP with an xform effect.
To simplify this code, add a new AdjustFP helper to do the color
xform, and also add the MulOutputByInputAlpha stage.
Bug: skia:
Change-Id: Icde19b5ec1c66aae76f894e9978c90a5f00c852e
Reviewed-on: https://skia-review.googlesource.com/62500
Reviewed-by: Florin Malita <fmalita@chromium.org>
Reviewed-by: Brian Salomon <bsalomon@google.com>
Commit-Queue: Brian Osman <brianosman@google.com>
diff --git a/src/shaders/gradients/SkSweepGradient.cpp b/src/shaders/gradients/SkSweepGradient.cpp
index 792024f..551a6fb 100644
--- a/src/shaders/gradients/SkSweepGradient.cpp
+++ b/src/shaders/gradients/SkSweepGradient.cpp
@@ -76,8 +76,9 @@
static std::unique_ptr<GrFragmentProcessor> Make(const CreateArgs& args, SkScalar tBias,
SkScalar tScale) {
- auto processor = std::unique_ptr<GrSweepGradient>(new GrSweepGradient(args, tBias, tScale));
- return processor->isValid() ? std::move(processor) : nullptr;
+ return GrGradientEffect::AdjustFP(std::unique_ptr<GrSweepGradient>(
+ new GrSweepGradient(args, tBias, tScale)),
+ args);
}
const char* name() const override { return "Sweep Gradient"; }
@@ -240,16 +241,10 @@
}
matrix.postConcat(fPtsToUnit);
- sk_sp<GrColorSpaceXform> colorSpaceXform = GrColorSpaceXform::Make(fColorSpace.get(),
- args.fDstColorSpace);
- auto inner = GrSweepGradient::Make(
+ return GrSweepGradient::Make(
GrGradientEffect::CreateArgs(args.fContext, this, &matrix, fTileMode,
- std::move(colorSpaceXform), SkToBool(args.fDstColorSpace)),
+ args.fDstColorSpace),
fTBias, fTScale);
- if (!inner) {
- return nullptr;
- }
- return GrFragmentProcessor::MulOutputByInputAlpha(std::move(inner));
}
#endif