1/* 2 * Copyright 2018 Google Inc. 3 * 4 * Use of this source code is governed by a BSD-style license that can be 5 * found in the LICENSE file. 6 */ 7 8in half4x4 gradientMatrix; 9 10@coordTransform { 11 gradientMatrix 12} 13 14void main() { 15 // We add a tiny delta to t. When gradient stops are set up so that a hard stop in a vertically 16 // or horizontally oriented gradient falls exactly at a column or row of pixel centers we can 17 // we can get slightly different interpolated t values along the column/row. By adding the delta 18 // we will consistently get the color to the "right" of the stop. Of course if the hard stop 19 // falls at X.5 - delta then we still could get inconsistent results, but that is much less 20 // likely. crbug.com/938592 21 // If/when we add filtering of the gradient this can be removed. 22 half t = half(sk_TransformedCoords2D[0].x) + 0.00001; 23 sk_OutColor = half4(t, 1, 0, 0); // y = 1 for always valid 24} 25 26////////////////////////////////////////////////////////////////////////////// 27 28@header { 29 #include "SkLinearGradient.h" 30 #include "GrGradientShader.h" 31} 32 33// The linear gradient never rejects a pixel so it doesn't change opacity 34@optimizationFlags { 35 kPreservesOpaqueInput_OptimizationFlag 36} 37 38@make { 39 static std::unique_ptr<GrFragmentProcessor> Make(const SkLinearGradient& gradient, 40 const GrFPArgs& args); 41} 42 43@cppEnd { 44 std::unique_ptr<GrFragmentProcessor> GrLinearGradientLayout::Make( 45 const SkLinearGradient& grad, const GrFPArgs& args) { 46 SkMatrix matrix; 47 if (!grad.totalLocalMatrix(args.fPreLocalMatrix, args.fPostLocalMatrix)->invert(&matrix)) { 48 return nullptr; 49 } 50 matrix.postConcat(grad.getGradientMatrix()); 51 return std::unique_ptr<GrFragmentProcessor>(new GrLinearGradientLayout(matrix)); 52 } 53} 54 55////////////////////////////////////////////////////////////////////////////// 56 57@test(d) { 58 SkScalar scale = GrGradientShader::RandomParams::kGradientScale; 59 SkPoint points[] = {{d->fRandom->nextRangeScalar(0.0f, scale), 60 d->fRandom->nextRangeScalar(0.0f, scale)}, 61 {d->fRandom->nextRangeScalar(0.0f, scale), 62 d->fRandom->nextRangeScalar(0.0f, scale)}}; 63 64 GrGradientShader::RandomParams params(d->fRandom); 65 auto shader = params.fUseColors4f ? 66 SkGradientShader::MakeLinear(points, params.fColors4f, params.fColorSpace, params.fStops, 67 params.fColorCount, params.fTileMode) : 68 SkGradientShader::MakeLinear(points, params.fColors, params.fStops, 69 params.fColorCount, params.fTileMode); 70 GrTest::TestAsFPArgs asFPArgs(d); 71 std::unique_ptr<GrFragmentProcessor> fp = as_SB(shader)->asFragmentProcessor(asFPArgs.args()); 72 GrAlwaysAssert(fp); 73 return fp; 74} 75