blob: aa5095448f07d5e3c6ef676139edeb2a8ce6e875 [file] [log] [blame]
jvanverth50530632015-04-27 10:36:27 -07001/*
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
joshualitt8072caa2015-02-12 14:20:52 -08008#include "GrPathProcessor.h"
9
joshualitt8072caa2015-02-12 14:20:52 -080010#include "gl/GrGLGpu.h"
11
jvanverthcba99b82015-06-24 06:59:57 -070012#include "glsl/GrGLSLCaps.h"
13
joshualitt102081a2015-09-11 11:52:17 -070014class GrGLPathProcessor : public GrGLPrimitiveProcessor {
15public:
16 GrGLPathProcessor() : fColor(GrColor_ILLEGAL) {}
17
18 static void GenKey(const GrPathProcessor& pathProc,
19 const GrGLSLCaps&,
20 GrProcessorKeyBuilder* b) {
21 b->add32(SkToInt(pathProc.opts().readsColor()) |
22 SkToInt(pathProc.opts().readsCoverage()) << 16);
23 }
24
25 void emitCode(EmitArgs& args) override {
26 GrGLGPBuilder* pb = args.fPB;
27 GrGLFragmentBuilder* fs = args.fPB->getFragmentShaderBuilder();
28 const GrPathProcessor& pathProc = args.fGP.cast<GrPathProcessor>();
29
30 // emit transforms
31 this->emitTransforms(args.fPB, args.fTransformsIn, args.fTransformsOut);
32
33 // Setup uniform color
34 if (pathProc.opts().readsColor()) {
35 const char* stagedLocalVarName;
36 fColorUniform = pb->addUniform(GrGLProgramBuilder::kFragment_Visibility,
37 kVec4f_GrSLType,
38 kDefault_GrSLPrecision,
39 "Color",
40 &stagedLocalVarName);
41 fs->codeAppendf("%s = %s;", args.fOutputColor, stagedLocalVarName);
42 }
43
44 // setup constant solid coverage
45 if (pathProc.opts().readsCoverage()) {
46 fs->codeAppendf("%s = vec4(1);", args.fOutputCoverage);
47 }
48 }
49
50 void emitTransforms(GrGLGPBuilder* pb, const TransformsIn& tin, TransformsOut* tout) {
51 tout->push_back_n(tin.count());
52 fInstalledTransforms.push_back_n(tin.count());
53 for (int i = 0; i < tin.count(); i++) {
54 const ProcCoords& coordTransforms = tin[i];
55 fInstalledTransforms[i].push_back_n(coordTransforms.count());
56 for (int t = 0; t < coordTransforms.count(); t++) {
57 GrSLType varyingType =
58 coordTransforms[t]->getMatrix().hasPerspective() ? kVec3f_GrSLType :
59 kVec2f_GrSLType;
60
61 SkString strVaryingName("MatrixCoord");
62 strVaryingName.appendf("_%i_%i", i, t);
63 GrGLVertToFrag v(varyingType);
64 fInstalledTransforms[i][t].fHandle =
65 pb->addSeparableVarying(strVaryingName.c_str(), &v).toIndex();
66 fInstalledTransforms[i][t].fType = varyingType;
67
68 SkNEW_APPEND_TO_TARRAY(&(*tout)[i], GrGLProcessor::TransformedCoords,
69 (SkString(v.fsIn()), varyingType));
70 }
71 }
72 }
73
74 void setData(const GrGLProgramDataManager& pd, const GrPrimitiveProcessor& primProc) override {
75 const GrPathProcessor& pathProc = primProc.cast<GrPathProcessor>();
76 if (pathProc.opts().readsColor() && pathProc.color() != fColor) {
77 GrGLfloat c[4];
78 GrColorToRGBAFloat(pathProc.color(), c);
79 pd.set4fv(fColorUniform, 1, c);
80 fColor = pathProc.color();
81 }
82 }
83
84 void setTransformData(const GrPrimitiveProcessor& primProc,
85 const GrGLProgramDataManager& pdman,
86 int index,
87 const SkTArray<const GrCoordTransform*, true>& coordTransforms) override {
88 const GrPathProcessor& pathProc = primProc.cast<GrPathProcessor>();
89 SkSTArray<2, Transform, true>& transforms = fInstalledTransforms[index];
90 int numTransforms = transforms.count();
91 for (int t = 0; t < numTransforms; ++t) {
92 SkASSERT(transforms[t].fHandle.isValid());
93 const SkMatrix& transform = GetTransformMatrix(pathProc.localMatrix(),
94 *coordTransforms[t]);
95 if (transforms[t].fCurrentValue.cheapEqualTo(transform)) {
96 continue;
97 }
98 transforms[t].fCurrentValue = transform;
99
100 SkASSERT(transforms[t].fType == kVec2f_GrSLType ||
101 transforms[t].fType == kVec3f_GrSLType);
102 unsigned components = transforms[t].fType == kVec2f_GrSLType ? 2 : 3;
103 pdman.setPathFragmentInputTransform(transforms[t].fHandle, components, transform);
104 }
105 }
106
107private:
108 UniformHandle fColorUniform;
109 GrColor fColor;
110
111 typedef GrGLPrimitiveProcessor INHERITED;
112};
113
joshualitt8072caa2015-02-12 14:20:52 -0800114GrPathProcessor::GrPathProcessor(GrColor color,
joshualittf2384692015-09-10 11:00:51 -0700115 const GrPipelineOptimizations& opts,
joshualitt8072caa2015-02-12 14:20:52 -0800116 const SkMatrix& viewMatrix,
117 const SkMatrix& localMatrix)
joshualitte3ababe2015-05-15 07:56:07 -0700118 : INHERITED(true)
119 , fColor(color)
joshualitte578a952015-05-14 10:09:13 -0700120 , fViewMatrix(viewMatrix)
joshualittf2384692015-09-10 11:00:51 -0700121 , fLocalMatrix(localMatrix)
122 , fOpts(opts) {
joshualitt8072caa2015-02-12 14:20:52 -0800123 this->initClassID<GrPathProcessor>();
124}
125
joshualitt465283c2015-09-11 08:19:35 -0700126void GrPathProcessor::getGLProcessorKey(const GrGLSLCaps& caps,
joshualitt8072caa2015-02-12 14:20:52 -0800127 GrProcessorKeyBuilder* b) const {
joshualitt465283c2015-09-11 08:19:35 -0700128 GrGLPathProcessor::GenKey(*this, caps, b);
joshualitt8072caa2015-02-12 14:20:52 -0800129}
130
joshualitt465283c2015-09-11 08:19:35 -0700131GrGLPrimitiveProcessor* GrPathProcessor::createGLInstance(const GrGLSLCaps& caps) const {
jvanverth50530632015-04-27 10:36:27 -0700132 SkASSERT(caps.pathRenderingSupport());
joshualitt465283c2015-09-11 08:19:35 -0700133 return new GrGLPathProcessor();
joshualitt8072caa2015-02-12 14:20:52 -0800134}