blob: acc344d4a864822497d87058d1915c334e2d958b [file] [log] [blame]
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -05001/*
Ethan Nicholas130fb3f2018-02-01 12:14:34 -05002 * Copyright 2018 Google Inc.
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -05003 *
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 GrMagnifierEffect.fp; do not modify.
10 **************************************************************************************************/
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050011#include "GrMagnifierEffect.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050012
Greg Daniel456f9b52020-03-05 19:14:18 +000013#include "src/gpu/GrTexture.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050014#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 Nicholas2d5f9b32017-12-13 14:36:14 -050019class GrGLSLMagnifierEffect : public GrGLSLFragmentProcessor {
20public:
21 GrGLSLMagnifierEffect() {}
22 void emitCode(EmitArgs& args) override {
23 GrGLSLFPFragmentBuilder* fragBuilder = args.fFragBuilder;
Mike Kleind6ab77a2019-03-21 08:18:24 -050024 const GrMagnifierEffect& _outer = args.fFp.cast<GrMagnifierEffect>();
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050025 (void)_outer;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040026 auto bounds = _outer.bounds;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050027 (void)bounds;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040028 auto srcRect = _outer.srcRect;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050029 (void)srcRect;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040030 auto xInvZoom = _outer.xInvZoom;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050031 (void)xInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040032 auto yInvZoom = _outer.yInvZoom;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050033 (void)yInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040034 auto xInvInset = _outer.xInvInset;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050035 (void)xInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040036 auto yInvInset = _outer.yInvInset;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050037 (void)yInvInset;
John Stiles50819422020-06-18 13:00:38 -040038 boundsUniformVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
39 kFloat4_GrSLType, "boundsUniform");
40 xInvZoomVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
41 kFloat_GrSLType, "xInvZoom");
42 yInvZoomVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
43 kFloat_GrSLType, "yInvZoom");
44 xInvInsetVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
45 kFloat_GrSLType, "xInvInset");
46 yInvInsetVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
47 kFloat_GrSLType, "yInvInset");
48 offsetVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
49 kHalf2_GrSLType, "offset");
Ethan Nicholas58430122020-04-14 09:54:02 -040050 SkString sk_TransformedCoords2D_0 = fragBuilder->ensureCoords2D(
51 args.fTransformedCoords[0].fVaryingPoint, _outer.sampleMatrix());
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050052 fragBuilder->codeAppendf(
John Stiles50819422020-06-18 13:00:38 -040053 R"SkSL(float2 coord = %s;
54float2 zoom_coord = float2(%s) + coord * float2(%s, %s);
55float2 delta = (coord - %s.xy) * %s.zw;
56delta = min(delta, float2(half2(1.0, 1.0)) - delta);
57delta *= float2(%s, %s);
58float weight = 0.0;
59if (delta.x < 2.0 && delta.y < 2.0) {
60 delta = float2(half2(2.0, 2.0)) - delta;
61 float dist = length(delta);
62 dist = max(2.0 - dist, 0.0);
63 weight = min(dist * dist, 1.0);
64} else {
65 float2 delta_squared = delta * delta;
66 weight = min(min(delta_squared.x, delta_squared.y), 1.0);
67})SkSL",
68 sk_TransformedCoords2D_0.c_str(), args.fUniformHandler->getUniformCStr(offsetVar),
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040069 args.fUniformHandler->getUniformCStr(xInvZoomVar),
70 args.fUniformHandler->getUniformCStr(yInvZoomVar),
71 args.fUniformHandler->getUniformCStr(boundsUniformVar),
72 args.fUniformHandler->getUniformCStr(boundsUniformVar),
73 args.fUniformHandler->getUniformCStr(xInvInsetVar),
74 args.fUniformHandler->getUniformCStr(yInvInsetVar));
Brian Salomonf5cd6042020-06-16 14:04:25 -040075 SkString _sample1112;
76 SkString _coords1112("mix(coord, zoom_coord, weight)");
77 _sample1112 = this->invokeChild(_outer.src_index, args, _coords1112.c_str());
John Stiles50819422020-06-18 13:00:38 -040078 fragBuilder->codeAppendf(
79 R"SkSL(
80%s = %s;
81)SkSL",
82 args.fOutputColor, _sample1112.c_str());
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050083 }
84
85private:
86 void onSetData(const GrGLSLProgramDataManager& pdman,
Mike Kleind6ab77a2019-03-21 08:18:24 -050087 const GrFragmentProcessor& _proc) override {
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050088 const GrMagnifierEffect& _outer = _proc.cast<GrMagnifierEffect>();
89 {
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040090 pdman.set1f(xInvZoomVar, (_outer.xInvZoom));
91 pdman.set1f(yInvZoomVar, (_outer.yInvZoom));
92 pdman.set1f(xInvInsetVar, (_outer.xInvInset));
93 pdman.set1f(yInvInsetVar, (_outer.yInvInset));
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050094 }
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040095 auto bounds = _outer.bounds;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050096 (void)bounds;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040097 UniformHandle& boundsUniform = boundsUniformVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050098 (void)boundsUniform;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040099 auto srcRect = _outer.srcRect;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500100 (void)srcRect;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400101 UniformHandle& xInvZoom = xInvZoomVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500102 (void)xInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400103 UniformHandle& yInvZoom = yInvZoomVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500104 (void)yInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400105 UniformHandle& xInvInset = xInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500106 (void)xInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400107 UniformHandle& yInvInset = yInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500108 (void)yInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400109 UniformHandle& offset = offsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500110 (void)offset;
111
Brian Salomonf5cd6042020-06-16 14:04:25 -0400112 pdman.set2f(offset, srcRect.x(), srcRect.y());
John Stiles50819422020-06-18 13:00:38 -0400113 pdman.set4f(boundsUniform, bounds.x(), bounds.y(), 1.f / bounds.width(),
114 1.f / bounds.height());
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500115 }
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400116 UniformHandle boundsUniformVar;
117 UniformHandle offsetVar;
118 UniformHandle xInvZoomVar;
119 UniformHandle yInvZoomVar;
120 UniformHandle xInvInsetVar;
121 UniformHandle yInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500122};
123GrGLSLFragmentProcessor* GrMagnifierEffect::onCreateGLSLInstance() const {
124 return new GrGLSLMagnifierEffect();
125}
Mike Kleind6ab77a2019-03-21 08:18:24 -0500126void GrMagnifierEffect::onGetGLSLProcessorKey(const GrShaderCaps& caps,
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500127 GrProcessorKeyBuilder* b) const {}
128bool GrMagnifierEffect::onIsEqual(const GrFragmentProcessor& other) const {
129 const GrMagnifierEffect& that = other.cast<GrMagnifierEffect>();
130 (void)that;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400131 if (bounds != that.bounds) return false;
132 if (srcRect != that.srcRect) return false;
133 if (xInvZoom != that.xInvZoom) return false;
134 if (yInvZoom != that.yInvZoom) return false;
135 if (xInvInset != that.xInvInset) return false;
136 if (yInvInset != that.yInvInset) return false;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500137 return true;
138}
139GrMagnifierEffect::GrMagnifierEffect(const GrMagnifierEffect& src)
140 : INHERITED(kGrMagnifierEffect_ClassID, src.optimizationFlags())
Brian Salomonf5cd6042020-06-16 14:04:25 -0400141 , fCoordTransform0(src.fCoordTransform0)
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400142 , bounds(src.bounds)
143 , srcRect(src.srcRect)
144 , xInvZoom(src.xInvZoom)
145 , yInvZoom(src.yInvZoom)
146 , xInvInset(src.xInvInset)
147 , yInvInset(src.yInvInset) {
Brian Salomonf5cd6042020-06-16 14:04:25 -0400148 { src_index = this->cloneAndRegisterChildProcessor(src.childProcessor(src.src_index)); }
149 this->addCoordTransform(&fCoordTransform0);
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500150}
151std::unique_ptr<GrFragmentProcessor> GrMagnifierEffect::clone() const {
152 return std::unique_ptr<GrFragmentProcessor>(new GrMagnifierEffect(*this));
153}
154GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrMagnifierEffect);
155#if GR_TEST_UTILS
156std::unique_ptr<GrFragmentProcessor> GrMagnifierEffect::TestCreate(GrProcessorTestData* d) {
Mike Kleind6ab77a2019-03-21 08:18:24 -0500157 const int kMaxWidth = 200;
158 const int kMaxHeight = 200;
159 const SkScalar kMaxInset = 20.0f;
160 uint32_t width = d->fRandom->nextULessThan(kMaxWidth);
161 uint32_t height = d->fRandom->nextULessThan(kMaxHeight);
162 SkScalar inset = d->fRandom->nextRangeScalar(1.0f, kMaxInset);
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500163
Mike Kleind6ab77a2019-03-21 08:18:24 -0500164 SkIRect bounds = SkIRect::MakeWH(SkIntToScalar(kMaxWidth), SkIntToScalar(kMaxHeight));
165 SkRect srcRect = SkRect::MakeWH(SkIntToScalar(width), SkIntToScalar(height));
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500166
Brian Salomonf5cd6042020-06-16 14:04:25 -0400167 auto src = GrProcessorUnitTest::MakeChildFP(d);
168 auto effect = GrMagnifierEffect::Make(std::move(src),
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500169 bounds,
170 srcRect,
171 srcRect.width() / bounds.width(),
172 srcRect.height() / bounds.height(),
173 bounds.width() / inset,
174 bounds.height() / inset);
175 SkASSERT(effect);
176 return effect;
177}
178#endif