| /* |
| * Copyright 2019 Google LLC |
| * |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| |
| /************************************************************************************************** |
| *** This file was autogenerated from GrColorMatrixFragmentProcessor.fp; do not modify. |
| **************************************************************************************************/ |
| #include "GrColorMatrixFragmentProcessor.h" |
| |
| #include "src/core/SkUtils.h" |
| #include "src/gpu/GrTexture.h" |
| #include "src/gpu/glsl/GrGLSLFragmentProcessor.h" |
| #include "src/gpu/glsl/GrGLSLFragmentShaderBuilder.h" |
| #include "src/gpu/glsl/GrGLSLProgramBuilder.h" |
| #include "src/sksl/SkSLCPP.h" |
| #include "src/sksl/SkSLUtil.h" |
| class GrGLSLColorMatrixFragmentProcessor : public GrGLSLFragmentProcessor { |
| public: |
| GrGLSLColorMatrixFragmentProcessor() {} |
| void emitCode(EmitArgs& args) override { |
| GrGLSLFPFragmentBuilder* fragBuilder = args.fFragBuilder; |
| const GrColorMatrixFragmentProcessor& _outer = |
| args.fFp.cast<GrColorMatrixFragmentProcessor>(); |
| (void)_outer; |
| auto m = _outer.m; |
| (void)m; |
| auto v = _outer.v; |
| (void)v; |
| auto unpremulInput = _outer.unpremulInput; |
| (void)unpremulInput; |
| auto clampRGBOutput = _outer.clampRGBOutput; |
| (void)clampRGBOutput; |
| auto premulOutput = _outer.premulOutput; |
| (void)premulOutput; |
| mVar = args.fUniformHandler->addUniform( |
| &_outer, kFragment_GrShaderFlag, kHalf4x4_GrSLType, "m"); |
| vVar = args.fUniformHandler->addUniform( |
| &_outer, kFragment_GrShaderFlag, kHalf4_GrSLType, "v"); |
| SkString _sample0 = this->invokeChild(0, args); |
| fragBuilder->codeAppendf( |
| R"SkSL(half4 color = %s; |
| @if (%s) { |
| color = half4(color.xyz / max(color.w, 9.9999997473787516e-05), color.w); |
| } |
| color = (sk_Caps.rewriteMatrixVectorMultiply ? ((%s[0] * color.x + %s[1] * color.y) + %s[2] * color.z) + %s[3] * color.w : %s * color) + %s; |
| @if (%s) { |
| color = clamp(color, 0.0, 1.0); |
| } else { |
| color.w = clamp(color.w, 0.0, 1.0); |
| } |
| @if (%s) { |
| color.xyz *= color.w; |
| } |
| return color; |
| )SkSL", |
| _sample0.c_str(), |
| (_outer.unpremulInput ? "true" : "false"), |
| args.fUniformHandler->getUniformCStr(mVar), |
| args.fUniformHandler->getUniformCStr(mVar), |
| args.fUniformHandler->getUniformCStr(mVar), |
| args.fUniformHandler->getUniformCStr(mVar), |
| args.fUniformHandler->getUniformCStr(mVar), |
| args.fUniformHandler->getUniformCStr(vVar), |
| (_outer.clampRGBOutput ? "true" : "false"), |
| (_outer.premulOutput ? "true" : "false")); |
| } |
| |
| private: |
| void onSetData(const GrGLSLProgramDataManager& pdman, |
| const GrFragmentProcessor& _proc) override { |
| const GrColorMatrixFragmentProcessor& _outer = _proc.cast<GrColorMatrixFragmentProcessor>(); |
| { |
| const SkM44& mValue = _outer.m; |
| if (mPrev != (mValue)) { |
| mPrev = mValue; |
| static_assert(1 == 1); |
| pdman.setSkM44(mVar, mValue); |
| } |
| const SkV4& vValue = _outer.v; |
| if (vPrev != (vValue)) { |
| vPrev = vValue; |
| pdman.set4fv(vVar, 1, vValue.ptr()); |
| } |
| } |
| } |
| SkM44 mPrev = SkM44(SkM44::kNaN_Constructor); |
| SkV4 vPrev = SkV4{SK_FloatNaN, SK_FloatNaN, SK_FloatNaN, SK_FloatNaN}; |
| UniformHandle mVar; |
| UniformHandle vVar; |
| }; |
| std::unique_ptr<GrGLSLFragmentProcessor> GrColorMatrixFragmentProcessor::onMakeProgramImpl() const { |
| return std::make_unique<GrGLSLColorMatrixFragmentProcessor>(); |
| } |
| void GrColorMatrixFragmentProcessor::onGetGLSLProcessorKey(const GrShaderCaps& caps, |
| GrProcessorKeyBuilder* b) const { |
| b->addBool(unpremulInput, "unpremulInput"); |
| b->addBool(clampRGBOutput, "clampRGBOutput"); |
| b->addBool(premulOutput, "premulOutput"); |
| } |
| bool GrColorMatrixFragmentProcessor::onIsEqual(const GrFragmentProcessor& other) const { |
| const GrColorMatrixFragmentProcessor& that = other.cast<GrColorMatrixFragmentProcessor>(); |
| (void)that; |
| if (m != that.m) return false; |
| if (v != that.v) return false; |
| if (unpremulInput != that.unpremulInput) return false; |
| if (clampRGBOutput != that.clampRGBOutput) return false; |
| if (premulOutput != that.premulOutput) return false; |
| return true; |
| } |
| GrColorMatrixFragmentProcessor::GrColorMatrixFragmentProcessor( |
| const GrColorMatrixFragmentProcessor& src) |
| : INHERITED(kGrColorMatrixFragmentProcessor_ClassID, src.optimizationFlags()) |
| , m(src.m) |
| , v(src.v) |
| , unpremulInput(src.unpremulInput) |
| , clampRGBOutput(src.clampRGBOutput) |
| , premulOutput(src.premulOutput) { |
| this->cloneAndRegisterAllChildProcessors(src); |
| } |
| std::unique_ptr<GrFragmentProcessor> GrColorMatrixFragmentProcessor::clone() const { |
| return std::make_unique<GrColorMatrixFragmentProcessor>(*this); |
| } |
| #if GR_TEST_UTILS |
| SkString GrColorMatrixFragmentProcessor::onDumpInfo() const { |
| return SkStringPrintf( |
| "(m=half4x4(%f, %f, %f, %f, %f, %f, %f, %f, %f, %f, %f, %f, %f, %f, %f, %f), " |
| "v=half4(%f, %f, %f, %f), unpremulInput=%s, clampRGBOutput=%s, premulOutput=%s)", |
| m.rc(0, 0), |
| m.rc(1, 0), |
| m.rc(2, 0), |
| m.rc(3, 0), |
| m.rc(0, 1), |
| m.rc(1, 1), |
| m.rc(2, 1), |
| m.rc(3, 1), |
| m.rc(0, 2), |
| m.rc(1, 2), |
| m.rc(2, 2), |
| m.rc(3, 2), |
| m.rc(0, 3), |
| m.rc(1, 3), |
| m.rc(2, 3), |
| m.rc(3, 3), |
| v.x, |
| v.y, |
| v.z, |
| v.w, |
| (unpremulInput ? "true" : "false"), |
| (clampRGBOutput ? "true" : "false"), |
| (premulOutput ? "true" : "false")); |
| } |
| #endif |
| GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrColorMatrixFragmentProcessor); |
| #if GR_TEST_UTILS |
| std::unique_ptr<GrFragmentProcessor> GrColorMatrixFragmentProcessor::TestCreate( |
| GrProcessorTestData* d) { |
| float m[20]; |
| for (int i = 0; i < 20; ++i) { |
| m[i] = d->fRandom->nextRangeScalar(-10.f, 10.f); |
| } |
| bool unpremul = d->fRandom->nextBool(); |
| bool clampRGB = d->fRandom->nextBool(); |
| bool premul = d->fRandom->nextBool(); |
| return Make(d->inputFP(), m, unpremul, clampRGB, premul); |
| } |
| #endif |