blob: cb421ad7f34d3849d38c3f19a886386e2175fdff [file] [log] [blame]
joshualitt8072caa2015-02-12 14:20:52 -08001/*
2 * Copyright 2014 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
egdaniele659a582015-11-13 09:55:43 -08008#include "GrGLSLGeometryProcessor.h"
joshualitt8072caa2015-02-12 14:20:52 -08009
egdaniel7ea439b2015-12-03 09:20:44 -080010#include "GrCoordTransform.h"
egdaniel2d721d32015-11-11 13:06:05 -080011#include "glsl/GrGLSLFragmentShaderBuilder.h"
egdaniel7ea439b2015-12-03 09:20:44 -080012#include "glsl/GrGLSLUniformHandler.h"
egdaniel0eafe792015-11-20 14:01:22 -080013#include "glsl/GrGLSLVarying.h"
egdaniel2d721d32015-11-11 13:06:05 -080014#include "glsl/GrGLSLVertexShaderBuilder.h"
joshualitt8072caa2015-02-12 14:20:52 -080015
egdaniele659a582015-11-13 09:55:43 -080016void GrGLSLGeometryProcessor::emitCode(EmitArgs& args) {
egdaniel4ca2e602015-11-18 08:01:26 -080017 GrGLSLVertexBuilder* vBuilder = args.fVertBuilder;
joshualitt8072caa2015-02-12 14:20:52 -080018 GrGPArgs gpArgs;
19 this->onEmitCode(args, &gpArgs);
csmartdalton936f81b2017-02-13 15:45:35 -070020 vBuilder->transformToNormalizedDeviceSpace(gpArgs.fPositionVar, args.fRTAdjustName);
Ethan Nicholas8aa45692017-09-20 11:24:15 -040021 if (kFloat2_GrSLType == gpArgs.fPositionVar.getType() ||
Ethan Nicholasf7b88202017-09-18 14:10:39 -040022 kHalf2_GrSLType == gpArgs.fPositionVar.getType()) {
cdaltonc08f1962016-02-12 12:14:06 -080023 args.fVaryingHandler->setNoPerspective();
24 }
joshualitt8072caa2015-02-12 14:20:52 -080025}
26
egdaniel7ea439b2015-12-03 09:20:44 -080027void GrGLSLGeometryProcessor::emitTransforms(GrGLSLVertexBuilder* vb,
egdaniel0eafe792015-11-20 14:01:22 -080028 GrGLSLVaryingHandler* varyingHandler,
egdaniel7ea439b2015-12-03 09:20:44 -080029 GrGLSLUniformHandler* uniformHandler,
egdaniele659a582015-11-13 09:55:43 -080030 const GrShaderVar& posVar,
31 const char* localCoords,
32 const SkMatrix& localMatrix,
bsalomona624bf32016-09-20 09:12:47 -070033 FPCoordTransformHandler* handler) {
34 int i = 0;
35 while (const GrCoordTransform* coordTransform = handler->nextCoordTransform()) {
36 SkString strUniName;
37 strUniName.printf("CoordTransformMatrix_%d", i);
38 GrSLType varyingType;
joshualitt8072caa2015-02-12 14:20:52 -080039
bsalomona624bf32016-09-20 09:12:47 -070040 uint32_t type = coordTransform->getMatrix().getType();
Brian Salomon2ebd0c82016-10-03 17:15:28 -040041 type |= localMatrix.getType();
42
Ethan Nicholas8aa45692017-09-20 11:24:15 -040043 varyingType = SkToBool(SkMatrix::kPerspective_Mask & type) ? kFloat3_GrSLType :
44 kFloat2_GrSLType;
bsalomona624bf32016-09-20 09:12:47 -070045 const char* uniName;
joshualitt8072caa2015-02-12 14:20:52 -080046
joshualitt8072caa2015-02-12 14:20:52 -080047
bsalomona624bf32016-09-20 09:12:47 -070048 fInstalledTransforms.push_back().fHandle = uniformHandler->addUniform(kVertex_GrShaderFlag,
Ethan Nicholas8aa45692017-09-20 11:24:15 -040049 kFloat3x3_GrSLType,
bsalomona624bf32016-09-20 09:12:47 -070050 strUniName.c_str(),
51 &uniName).toIndex();
52 SkString strVaryingName;
53 strVaryingName.printf("TransformedCoords_%d", i);
joshualitt8072caa2015-02-12 14:20:52 -080054
bsalomona624bf32016-09-20 09:12:47 -070055 GrGLSLVertToFrag v(varyingType);
Chris Daltonfdde34e2017-10-16 14:15:26 -060056 varyingHandler->addVarying(strVaryingName.c_str(), &v);
joshualitt8072caa2015-02-12 14:20:52 -080057
Ethan Nicholas8aa45692017-09-20 11:24:15 -040058 SkASSERT(kFloat2_GrSLType == varyingType || kFloat3_GrSLType == varyingType);
bsalomona624bf32016-09-20 09:12:47 -070059 handler->specifyCoordsForCurrCoordTransform(SkString(v.fsIn()), varyingType);
60
Ethan Nicholas8aa45692017-09-20 11:24:15 -040061 if (kFloat2_GrSLType == varyingType) {
62 vb->codeAppendf("%s = (%s * float3(%s, 1)).xy;", v.vsOut(), uniName, localCoords);
bsalomona624bf32016-09-20 09:12:47 -070063 } else {
Ethan Nicholas8aa45692017-09-20 11:24:15 -040064 vb->codeAppendf("%s = %s * float3(%s, 1);", v.vsOut(), uniName, localCoords);
joshualitt8072caa2015-02-12 14:20:52 -080065 }
bsalomona624bf32016-09-20 09:12:47 -070066 ++i;
joshualitt8072caa2015-02-12 14:20:52 -080067 }
68}
69
bsalomona624bf32016-09-20 09:12:47 -070070void GrGLSLGeometryProcessor::setTransformDataHelper(const SkMatrix& localMatrix,
71 const GrGLSLProgramDataManager& pdman,
72 FPCoordTransformIter* transformIter) {
73 int i = 0;
74 while (const GrCoordTransform* coordTransform = transformIter->next()) {
75 const SkMatrix& m = GetTransformMatrix(localMatrix, *coordTransform);
76 if (!fInstalledTransforms[i].fCurrentValue.cheapEqualTo(m)) {
77 pdman.setSkMatrix(fInstalledTransforms[i].fHandle.toIndex(), m);
78 fInstalledTransforms[i].fCurrentValue = m;
79 }
80 ++i;
81 }
82 SkASSERT(i == fInstalledTransforms.count());
83}
84
Brian Salomon7f235432017-08-16 09:41:48 -040085void GrGLSLGeometryProcessor::writeOutputPosition(GrGLSLVertexBuilder* vertBuilder,
86 GrGPArgs* gpArgs,
87 const char* posName) {
Ethan Nicholas8aa45692017-09-20 11:24:15 -040088 gpArgs->fPositionVar.set(kFloat2_GrSLType, "pos2");
89 vertBuilder->codeAppendf("float2 %s = %s;", gpArgs->fPositionVar.c_str(), posName);
joshualitt5559ca22015-05-21 15:50:36 -070090}
91
Brian Salomon7f235432017-08-16 09:41:48 -040092void GrGLSLGeometryProcessor::writeOutputPosition(GrGLSLVertexBuilder* vertBuilder,
93 GrGLSLUniformHandler* uniformHandler,
94 GrGPArgs* gpArgs,
95 const char* posName,
96 const SkMatrix& mat,
97 UniformHandle* viewMatrixUniform) {
joshualitt8072caa2015-02-12 14:20:52 -080098 if (mat.isIdentity()) {
Ethan Nicholas8aa45692017-09-20 11:24:15 -040099 gpArgs->fPositionVar.set(kFloat2_GrSLType, "pos2");
100 vertBuilder->codeAppendf("float2 %s = %s;", gpArgs->fPositionVar.c_str(), posName);
joshualitt8072caa2015-02-12 14:20:52 -0800101 } else {
joshualitt5559ca22015-05-21 15:50:36 -0700102 const char* viewMatrixName;
cdalton5e58cee2016-02-11 12:49:47 -0800103 *viewMatrixUniform = uniformHandler->addUniform(kVertex_GrShaderFlag,
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400104 kFloat3x3_GrSLType,
egdaniel7ea439b2015-12-03 09:20:44 -0800105 "uViewM",
106 &viewMatrixName);
joshualitt5559ca22015-05-21 15:50:36 -0700107 if (!mat.hasPerspective()) {
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400108 gpArgs->fPositionVar.set(kFloat2_GrSLType, "pos2");
109 vertBuilder->codeAppendf("float2 %s = (%s * float3(%s, 1)).xy;",
egdaniel4ca2e602015-11-18 08:01:26 -0800110 gpArgs->fPositionVar.c_str(), viewMatrixName, posName);
joshualitt5559ca22015-05-21 15:50:36 -0700111 } else {
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400112 gpArgs->fPositionVar.set(kFloat3_GrSLType, "pos3");
113 vertBuilder->codeAppendf("float3 %s = %s * float3(%s, 1);",
egdaniel4ca2e602015-11-18 08:01:26 -0800114 gpArgs->fPositionVar.c_str(), viewMatrixName, posName);
joshualitt5559ca22015-05-21 15:50:36 -0700115 }
joshualitt8072caa2015-02-12 14:20:52 -0800116 }
117}