blob: b176d0c567e0af1819d3c1d777b339a019205478 [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
John Stiles45f5b032020-07-27 17:31:29 -040013#include "src/core/SkUtils.h"
Greg Daniel456f9b52020-03-05 19:14:18 +000014#include "src/gpu/GrTexture.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050015#include "src/gpu/glsl/GrGLSLFragmentProcessor.h"
16#include "src/gpu/glsl/GrGLSLFragmentShaderBuilder.h"
17#include "src/gpu/glsl/GrGLSLProgramBuilder.h"
18#include "src/sksl/SkSLCPP.h"
19#include "src/sksl/SkSLUtil.h"
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050020class GrGLSLMagnifierEffect : public GrGLSLFragmentProcessor {
21public:
22 GrGLSLMagnifierEffect() {}
23 void emitCode(EmitArgs& args) override {
24 GrGLSLFPFragmentBuilder* fragBuilder = args.fFragBuilder;
Mike Kleind6ab77a2019-03-21 08:18:24 -050025 const GrMagnifierEffect& _outer = args.fFp.cast<GrMagnifierEffect>();
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050026 (void)_outer;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040027 auto bounds = _outer.bounds;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050028 (void)bounds;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040029 auto srcRect = _outer.srcRect;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050030 (void)srcRect;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040031 auto xInvZoom = _outer.xInvZoom;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050032 (void)xInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040033 auto yInvZoom = _outer.yInvZoom;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050034 (void)yInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040035 auto xInvInset = _outer.xInvInset;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050036 (void)xInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040037 auto yInvInset = _outer.yInvInset;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050038 (void)yInvInset;
John Stiles50819422020-06-18 13:00:38 -040039 boundsUniformVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
40 kFloat4_GrSLType, "boundsUniform");
41 xInvZoomVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
42 kFloat_GrSLType, "xInvZoom");
43 yInvZoomVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
44 kFloat_GrSLType, "yInvZoom");
45 xInvInsetVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
46 kFloat_GrSLType, "xInvInset");
47 yInvInsetVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
48 kFloat_GrSLType, "yInvInset");
49 offsetVar = args.fUniformHandler->addUniform(&_outer, kFragment_GrShaderFlag,
50 kHalf2_GrSLType, "offset");
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050051 fragBuilder->codeAppendf(
Michael Ludwigfc2fdf02020-06-29 17:20:13 -040052 R"SkSL(float2 zoom_coord = float2(%s) + %s * float2(%s, %s);
53float2 delta = (%s - %s.xy) * %s.zw;
John Stiles50819422020-06-18 13:00:38 -040054delta = 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 Ludwigfc2fdf02020-06-29 17:20:13 -040066 args.fUniformHandler->getUniformCStr(offsetVar), args.fSampleCoord,
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040067 args.fUniformHandler->getUniformCStr(xInvZoomVar),
Michael Ludwigfc2fdf02020-06-29 17:20:13 -040068 args.fUniformHandler->getUniformCStr(yInvZoomVar), args.fSampleCoord,
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040069 args.fUniformHandler->getUniformCStr(boundsUniformVar),
70 args.fUniformHandler->getUniformCStr(boundsUniformVar),
71 args.fUniformHandler->getUniformCStr(xInvInsetVar),
72 args.fUniformHandler->getUniformCStr(yInvInsetVar));
Michael Ludwigfc2fdf02020-06-29 17:20:13 -040073 SkString _coords1043 = SkStringPrintf("mix(%s, zoom_coord, weight)", args.fSampleCoord);
Brian Osman12c5d292020-07-13 16:11:35 -040074 SkString _sample1043 = this->invokeChild(0, args, _coords1043.c_str());
John Stiles50819422020-06-18 13:00:38 -040075 fragBuilder->codeAppendf(
76 R"SkSL(
77%s = %s;
78)SkSL",
Michael Ludwigfc2fdf02020-06-29 17:20:13 -040079 args.fOutputColor, _sample1043.c_str());
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050080 }
81
82private:
83 void onSetData(const GrGLSLProgramDataManager& pdman,
Mike Kleind6ab77a2019-03-21 08:18:24 -050084 const GrFragmentProcessor& _proc) override {
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050085 const GrMagnifierEffect& _outer = _proc.cast<GrMagnifierEffect>();
86 {
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040087 pdman.set1f(xInvZoomVar, (_outer.xInvZoom));
88 pdman.set1f(yInvZoomVar, (_outer.yInvZoom));
89 pdman.set1f(xInvInsetVar, (_outer.xInvInset));
90 pdman.set1f(yInvInsetVar, (_outer.yInvInset));
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050091 }
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040092 auto bounds = _outer.bounds;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050093 (void)bounds;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040094 UniformHandle& boundsUniform = boundsUniformVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050095 (void)boundsUniform;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040096 auto srcRect = _outer.srcRect;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050097 (void)srcRect;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -040098 UniformHandle& xInvZoom = xInvZoomVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -050099 (void)xInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400100 UniformHandle& yInvZoom = yInvZoomVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500101 (void)yInvZoom;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400102 UniformHandle& xInvInset = xInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500103 (void)xInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400104 UniformHandle& yInvInset = yInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500105 (void)yInvInset;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400106 UniformHandle& offset = offsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500107 (void)offset;
108
Brian Salomonf5cd6042020-06-16 14:04:25 -0400109 pdman.set2f(offset, srcRect.x(), srcRect.y());
John Stiles50819422020-06-18 13:00:38 -0400110 pdman.set4f(boundsUniform, bounds.x(), bounds.y(), 1.f / bounds.width(),
111 1.f / bounds.height());
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500112 }
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400113 UniformHandle boundsUniformVar;
114 UniformHandle offsetVar;
115 UniformHandle xInvZoomVar;
116 UniformHandle yInvZoomVar;
117 UniformHandle xInvInsetVar;
118 UniformHandle yInvInsetVar;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500119};
120GrGLSLFragmentProcessor* GrMagnifierEffect::onCreateGLSLInstance() const {
121 return new GrGLSLMagnifierEffect();
122}
Mike Kleind6ab77a2019-03-21 08:18:24 -0500123void GrMagnifierEffect::onGetGLSLProcessorKey(const GrShaderCaps& caps,
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500124 GrProcessorKeyBuilder* b) const {}
125bool GrMagnifierEffect::onIsEqual(const GrFragmentProcessor& other) const {
126 const GrMagnifierEffect& that = other.cast<GrMagnifierEffect>();
127 (void)that;
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400128 if (bounds != that.bounds) return false;
129 if (srcRect != that.srcRect) return false;
130 if (xInvZoom != that.xInvZoom) return false;
131 if (yInvZoom != that.yInvZoom) return false;
132 if (xInvInset != that.xInvInset) return false;
133 if (yInvInset != that.yInvInset) return false;
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500134 return true;
135}
136GrMagnifierEffect::GrMagnifierEffect(const GrMagnifierEffect& src)
137 : INHERITED(kGrMagnifierEffect_ClassID, src.optimizationFlags())
Ethan Nicholasbcd51e82019-04-09 10:40:41 -0400138 , bounds(src.bounds)
139 , srcRect(src.srcRect)
140 , xInvZoom(src.xInvZoom)
141 , yInvZoom(src.yInvZoom)
142 , xInvInset(src.xInvInset)
143 , yInvInset(src.yInvInset) {
Brian Osman12c5d292020-07-13 16:11:35 -0400144 this->cloneAndRegisterAllChildProcessors(src);
Michael Ludwige88320b2020-06-24 09:04:56 -0400145 this->setUsesSampleCoordsDirectly();
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500146}
147std::unique_ptr<GrFragmentProcessor> GrMagnifierEffect::clone() const {
John Stilesfbd050b2020-08-03 13:21:46 -0400148 return std::make_unique<GrMagnifierEffect>(*this);
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500149}
150GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrMagnifierEffect);
151#if GR_TEST_UTILS
152std::unique_ptr<GrFragmentProcessor> GrMagnifierEffect::TestCreate(GrProcessorTestData* d) {
Mike Kleind6ab77a2019-03-21 08:18:24 -0500153 const int kMaxWidth = 200;
154 const int kMaxHeight = 200;
155 const SkScalar kMaxInset = 20.0f;
156 uint32_t width = d->fRandom->nextULessThan(kMaxWidth);
157 uint32_t height = d->fRandom->nextULessThan(kMaxHeight);
158 SkScalar inset = d->fRandom->nextRangeScalar(1.0f, kMaxInset);
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500159
Mike Kleind6ab77a2019-03-21 08:18:24 -0500160 SkIRect bounds = SkIRect::MakeWH(SkIntToScalar(kMaxWidth), SkIntToScalar(kMaxHeight));
161 SkRect srcRect = SkRect::MakeWH(SkIntToScalar(width), SkIntToScalar(height));
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500162
Brian Salomonf5cd6042020-06-16 14:04:25 -0400163 auto src = GrProcessorUnitTest::MakeChildFP(d);
164 auto effect = GrMagnifierEffect::Make(std::move(src),
Ethan Nicholas2d5f9b32017-12-13 14:36:14 -0500165 bounds,
166 srcRect,
167 srcRect.width() / bounds.width(),
168 srcRect.height() / bounds.height(),
169 bounds.width() / inset,
170 bounds.height() / inset);
171 SkASSERT(effect);
172 return effect;
173}
174#endif