blob: 186dcfe36522263aea4010ff01385781dadeb7ff [file] [log] [blame]
Ethan Nicholas82399462017-10-16 12:35:44 -04001/*
Ethan Nicholas130fb3f2018-02-01 12:14:34 -05002 * Copyright 2018 Google Inc.
Ethan Nicholas82399462017-10-16 12:35:44 -04003 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
Ethan Nicholas130fb3f2018-02-01 12:14:34 -05008/**************************************************************************************************
9 *** This file was autogenerated from GrRectBlurEffect.fp; do not modify.
10 **************************************************************************************************/
Ethan Nicholas82399462017-10-16 12:35:44 -040011#include "GrRectBlurEffect.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050012
13#include "include/gpu/GrTexture.h"
14#include "src/gpu/glsl/GrGLSLFragmentProcessor.h"
15#include "src/gpu/glsl/GrGLSLFragmentShaderBuilder.h"
16#include "src/gpu/glsl/GrGLSLProgramBuilder.h"
17#include "src/sksl/SkSLCPP.h"
18#include "src/sksl/SkSLUtil.h"
Ethan Nicholas82399462017-10-16 12:35:44 -040019class GrGLSLRectBlurEffect : public GrGLSLFragmentProcessor {
20public:
21 GrGLSLRectBlurEffect() {}
22 void emitCode(EmitArgs& args) override {
23 GrGLSLFPFragmentBuilder* fragBuilder = args.fFragBuilder;
Mike Kleind6ab77a2019-03-21 08:18:24 -050024 const GrRectBlurEffect& _outer = args.fFp.cast<GrRectBlurEffect>();
Ethan Nicholas82399462017-10-16 12:35:44 -040025 (void)_outer;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040026 auto rect = _outer.rect;
Ethan Nicholas82399462017-10-16 12:35:44 -040027 (void)rect;
Brian Salomonb2d5d402019-09-10 10:11:52 -040028 auto invSixSigma = _outer.invSixSigma;
29 (void)invSixSigma;
30 auto isFast = _outer.isFast;
31 (void)isFast;
Brian Salomon2c596592019-08-13 20:05:04 -040032 highp = ((abs(rect.left()) > 16000.0 || abs(rect.top()) > 16000.0) ||
33 abs(rect.right()) > 16000.0) ||
34 abs(rect.bottom()) > 16000.0;
35 if (highp) {
36 rectFVar = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kFloat4_GrSLType,
37 "rectF");
Ethan Nicholas82399462017-10-16 12:35:44 -040038 }
Brian Salomon2c596592019-08-13 20:05:04 -040039 if (!highp) {
40 rectHVar = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kHalf4_GrSLType,
41 "rectH");
Ethan Nicholas82399462017-10-16 12:35:44 -040042 }
Brian Salomonb2d5d402019-09-10 10:11:52 -040043 invSixSigmaVar = args.fUniformHandler->addUniform(kFragment_GrShaderFlag, kHalf_GrSLType,
44 "invSixSigma");
Ethan Nicholas82399462017-10-16 12:35:44 -040045 fragBuilder->codeAppendf(
Brian Salomonb2d5d402019-09-10 10:11:52 -040046 "/* key */ bool highp = %s;\nhalf xCoverage, yCoverage;\n@if (%s) {\n half x, "
47 "y;\n @if (highp) {\n x = max(half(%s.x - sk_FragCoord.x), "
48 "half(sk_FragCoord.x - %s.z));\n y = max(half(%s.y - sk_FragCoord.y), "
49 "half(sk_FragCoord.y - %s.w));\n } else {\n x = max(half(float(%s.x) - "
50 "sk_FragCoord.x), half(sk_FragCoord.x - float(%s.z)));\n y = "
51 "max(half(float(%s.y) - sk_FragCoord.y), half(sk_FragCoord.y - float(%s.w)));\n "
52 "}\n xCoverage = sample(%s, float2(half2(x * %s, 0.5))).",
53 (highp ? "true" : "false"), (_outer.isFast ? "true" : "false"),
54 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
55 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
Brian Salomon2c596592019-08-13 20:05:04 -040056 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
57 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
58 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)",
Brian Salomon5331e2a2019-08-19 17:18:10 -040059 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)",
Brian Salomon5331e2a2019-08-19 17:18:10 -040060 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)",
61 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)",
Brian Salomone7366842019-09-04 11:20:45 -040062 fragBuilder->getProgramBuilder()->samplerVariable(args.fTexSamplers[0]),
Brian Salomonb2d5d402019-09-10 10:11:52 -040063 args.fUniformHandler->getUniformCStr(invSixSigmaVar));
Ethan Nicholas82399462017-10-16 12:35:44 -040064 fragBuilder->codeAppendf(
Brian Salomonb2d5d402019-09-10 10:11:52 -040065 "%s.w;\n yCoverage = sample(%s, float2(half2(y * %s, 0.5))).%s.w;\n %s = (%s "
66 "* xCoverage) * yCoverage;\n} else {\n half l, r, t, b;\n @if (highp) {\n "
67 " l = half(sk_FragCoord.x - %s.x);\n r = half(%s.z - sk_FragCoord.x);\n "
68 " t = half(sk_FragCoord.y - %s.y);\n b = half(%s.w - "
69 "sk_FragCoord.y);\n } else {\n l = half(sk_FragCoord.x - float(%s.x));\n "
70 " r = half(float(%s.z) - sk_FragCoord.x);\n t = half(sk_FragCoord.y - "
71 "float(%s.y));\n b = half(float(",
72 fragBuilder->getProgramBuilder()->samplerSwizzle(args.fTexSamplers[0]).c_str(),
73 fragBuilder->getProgramBuilder()->samplerVariable(args.fTexSamplers[0]),
74 args.fUniformHandler->getUniformCStr(invSixSigmaVar),
75 fragBuilder->getProgramBuilder()->samplerSwizzle(args.fTexSamplers[0]).c_str(),
76 args.fOutputColor, args.fInputColor,
77 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
78 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
79 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
80 rectFVar.isValid() ? args.fUniformHandler->getUniformCStr(rectFVar) : "float4(0)",
81 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)",
82 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)",
83 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)");
84 fragBuilder->codeAppendf(
85 "%s.w) - sk_FragCoord.y);\n }\n half il = 1.0 + l * %s;\n half ir = 1.0 + "
86 "r * %s;\n half it = 1.0 + t * %s;\n half ib = 1.0 + b * %s;\n xCoverage "
87 "= (1.0 - sample(%s, float2(half2(il, 0.5))).%s.w) - sample(%s, float2(half2(ir, "
88 "0.5))).%s.w;\n yCoverage = (1.0 - sample(%s, float2(half2(it, 0.5))).%s.w) - "
89 "sample(%s, float2(half2(ib, 0.5))).%s.w;\n}\n%s = (%s * xCoverage) * yCoverage;\n",
90 rectHVar.isValid() ? args.fUniformHandler->getUniformCStr(rectHVar) : "half4(0)",
91 args.fUniformHandler->getUniformCStr(invSixSigmaVar),
92 args.fUniformHandler->getUniformCStr(invSixSigmaVar),
93 args.fUniformHandler->getUniformCStr(invSixSigmaVar),
94 args.fUniformHandler->getUniformCStr(invSixSigmaVar),
95 fragBuilder->getProgramBuilder()->samplerVariable(args.fTexSamplers[0]),
96 fragBuilder->getProgramBuilder()->samplerSwizzle(args.fTexSamplers[0]).c_str(),
97 fragBuilder->getProgramBuilder()->samplerVariable(args.fTexSamplers[0]),
98 fragBuilder->getProgramBuilder()->samplerSwizzle(args.fTexSamplers[0]).c_str(),
99 fragBuilder->getProgramBuilder()->samplerVariable(args.fTexSamplers[0]),
100 fragBuilder->getProgramBuilder()->samplerSwizzle(args.fTexSamplers[0]).c_str(),
101 fragBuilder->getProgramBuilder()->samplerVariable(args.fTexSamplers[0]),
Brian Salomone7366842019-09-04 11:20:45 -0400102 fragBuilder->getProgramBuilder()->samplerSwizzle(args.fTexSamplers[0]).c_str(),
Brian Salomon5331e2a2019-08-19 17:18:10 -0400103 args.fOutputColor, args.fInputColor);
Ethan Nicholas82399462017-10-16 12:35:44 -0400104 }
105
106private:
107 void onSetData(const GrGLSLProgramDataManager& pdman,
Mike Kleind6ab77a2019-03-21 08:18:24 -0500108 const GrFragmentProcessor& _proc) override {
Ethan Nicholas82399462017-10-16 12:35:44 -0400109 const GrRectBlurEffect& _outer = _proc.cast<GrRectBlurEffect>();
Brian Salomonb2d5d402019-09-10 10:11:52 -0400110 { pdman.set1f(invSixSigmaVar, (_outer.invSixSigma)); }
Brian Salomon2c596592019-08-13 20:05:04 -0400111 auto rect = _outer.rect;
Ethan Nicholas82399462017-10-16 12:35:44 -0400112 (void)rect;
Brian Salomon2c596592019-08-13 20:05:04 -0400113 UniformHandle& rectF = rectFVar;
114 (void)rectF;
115 UniformHandle& rectH = rectHVar;
116 (void)rectH;
Brian Salomonb2d5d402019-09-10 10:11:52 -0400117 GrSurfaceProxy& integralProxy = *_outer.textureSampler(0).proxy();
118 GrTexture& integral = *integralProxy.peekTexture();
119 (void)integral;
120 UniformHandle& invSixSigma = invSixSigmaVar;
121 (void)invSixSigma;
122 auto isFast = _outer.isFast;
123 (void)isFast;
Ethan Nicholas82399462017-10-16 12:35:44 -0400124
Brian Salomon2c596592019-08-13 20:05:04 -0400125 float r[]{rect.fLeft, rect.fTop, rect.fRight, rect.fBottom};
126 pdman.set4fv(highp ? rectF : rectH, 1, r);
Ethan Nicholas82399462017-10-16 12:35:44 -0400127 }
Brian Salomon2c596592019-08-13 20:05:04 -0400128 bool highp = false;
129 UniformHandle rectFVar;
130 UniformHandle rectHVar;
Brian Salomonb2d5d402019-09-10 10:11:52 -0400131 UniformHandle invSixSigmaVar;
Ethan Nicholas82399462017-10-16 12:35:44 -0400132};
133GrGLSLFragmentProcessor* GrRectBlurEffect::onCreateGLSLInstance() const {
134 return new GrGLSLRectBlurEffect();
135}
Mike Kleind6ab77a2019-03-21 08:18:24 -0500136void GrRectBlurEffect::onGetGLSLProcessorKey(const GrShaderCaps& caps,
Ethan Nicholascab767f2019-07-01 13:32:07 -0400137 GrProcessorKeyBuilder* b) const {
Brian Salomon2c596592019-08-13 20:05:04 -0400138 bool highp = ((abs(rect.left()) > 16000.0 || abs(rect.top()) > 16000.0) ||
139 abs(rect.right()) > 16000.0) ||
140 abs(rect.bottom()) > 16000.0;
141 b->add32((int32_t)highp);
Brian Salomonb2d5d402019-09-10 10:11:52 -0400142 b->add32((int32_t)isFast);
Ethan Nicholascab767f2019-07-01 13:32:07 -0400143}
Ethan Nicholas82399462017-10-16 12:35:44 -0400144bool GrRectBlurEffect::onIsEqual(const GrFragmentProcessor& other) const {
145 const GrRectBlurEffect& that = other.cast<GrRectBlurEffect>();
146 (void)that;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400147 if (rect != that.rect) return false;
Brian Salomonb2d5d402019-09-10 10:11:52 -0400148 if (integral != that.integral) return false;
149 if (invSixSigma != that.invSixSigma) return false;
150 if (isFast != that.isFast) return false;
Ethan Nicholas82399462017-10-16 12:35:44 -0400151 return true;
152}
153GrRectBlurEffect::GrRectBlurEffect(const GrRectBlurEffect& src)
154 : INHERITED(kGrRectBlurEffect_ClassID, src.optimizationFlags())
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400155 , rect(src.rect)
Brian Salomonb2d5d402019-09-10 10:11:52 -0400156 , integral(src.integral)
157 , invSixSigma(src.invSixSigma)
158 , isFast(src.isFast) {
Brian Salomone7366842019-09-04 11:20:45 -0400159 this->setTextureSamplerCnt(1);
160}
Ethan Nicholas82399462017-10-16 12:35:44 -0400161std::unique_ptr<GrFragmentProcessor> GrRectBlurEffect::clone() const {
162 return std::unique_ptr<GrFragmentProcessor>(new GrRectBlurEffect(*this));
163}
Brian Salomone7366842019-09-04 11:20:45 -0400164const GrFragmentProcessor::TextureSampler& GrRectBlurEffect::onTextureSampler(int index) const {
Brian Salomonb2d5d402019-09-10 10:11:52 -0400165 return IthTextureSampler(index, integral);
Brian Salomone7366842019-09-04 11:20:45 -0400166}
Ethan Nicholas82399462017-10-16 12:35:44 -0400167GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrRectBlurEffect);
168#if GR_TEST_UTILS
169std::unique_ptr<GrFragmentProcessor> GrRectBlurEffect::TestCreate(GrProcessorTestData* data) {
Mike Kleind6ab77a2019-03-21 08:18:24 -0500170 float sigma = data->fRandom->nextRangeF(3, 8);
171 float width = data->fRandom->nextRangeF(200, 300);
Ethan Nicholas82399462017-10-16 12:35:44 -0400172 float height = data->fRandom->nextRangeF(200, 300);
Mike Kleind6ab77a2019-03-21 08:18:24 -0500173 return GrRectBlurEffect::Make(data->proxyProvider(), *data->caps()->shaderCaps(),
174 SkRect::MakeWH(width, height), sigma);
Ethan Nicholas82399462017-10-16 12:35:44 -0400175}
176#endif