blob: 199163939f280274d762005bcb540072eea7312b [file] [log] [blame]
joshualitt8072caa2015-02-12 14:20:52 -08001/*
2 * Copyright 2013 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#ifndef GrGLSLPrimitiveProcessor_DEFINED
9#define GrGLSLPrimitiveProcessor_DEFINED
joshualitt8072caa2015-02-12 14:20:52 -080010
bsalomona624bf32016-09-20 09:12:47 -070011#include "GrFragmentProcessor.h"
joshualitt8072caa2015-02-12 14:20:52 -080012#include "GrPrimitiveProcessor.h"
egdaniel018fb622015-10-28 07:26:40 -070013#include "glsl/GrGLSLProgramDataManager.h"
joshualitt8072caa2015-02-12 14:20:52 -080014
15class GrBatchTracker;
16class GrPrimitiveProcessor;
egdaniela2e3e0f2015-11-19 07:23:45 -080017class GrGLSLCaps;
cdalton85285412016-02-18 12:37:07 -080018class GrGLSLPPFragmentBuilder;
csmartdalton276cc412016-11-21 11:55:00 -070019class GrGLSLGeometryBuilder;
egdaniel8dcdedc2015-11-11 06:27:20 -080020class GrGLSLGPBuilder;
Brian Salomon59dc4112016-11-23 01:02:43 +000021class GrGLSLUniformHandler;
egdaniel0eafe792015-11-20 14:01:22 -080022class GrGLSLVaryingHandler;
egdaniela2e3e0f2015-11-19 07:23:45 -080023class GrGLSLVertexBuilder;
joshualitt8072caa2015-02-12 14:20:52 -080024
egdaniele659a582015-11-13 09:55:43 -080025class GrGLSLPrimitiveProcessor {
joshualitt8072caa2015-02-12 14:20:52 -080026public:
bsalomona624bf32016-09-20 09:12:47 -070027 using FPCoordTransformIter = GrFragmentProcessor::CoordTransformIter;
28
egdaniele659a582015-11-13 09:55:43 -080029 virtual ~GrGLSLPrimitiveProcessor() {}
joshualitt8072caa2015-02-12 14:20:52 -080030
Brian Salomon59dc4112016-11-23 01:02:43 +000031 typedef GrGLSLProgramDataManager::UniformHandle UniformHandle;
32 typedef GrGLSLProgramDataManager::UniformHandle SamplerHandle;
joshualitt8072caa2015-02-12 14:20:52 -080033
bsalomona624bf32016-09-20 09:12:47 -070034 /**
35 * This class provides access to the GrCoordTransforms across all GrFragmentProcessors in a
36 * GrPipeline. It is also used by the primitive processor to specify the fragment shader
37 * variable that will hold the transformed coords for each GrCoordTransform. It is required that
38 * the primitive processor iterate over each coord transform and insert a shader var result for
39 * each. The GrGLSLFragmentProcessors will reference these variables in their fragment code.
40 */
41 class FPCoordTransformHandler : public SkNoncopyable {
42 public:
43 FPCoordTransformHandler(const GrPipeline& pipeline,
44 SkTArray<GrShaderVar>* transformedCoordVars)
45 : fIter(pipeline)
46 , fTransformedCoordVars(transformedCoordVars) {}
47
48 ~FPCoordTransformHandler() { SkASSERT(!this->nextCoordTransform());}
49
50 const GrCoordTransform* nextCoordTransform();
51
52 // 'args' are constructor params to GrShaderVar.
53 template<typename... Args>
54 void specifyCoordsForCurrCoordTransform(Args&&... args) {
55 SkASSERT(!fAddedCoord);
56 fTransformedCoordVars->emplace_back(std::forward<Args>(args)...);
57 SkDEBUGCODE(fAddedCoord = true;)
58 }
59
60 private:
61 GrFragmentProcessor::CoordTransformIter fIter;
62 SkDEBUGCODE(bool fAddedCoord = false;)
63 SkDEBUGCODE(const GrCoordTransform* fCurr = nullptr;)
64 SkTArray<GrShaderVar>* fTransformedCoordVars;
65 };
joshualitt8072caa2015-02-12 14:20:52 -080066
67 struct EmitArgs {
egdaniel7ea439b2015-12-03 09:20:44 -080068 EmitArgs(GrGLSLVertexBuilder* vertBuilder,
csmartdalton276cc412016-11-21 11:55:00 -070069 GrGLSLGeometryBuilder* geomBuilder,
cdalton85285412016-02-18 12:37:07 -080070 GrGLSLPPFragmentBuilder* fragBuilder,
egdaniel0eafe792015-11-20 14:01:22 -080071 GrGLSLVaryingHandler* varyingHandler,
egdaniel7ea439b2015-12-03 09:20:44 -080072 GrGLSLUniformHandler* uniformHandler,
egdaniela2e3e0f2015-11-19 07:23:45 -080073 const GrGLSLCaps* caps,
joshualitt8072caa2015-02-12 14:20:52 -080074 const GrPrimitiveProcessor& gp,
joshualitt8072caa2015-02-12 14:20:52 -080075 const char* outputColor,
76 const char* outputCoverage,
dvonbeck9b03e7b2016-08-01 11:01:56 -070077 const char* distanceVectorName,
egdaniel09aa1fc2016-04-20 07:09:46 -070078 const SamplerHandle* texSamplers,
79 const SamplerHandle* bufferSamplers,
bsalomona624bf32016-09-20 09:12:47 -070080 FPCoordTransformHandler* transformHandler)
egdaniel7ea439b2015-12-03 09:20:44 -080081 : fVertBuilder(vertBuilder)
csmartdalton276cc412016-11-21 11:55:00 -070082 , fGeomBuilder(geomBuilder)
egdaniel4ca2e602015-11-18 08:01:26 -080083 , fFragBuilder(fragBuilder)
egdaniel0eafe792015-11-20 14:01:22 -080084 , fVaryingHandler(varyingHandler)
egdaniel7ea439b2015-12-03 09:20:44 -080085 , fUniformHandler(uniformHandler)
egdaniela2e3e0f2015-11-19 07:23:45 -080086 , fGLSLCaps(caps)
joshualitt8072caa2015-02-12 14:20:52 -080087 , fGP(gp)
joshualitt8072caa2015-02-12 14:20:52 -080088 , fOutputColor(outputColor)
89 , fOutputCoverage(outputCoverage)
dvonbeck9b03e7b2016-08-01 11:01:56 -070090 , fDistanceVectorName(distanceVectorName)
cdalton3f6f76f2016-04-11 12:18:09 -070091 , fTexSamplers(texSamplers)
cdalton74b8d322016-04-11 14:47:28 -070092 , fBufferSamplers(bufferSamplers)
bsalomona624bf32016-09-20 09:12:47 -070093 , fFPCoordTransformHandler(transformHandler) {}
egdaniel4ca2e602015-11-18 08:01:26 -080094 GrGLSLVertexBuilder* fVertBuilder;
csmartdalton276cc412016-11-21 11:55:00 -070095 GrGLSLGeometryBuilder* fGeomBuilder;
cdalton85285412016-02-18 12:37:07 -080096 GrGLSLPPFragmentBuilder* fFragBuilder;
egdaniel0eafe792015-11-20 14:01:22 -080097 GrGLSLVaryingHandler* fVaryingHandler;
egdaniel7ea439b2015-12-03 09:20:44 -080098 GrGLSLUniformHandler* fUniformHandler;
egdaniela2e3e0f2015-11-19 07:23:45 -080099 const GrGLSLCaps* fGLSLCaps;
joshualitt8072caa2015-02-12 14:20:52 -0800100 const GrPrimitiveProcessor& fGP;
joshualitt8072caa2015-02-12 14:20:52 -0800101 const char* fOutputColor;
102 const char* fOutputCoverage;
dvonbeck9b03e7b2016-08-01 11:01:56 -0700103 const char* fDistanceVectorName;
egdaniel09aa1fc2016-04-20 07:09:46 -0700104 const SamplerHandle* fTexSamplers;
105 const SamplerHandle* fBufferSamplers;
bsalomona624bf32016-09-20 09:12:47 -0700106 FPCoordTransformHandler* fFPCoordTransformHandler;
joshualitt8072caa2015-02-12 14:20:52 -0800107 };
108
109 /**
110 * This is similar to emitCode() in the base class, except it takes a full shader builder.
111 * This allows the effect subclass to emit vertex code.
112 */
113 virtual void emitCode(EmitArgs&) = 0;
114
bsalomona624bf32016-09-20 09:12:47 -0700115 /**
116 * A GrGLSLPrimitiveProcessor instance can be reused with any GrGLSLPrimitiveProcessor that
117 * produces the same stage key; this function reads data from a GrGLSLPrimitiveProcessor and
118 * uploads any uniform variables required by the shaders created in emitCode(). The
119 * GrPrimitiveProcessor parameter is guaranteed to be of the same type and to have an
120 * identical processor key as the GrPrimitiveProcessor that created this
121 * GrGLSLPrimitiveProcessor.
122 * The subclass may use the transform iterator to perform any setup required for the particular
123 * set of fp transform matrices, such as uploading via uniforms. The iterator will iterate over
124 * the transforms in the same order as the TransformHandler passed to emitCode.
125 */
126 virtual void setData(const GrGLSLProgramDataManager&, const GrPrimitiveProcessor&,
127 FPCoordTransformIter&&) = 0;
joshualitt8072caa2015-02-12 14:20:52 -0800128
129 static SkMatrix GetTransformMatrix(const SkMatrix& localMatrix, const GrCoordTransform&);
130
131protected:
cdalton85285412016-02-18 12:37:07 -0800132 void setupUniformColor(GrGLSLPPFragmentBuilder* fragBuilder,
egdaniel7ea439b2015-12-03 09:20:44 -0800133 GrGLSLUniformHandler* uniformHandler,
egdaniel8dcdedc2015-11-11 06:27:20 -0800134 const char* outputName,
135 UniformHandle* colorUniform);
joshualitt8072caa2015-02-12 14:20:52 -0800136};
137
138#endif