blob: 9a768c21b456c40de6e1fed2164ed2e66e2403aa [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"
Chris Daltonc17bf322017-10-24 10:59:03 -060014#include "glsl/GrGLSLVertexGeoBuilder.h"
joshualitt8072caa2015-02-12 14:20:52 -080015
egdaniele659a582015-11-13 09:55:43 -080016void GrGLSLGeometryProcessor::emitCode(EmitArgs& args) {
joshualitt8072caa2015-02-12 14:20:52 -080017 GrGPArgs gpArgs;
18 this->onEmitCode(args, &gpArgs);
Chris Daltonc17bf322017-10-24 10:59:03 -060019
20 GrGLSLVertexBuilder* vBuilder = args.fVertBuilder;
21 if (!args.fGP.willUseGeoShader()) {
22 // Emit the vertex position to the hardware in the normalized window coordinates it expects.
Chris Dalton23261772017-12-10 16:41:45 -070023 SkASSERT(kFloat2_GrSLType == gpArgs.fPositionVar.getType() ||
24 kFloat3_GrSLType == gpArgs.fPositionVar.getType());
Chris Daltonc17bf322017-10-24 10:59:03 -060025 vBuilder->emitNormalizedSkPosition(gpArgs.fPositionVar.c_str(), args.fRTAdjustName,
26 gpArgs.fPositionVar.getType());
Chris Dalton23261772017-12-10 16:41:45 -070027 if (kFloat2_GrSLType == gpArgs.fPositionVar.getType()) {
28 args.fVaryingHandler->setNoPerspective();
29 }
Chris Daltonc17bf322017-10-24 10:59:03 -060030 } else {
31 // Since we have a geometry shader, leave the vertex position in Skia device space for now.
32 // The geometry Shader will operate in device space, and then convert the final positions to
33 // normalized hardware window coordinates under the hood, once everything else has finished.
Chris Dalton23261772017-12-10 16:41:45 -070034 // The subclass must call setNoPerspective on the varying handler, if applicable.
Chris Daltonc17bf322017-10-24 10:59:03 -060035 vBuilder->codeAppendf("sk_Position = float4(%s", gpArgs.fPositionVar.c_str());
Chris Dalton23261772017-12-10 16:41:45 -070036 switch (gpArgs.fPositionVar.getType()) {
37 case kFloat_GrSLType:
38 vBuilder->codeAppend(", 0"); // fallthru.
39 case kFloat2_GrSLType:
40 vBuilder->codeAppend(", 0"); // fallthru.
41 case kFloat3_GrSLType:
42 vBuilder->codeAppend(", 1"); // fallthru.
43 case kFloat4_GrSLType:
44 vBuilder->codeAppend(");");
45 break;
46 default:
47 SK_ABORT("Invalid position var type");
48 break;
Chris Daltonc17bf322017-10-24 10:59:03 -060049 }
cdaltonc08f1962016-02-12 12:14:06 -080050 }
joshualitt8072caa2015-02-12 14:20:52 -080051}
52
egdaniel7ea439b2015-12-03 09:20:44 -080053void GrGLSLGeometryProcessor::emitTransforms(GrGLSLVertexBuilder* vb,
egdaniel0eafe792015-11-20 14:01:22 -080054 GrGLSLVaryingHandler* varyingHandler,
egdaniel7ea439b2015-12-03 09:20:44 -080055 GrGLSLUniformHandler* uniformHandler,
Brian Salomon04460cc2017-12-06 14:47:42 -050056 const GrShaderVar& localCoordsVar,
egdaniele659a582015-11-13 09:55:43 -080057 const SkMatrix& localMatrix,
bsalomona624bf32016-09-20 09:12:47 -070058 FPCoordTransformHandler* handler) {
Brian Salomon04460cc2017-12-06 14:47:42 -050059 SkASSERT(GrSLTypeIsFloatType(localCoordsVar.getType()));
Brian Salomon0215e392017-12-15 11:41:09 -050060 SkASSERT(2 == GrSLTypeVecLength(localCoordsVar.getType()) ||
61 3 == GrSLTypeVecLength(localCoordsVar.getType()));
Brian Salomon04460cc2017-12-06 14:47:42 -050062
Brian Salomon0215e392017-12-15 11:41:09 -050063 bool threeComponentLocalCoords = 3 == GrSLTypeVecLength(localCoordsVar.getType());
64 SkString localCoords;
65 if (threeComponentLocalCoords) {
66 localCoords = localCoordsVar.getName();
67 } else {
68 localCoords.printf("float3(%s, 1)", localCoordsVar.c_str());
69 }
bsalomona624bf32016-09-20 09:12:47 -070070 int i = 0;
71 while (const GrCoordTransform* coordTransform = handler->nextCoordTransform()) {
72 SkString strUniName;
73 strUniName.printf("CoordTransformMatrix_%d", i);
bsalomona624bf32016-09-20 09:12:47 -070074 const char* uniName;
bsalomona624bf32016-09-20 09:12:47 -070075 fInstalledTransforms.push_back().fHandle = uniformHandler->addUniform(kVertex_GrShaderFlag,
Ethan Nicholas8aa45692017-09-20 11:24:15 -040076 kFloat3x3_GrSLType,
bsalomona624bf32016-09-20 09:12:47 -070077 strUniName.c_str(),
78 &uniName).toIndex();
Brian Salomon0215e392017-12-15 11:41:09 -050079 GrSLType varyingType = kFloat2_GrSLType;
80 if (localMatrix.hasPerspective() || coordTransform->getMatrix().hasPerspective()) {
81 varyingType = kFloat3_GrSLType;
82 }
bsalomona624bf32016-09-20 09:12:47 -070083 SkString strVaryingName;
84 strVaryingName.printf("TransformedCoords_%d", i);
Chris Dalton27372882017-12-08 13:34:21 -070085 GrGLSLVarying v(varyingType);
Chris Daltonfdde34e2017-10-16 14:15:26 -060086 varyingHandler->addVarying(strVaryingName.c_str(), &v);
joshualitt8072caa2015-02-12 14:20:52 -080087
bsalomona624bf32016-09-20 09:12:47 -070088 handler->specifyCoordsForCurrCoordTransform(SkString(v.fsIn()), varyingType);
89
Ethan Nicholas8aa45692017-09-20 11:24:15 -040090 if (kFloat2_GrSLType == varyingType) {
Brian Salomon0215e392017-12-15 11:41:09 -050091 vb->codeAppendf("%s = (%s * %s).xy;", v.vsOut(), uniName, localCoords.c_str());
92 if (threeComponentLocalCoords) {
93 vb->codeAppendf("%s /= %s.z;", v.vsOut(), localCoords.c_str());
94 }
bsalomona624bf32016-09-20 09:12:47 -070095 } else {
Brian Salomon0215e392017-12-15 11:41:09 -050096 vb->codeAppendf("%s = %s * %s;", v.vsOut(), uniName, localCoords.c_str());
joshualitt8072caa2015-02-12 14:20:52 -080097 }
bsalomona624bf32016-09-20 09:12:47 -070098 ++i;
joshualitt8072caa2015-02-12 14:20:52 -080099 }
100}
101
bsalomona624bf32016-09-20 09:12:47 -0700102void GrGLSLGeometryProcessor::setTransformDataHelper(const SkMatrix& localMatrix,
103 const GrGLSLProgramDataManager& pdman,
104 FPCoordTransformIter* transformIter) {
105 int i = 0;
106 while (const GrCoordTransform* coordTransform = transformIter->next()) {
107 const SkMatrix& m = GetTransformMatrix(localMatrix, *coordTransform);
108 if (!fInstalledTransforms[i].fCurrentValue.cheapEqualTo(m)) {
109 pdman.setSkMatrix(fInstalledTransforms[i].fHandle.toIndex(), m);
110 fInstalledTransforms[i].fCurrentValue = m;
111 }
112 ++i;
113 }
114 SkASSERT(i == fInstalledTransforms.count());
115}
116
Brian Salomon7f235432017-08-16 09:41:48 -0400117void GrGLSLGeometryProcessor::writeOutputPosition(GrGLSLVertexBuilder* vertBuilder,
118 GrGPArgs* gpArgs,
119 const char* posName) {
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400120 gpArgs->fPositionVar.set(kFloat2_GrSLType, "pos2");
121 vertBuilder->codeAppendf("float2 %s = %s;", gpArgs->fPositionVar.c_str(), posName);
joshualitt5559ca22015-05-21 15:50:36 -0700122}
123
Brian Salomon7f235432017-08-16 09:41:48 -0400124void GrGLSLGeometryProcessor::writeOutputPosition(GrGLSLVertexBuilder* vertBuilder,
125 GrGLSLUniformHandler* uniformHandler,
126 GrGPArgs* gpArgs,
127 const char* posName,
128 const SkMatrix& mat,
129 UniformHandle* viewMatrixUniform) {
joshualitt8072caa2015-02-12 14:20:52 -0800130 if (mat.isIdentity()) {
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400131 gpArgs->fPositionVar.set(kFloat2_GrSLType, "pos2");
132 vertBuilder->codeAppendf("float2 %s = %s;", gpArgs->fPositionVar.c_str(), posName);
joshualitt8072caa2015-02-12 14:20:52 -0800133 } else {
joshualitt5559ca22015-05-21 15:50:36 -0700134 const char* viewMatrixName;
cdalton5e58cee2016-02-11 12:49:47 -0800135 *viewMatrixUniform = uniformHandler->addUniform(kVertex_GrShaderFlag,
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400136 kFloat3x3_GrSLType,
egdaniel7ea439b2015-12-03 09:20:44 -0800137 "uViewM",
138 &viewMatrixName);
joshualitt5559ca22015-05-21 15:50:36 -0700139 if (!mat.hasPerspective()) {
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400140 gpArgs->fPositionVar.set(kFloat2_GrSLType, "pos2");
141 vertBuilder->codeAppendf("float2 %s = (%s * float3(%s, 1)).xy;",
egdaniel4ca2e602015-11-18 08:01:26 -0800142 gpArgs->fPositionVar.c_str(), viewMatrixName, posName);
joshualitt5559ca22015-05-21 15:50:36 -0700143 } else {
Ethan Nicholas8aa45692017-09-20 11:24:15 -0400144 gpArgs->fPositionVar.set(kFloat3_GrSLType, "pos3");
145 vertBuilder->codeAppendf("float3 %s = %s * float3(%s, 1);",
egdaniel4ca2e602015-11-18 08:01:26 -0800146 gpArgs->fPositionVar.c_str(), viewMatrixName, posName);
joshualitt5559ca22015-05-21 15:50:36 -0700147 }
joshualitt8072caa2015-02-12 14:20:52 -0800148 }
149}