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
8 /**************************************************************************************************
9 *** This file was autogenerated from GrDualIntervalGradientColorizer.fp; do not modify.
10 **************************************************************************************************/
11 #include "GrDualIntervalGradientColorizer.h"
12 #include "glsl/GrGLSLFragmentProcessor.h"
13 #include "glsl/GrGLSLFragmentShaderBuilder.h"
14 #include "glsl/GrGLSLProgramBuilder.h"
15 #include "GrTexture.h"
16 #include "SkSLCPP.h"
17 #include "SkSLUtil.h"
18 class GrGLSLDualIntervalGradientColorizer : public GrGLSLFragmentProcessor {
19 public:
GrGLSLDualIntervalGradientColorizer()20 GrGLSLDualIntervalGradientColorizer() {}
emitCode(EmitArgs & args)21 void emitCode(EmitArgs& args) override {
22 GrGLSLFPFragmentBuilder* fragBuilder = args.fFragBuilder;
23 const GrDualIntervalGradientColorizer& _outer =
24 args.fFp.cast<GrDualIntervalGradientColorizer>();
25 (void)_outer;
26 auto scale01 = _outer.scale01();
27 (void)scale01;
28 auto bias01 = _outer.bias01();
29 (void)bias01;
30 auto scale23 = _outer.scale23();
31 (void)scale23;
32 auto bias23 = _outer.bias23();
33 (void)bias23;
34 auto threshold = _outer.threshold();
35 (void)threshold;
36 fScale01Var = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kFloat4_GrSLType,
37 kDefault_GrSLPrecision, "scale01");
38 fBias01Var = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kFloat4_GrSLType,
39 kDefault_GrSLPrecision, "bias01");
40 fScale23Var = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kFloat4_GrSLType,
41 kDefault_GrSLPrecision, "scale23");
42 fBias23Var = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kFloat4_GrSLType,
43 kDefault_GrSLPrecision, "bias23");
44 fThresholdVar = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kHalf_GrSLType,
45 kDefault_GrSLPrecision, "threshold");
46 fragBuilder->codeAppendf(
47 "half t = %s.x;\nfloat4 scale, bias;\nif (t < %s) {\n scale = %s;\n bias = "
48 "%s;\n} else {\n scale = %s;\n bias = %s;\n}\n%s = half4(float(t) * scale + "
49 "bias);\n",
50 args.fInputColor, args.fUniformHandler->getUniformCStr(fThresholdVar),
51 args.fUniformHandler->getUniformCStr(fScale01Var),
52 args.fUniformHandler->getUniformCStr(fBias01Var),
53 args.fUniformHandler->getUniformCStr(fScale23Var),
54 args.fUniformHandler->getUniformCStr(fBias23Var), args.fOutputColor);
55 }
56
57 private:
onSetData(const GrGLSLProgramDataManager & pdman,const GrFragmentProcessor & _proc)58 void onSetData(const GrGLSLProgramDataManager& pdman,
59 const GrFragmentProcessor& _proc) override {
60 const GrDualIntervalGradientColorizer& _outer =
61 _proc.cast<GrDualIntervalGradientColorizer>();
62 {
63 const SkPMColor4f& scale01Value = _outer.scale01();
64 if (fScale01Prev != scale01Value) {
65 fScale01Prev = scale01Value;
66 pdman.set4fv(fScale01Var, 1, scale01Value.vec());
67 }
68 const SkPMColor4f& bias01Value = _outer.bias01();
69 if (fBias01Prev != bias01Value) {
70 fBias01Prev = bias01Value;
71 pdman.set4fv(fBias01Var, 1, bias01Value.vec());
72 }
73 const SkPMColor4f& scale23Value = _outer.scale23();
74 if (fScale23Prev != scale23Value) {
75 fScale23Prev = scale23Value;
76 pdman.set4fv(fScale23Var, 1, scale23Value.vec());
77 }
78 const SkPMColor4f& bias23Value = _outer.bias23();
79 if (fBias23Prev != bias23Value) {
80 fBias23Prev = bias23Value;
81 pdman.set4fv(fBias23Var, 1, bias23Value.vec());
82 }
83 float thresholdValue = _outer.threshold();
84 if (fThresholdPrev != thresholdValue) {
85 fThresholdPrev = thresholdValue;
86 pdman.set1f(fThresholdVar, thresholdValue);
87 }
88 }
89 }
90 SkPMColor4f fScale01Prev = {SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN};
91 SkPMColor4f fBias01Prev = {SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN};
92 SkPMColor4f fScale23Prev = {SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN};
93 SkPMColor4f fBias23Prev = {SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN};
94 float fThresholdPrev = SK_FloatNaN;
95 UniformHandle fScale01Var;
96 UniformHandle fBias01Var;
97 UniformHandle fScale23Var;
98 UniformHandle fBias23Var;
99 UniformHandle fThresholdVar;
100 };
onCreateGLSLInstance() const101 GrGLSLFragmentProcessor* GrDualIntervalGradientColorizer::onCreateGLSLInstance() const {
102 return new GrGLSLDualIntervalGradientColorizer();
103 }
onGetGLSLProcessorKey(const GrShaderCaps & caps,GrProcessorKeyBuilder * b) const104 void GrDualIntervalGradientColorizer::onGetGLSLProcessorKey(const GrShaderCaps& caps,
105 GrProcessorKeyBuilder* b) const {}
onIsEqual(const GrFragmentProcessor & other) const106 bool GrDualIntervalGradientColorizer::onIsEqual(const GrFragmentProcessor& other) const {
107 const GrDualIntervalGradientColorizer& that = other.cast<GrDualIntervalGradientColorizer>();
108 (void)that;
109 if (fScale01 != that.fScale01) return false;
110 if (fBias01 != that.fBias01) return false;
111 if (fScale23 != that.fScale23) return false;
112 if (fBias23 != that.fBias23) return false;
113 if (fThreshold != that.fThreshold) return false;
114 return true;
115 }
GrDualIntervalGradientColorizer(const GrDualIntervalGradientColorizer & src)116 GrDualIntervalGradientColorizer::GrDualIntervalGradientColorizer(
117 const GrDualIntervalGradientColorizer& src)
118 : INHERITED(kGrDualIntervalGradientColorizer_ClassID, src.optimizationFlags())
119 , fScale01(src.fScale01)
120 , fBias01(src.fBias01)
121 , fScale23(src.fScale23)
122 , fBias23(src.fBias23)
123 , fThreshold(src.fThreshold) {}
clone() const124 std::unique_ptr<GrFragmentProcessor> GrDualIntervalGradientColorizer::clone() const {
125 return std::unique_ptr<GrFragmentProcessor>(new GrDualIntervalGradientColorizer(*this));
126 }
127
Make(const SkPMColor4f & c0,const SkPMColor4f & c1,const SkPMColor4f & c2,const SkPMColor4f & c3,float threshold)128 std::unique_ptr<GrFragmentProcessor> GrDualIntervalGradientColorizer::Make(const SkPMColor4f& c0,
129 const SkPMColor4f& c1,
130 const SkPMColor4f& c2,
131 const SkPMColor4f& c3,
132 float threshold) {
133 // Derive scale and biases from the 4 colors and threshold
134 auto vc0 = Sk4f::Load(c0.vec());
135 auto vc1 = Sk4f::Load(c1.vec());
136 auto scale01 = (vc1 - vc0) / threshold;
137 // bias01 = c0
138
139 auto vc2 = Sk4f::Load(c2.vec());
140 auto vc3 = Sk4f::Load(c3.vec());
141 auto scale23 = (vc3 - vc2) / (1 - threshold);
142 auto bias23 = vc2 - threshold * scale23;
143
144 return std::unique_ptr<GrFragmentProcessor>(new GrDualIntervalGradientColorizer(
145 {scale01[0], scale01[1], scale01[2], scale01[3]}, c0,
146 {scale23[0], scale23[1], scale23[2], scale23[3]},
147 {bias23[0], bias23[1], bias23[2], bias23[3]}, threshold));
148 }
149