blob: b447b1a3866ae86dd289d4e506e90d14472df8fb [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 Nicholas2d5f9b32017-12-13 14:36:14 -050050 fragBuilder->codeAppendf(
John Stiles50819422020-06-18 13:00:38 -040051 R"SkSL(float2 coord = %s;
52float2 zoom_coord = float2(%s) + coord * float2(%s, %s);
53float2 delta = (coord - %s.xy) * %s.zw;
54delta = min(delta, float2(half2(1.0, 1.0)) - delta);
55delta *= float2(%s, %s);
56float weight = 0.0;
57if (delta.x < 2.0 && delta.y < 2.0) {
58 delta = float2(half2(2.0, 2.0)) - delta;
59 float dist = length(delta);
60 dist = max(2.0 - dist, 0.0);
61 weight = min(dist * dist, 1.0);
62} else {
63 float2 delta_squared = delta * delta;
64 weight = min(min(delta_squared.x, delta_squared.y), 1.0);
65})SkSL",
Michael Ludwige88320b2020-06-24 09:04:56 -040066 args.fSampleCoord, args.fUniformHandler->getUniformCStr(offsetVar),
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040067 args.fUniformHandler->getUniformCStr(xInvZoomVar),
68 args.fUniformHandler->getUniformCStr(yInvZoomVar),
69 args.fUniformHandler->getUniformCStr(boundsUniformVar),
70 args.fUniformHandler->getUniformCStr(boundsUniformVar),
71 args.fUniformHandler->getUniformCStr(xInvInsetVar),
72 args.fUniformHandler->getUniformCStr(yInvInsetVar));
Michael Ludwigfbe28592020-06-26 16:02:15 -040073 SkString _coords1077("mix(coord, zoom_coord, weight)");
74 SkString _sample1077;
75 _sample1077 = this->invokeChild(_outer.src_index, args, _coords1077.c_str());
John Stiles50819422020-06-18 13:00:38 -040076 fragBuilder->codeAppendf(
77 R"SkSL(
78%s = %s;
79)SkSL",
Michael Ludwigfbe28592020-06-26 16:02:15 -040080 args.fOutputColor, _sample1077.c_str());
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050081 }
82
83private:
84 void onSetData(const GrGLSLProgramDataManager& pdman,
Mike Kleind6ab77a2019-03-21 08:18:24 -050085 const GrFragmentProcessor& _proc) override {
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050086 const GrMagnifierEffect& _outer = _proc.cast<GrMagnifierEffect>();
87 {
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040088 pdman.set1f(xInvZoomVar, (_outer.xInvZoom));
89 pdman.set1f(yInvZoomVar, (_outer.yInvZoom));
90 pdman.set1f(xInvInsetVar, (_outer.xInvInset));
91 pdman.set1f(yInvInsetVar, (_outer.yInvInset));
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050092 }
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040093 auto bounds = _outer.bounds;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050094 (void)bounds;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040095 UniformHandle& boundsUniform = boundsUniformVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050096 (void)boundsUniform;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040097 auto srcRect = _outer.srcRect;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050098 (void)srcRect;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040099 UniformHandle& xInvZoom = xInvZoomVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500100 (void)xInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400101 UniformHandle& yInvZoom = yInvZoomVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500102 (void)yInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400103 UniformHandle& xInvInset = xInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500104 (void)xInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400105 UniformHandle& yInvInset = yInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500106 (void)yInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400107 UniformHandle& offset = offsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500108 (void)offset;
109
Brian Salomonf5cd6042020-06-16 14:04:25 -0400110 pdman.set2f(offset, srcRect.x(), srcRect.y());
John Stiles50819422020-06-18 13:00:38 -0400111 pdman.set4f(boundsUniform, bounds.x(), bounds.y(), 1.f / bounds.width(),
112 1.f / bounds.height());
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500113 }
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400114 UniformHandle boundsUniformVar;
115 UniformHandle offsetVar;
116 UniformHandle xInvZoomVar;
117 UniformHandle yInvZoomVar;
118 UniformHandle xInvInsetVar;
119 UniformHandle yInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500120};
121GrGLSLFragmentProcessor* GrMagnifierEffect::onCreateGLSLInstance() const {
122 return new GrGLSLMagnifierEffect();
123}
Mike Kleind6ab77a2019-03-21 08:18:24 -0500124void GrMagnifierEffect::onGetGLSLProcessorKey(const GrShaderCaps& caps,
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500125 GrProcessorKeyBuilder* b) const {}
126bool GrMagnifierEffect::onIsEqual(const GrFragmentProcessor& other) const {
127 const GrMagnifierEffect& that = other.cast<GrMagnifierEffect>();
128 (void)that;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400129 if (bounds != that.bounds) return false;
130 if (srcRect != that.srcRect) return false;
131 if (xInvZoom != that.xInvZoom) return false;
132 if (yInvZoom != that.yInvZoom) return false;
133 if (xInvInset != that.xInvInset) return false;
134 if (yInvInset != that.yInvInset) return false;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500135 return true;
136}
137GrMagnifierEffect::GrMagnifierEffect(const GrMagnifierEffect& src)
138 : INHERITED(kGrMagnifierEffect_ClassID, src.optimizationFlags())
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400139 , bounds(src.bounds)
140 , srcRect(src.srcRect)
141 , xInvZoom(src.xInvZoom)
142 , yInvZoom(src.yInvZoom)
143 , xInvInset(src.xInvInset)
144 , yInvInset(src.yInvInset) {
Brian Salomonf5cd6042020-06-16 14:04:25 -0400145 { src_index = this->cloneAndRegisterChildProcessor(src.childProcessor(src.src_index)); }
Michael Ludwige88320b2020-06-24 09:04:56 -0400146 this->setUsesSampleCoordsDirectly();
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500147}
148std::unique_ptr<GrFragmentProcessor> GrMagnifierEffect::clone() const {
149 return std::unique_ptr<GrFragmentProcessor>(new GrMagnifierEffect(*this));
150}
151GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrMagnifierEffect);
152#if GR_TEST_UTILS
153std::unique_ptr<GrFragmentProcessor> GrMagnifierEffect::TestCreate(GrProcessorTestData* d) {
Mike Kleind6ab77a2019-03-21 08:18:24 -0500154 const int kMaxWidth = 200;
155 const int kMaxHeight = 200;
156 const SkScalar kMaxInset = 20.0f;
157 uint32_t width = d->fRandom->nextULessThan(kMaxWidth);
158 uint32_t height = d->fRandom->nextULessThan(kMaxHeight);
159 SkScalar inset = d->fRandom->nextRangeScalar(1.0f, kMaxInset);
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500160
Mike Kleind6ab77a2019-03-21 08:18:24 -0500161 SkIRect bounds = SkIRect::MakeWH(SkIntToScalar(kMaxWidth), SkIntToScalar(kMaxHeight));
162 SkRect srcRect = SkRect::MakeWH(SkIntToScalar(width), SkIntToScalar(height));
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500163
Brian Salomonf5cd6042020-06-16 14:04:25 -0400164 auto src = GrProcessorUnitTest::MakeChildFP(d);
165 auto effect = GrMagnifierEffect::Make(std::move(src),
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500166 bounds,
167 srcRect,
168 srcRect.width() / bounds.width(),
169 srcRect.height() / bounds.height(),
170 bounds.width() / inset,
171 bounds.height() / inset);
172 SkASSERT(effect);
173 return effect;
174}
175#endif