Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(27)

Side by Side Diff: src/gpu/GrDefaultGeoProcFactory.cpp

Issue 761563002: First step to moving vertex attributes to the geometryProcessor (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: rebase and small cleanup Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/gpu/GrDefaultGeoProcFactory.h ('k') | src/gpu/GrDefaultPathRenderer.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2014 Google Inc. 2 * Copyright 2014 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #include "GrDefaultGeoProcFactory.h" 8 #include "GrDefaultGeoProcFactory.h"
9 9
10 #include "gl/builders/GrGLProgramBuilder.h"
11 #include "gl/GrGLGeometryProcessor.h"
12 #include "GrDrawState.h" 10 #include "GrDrawState.h"
13 #include "GrInvariantOutput.h" 11 #include "GrInvariantOutput.h"
14 #include "GrTBackendProcessorFactory.h" 12 #include "GrTBackendProcessorFactory.h"
13 #include "gl/GrGLGeometryProcessor.h"
14 #include "gl/builders/GrGLProgramBuilder.h"
15 15
16 /* 16 /*
17 * The default Geometry Processor simply takes position and multiplies it by the uniform view 17 * The default Geometry Processor simply takes position and multiplies it by the uniform view
18 * matrix. It also leaves coverage untouched. Behind the scenes, we may add per vertex color or 18 * matrix. It also leaves coverage untouched. Behind the scenes, we may add per vertex color or
19 * local coords. 19 * local coords.
20 */ 20 */
21 class DefaultGeoProc : public GrGeometryProcessor { 21 class DefaultGeoProc : public GrGeometryProcessor {
22 public: 22 public:
23 static GrGeometryProcessor* Create(bool hasCoverage) { 23 static GrGeometryProcessor* Create(uint32_t gpTypeFlags) {
24 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProc, DefaultGeoProc, (hasCoverage )); 24 bool hasColor = SkToBool(gpTypeFlags & GrDefaultGeoProcFactory::kColor_G PType);
25 return SkRef(gDefaultGeoProc); 25 bool hasLocalCoord = SkToBool(gpTypeFlags & GrDefaultGeoProcFactory::kLo calCoord_GPType);
26 bool hasCoverage = SkToBool(gpTypeFlags & GrDefaultGeoProcFactory::kCove rage_GPType);
27 if (hasColor && hasLocalCoord && hasCoverage) {
bsalomon 2014/11/26 18:10:15 I wonder if this would read better as a switch/cas
28 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProcColLocCov,
29 DefaultGeoProc,
30 (gpTypeFlags));
31 return SkRef(gDefaultGeoProcColLocCov);
32 } else if (hasColor && hasLocalCoord) {
33 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProcColLoc,
34 DefaultGeoProc,
35 (gpTypeFlags));
36 return SkRef(gDefaultGeoProcColLoc);
37 } else if (hasColor && hasCoverage) {
38 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProcColCov,
39 DefaultGeoProc,
40 (gpTypeFlags));
41 return SkRef(gDefaultGeoProcColCov);
42 } else if (hasColor) {
43 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProcCol,
44 DefaultGeoProc,
45 (gpTypeFlags));
46 return SkRef(gDefaultGeoProcCol);
47 } else if (hasLocalCoord && hasCoverage) {
48 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProcLocCov,
49 DefaultGeoProc,
50 (gpTypeFlags));
51 return SkRef(gDefaultGeoProcLocCov);
52 } else if (hasLocalCoord) {
53 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProcLoc,
54 DefaultGeoProc,
55 (gpTypeFlags));
56 return SkRef(gDefaultGeoProcLoc);
57 } else if (hasCoverage) {
58 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProcCov,
59 DefaultGeoProc,
60 (gpTypeFlags));
61 return SkRef(gDefaultGeoProcCov);
62 } else {
63 SkASSERT(GrDefaultGeoProcFactory::kPosition_GPType == gpTypeFlags);
64 GR_CREATE_STATIC_PROCESSOR(gDefaultGeoProc,
65 DefaultGeoProc,
66 (gpTypeFlags));
67 return SkRef(gDefaultGeoProc);
68 }
26 } 69 }
27 70
28 static const char* Name() { return "DefaultGeometryProcessor"; } 71 static const char* Name() { return "DefaultGeometryProcessor"; }
29 72
30 virtual const GrBackendGeometryProcessorFactory& getFactory() const SK_OVERR IDE { 73 virtual const GrBackendGeometryProcessorFactory& getFactory() const SK_OVERR IDE {
31 return GrTBackendGeometryProcessorFactory<DefaultGeoProc>::getInstance() ; 74 return GrTBackendGeometryProcessorFactory<DefaultGeoProc>::getInstance() ;
32 } 75 }
33 76
77 const GrAttribute* inPosition() const { return fInPosition; }
78 const GrAttribute* inColor() const { return fInColor; }
79 const GrAttribute* inLocalCoords() const { return fInLocalCoords; }
80 const GrAttribute* inCoverage() const { return fInCoverage; }
81
34 class GLProcessor : public GrGLGeometryProcessor { 82 class GLProcessor : public GrGLGeometryProcessor {
35 public: 83 public:
36 GLProcessor(const GrBackendProcessorFactory& factory, const GrProcessor& ) 84 GLProcessor(const GrBackendProcessorFactory& factory, const GrProcessor& )
37 : INHERITED (factory) {} 85 : INHERITED (factory) {}
38 86
39 virtual void emitCode(const EmitArgs& args) SK_OVERRIDE { 87 virtual void emitCode(const EmitArgs& args) SK_OVERRIDE {
88 const DefaultGeoProc& gp = args.fGP.cast<DefaultGeoProc>();
bsalomon 2014/11/26 18:10:15 Curious why pos/lc are different than cov/col (get
40 GrGLVertexBuilder* vs = args.fPB->getVertexShaderBuilder(); 89 GrGLVertexBuilder* vs = args.fPB->getVertexShaderBuilder();
41 90
91 vs->codeAppendf("%s = %s;", vs->positionCoords(), gp.inPosition()->f Name);
92
93 // Setup pass through color
94 if (gp.inColor()) {
95 args.fPB->addPassThroughAttribute(gp.inColor(), args.fOutputColo r);
96 }
97
98 // Setup local coords if needed
99 if (gp.inLocalCoords()) {
100 vs->codeAppendf("%s = %s;", vs->localCoords(), gp.inLocalCoords( )->fName);
101 } else {
102 vs->codeAppendf("%s = %s;", vs->localCoords(), gp.inPosition()-> fName);
103 }
104
42 // setup position varying 105 // setup position varying
43 vs->codeAppendf("%s = %s * vec3(%s, 1);", vs->glPosition(), vs->uVie wM(), 106 vs->codeAppendf("%s = %s * vec3(%s, 1);", vs->glPosition(), vs->uVie wM(),
44 vs->inPosition()); 107 gp.inPosition()->fName);
45 108
46 // output coverage in FS(pass through) 109 // Setup coverage as pass through
47 GrGLGPFragmentBuilder* fs = args.fPB->getFragmentShaderBuilder(); 110 GrGLGPFragmentBuilder* fs = args.fPB->getFragmentShaderBuilder();
48 fs->codeAppendf("%s = %s;", args.fOutput, GrGLSLExpr4(args.fInput).c _str()); 111 fs->codeAppendf("float alpha = 1.0;");
112 if (gp.inCoverage()) {
113 args.fPB->addPassThroughAttribute(gp.inCoverage(), "alpha");
114 }
115 fs->codeAppendf("%s = vec4(alpha);", args.fOutputCoverage);
49 } 116 }
50 117
51 static inline void GenKey(const GrProcessor&, const GrGLCaps&, GrProcess orKeyBuilder*) {} 118 static inline void GenKey(const GrProcessor& gp, const GrGLCaps&, GrProc essorKeyBuilder* b) {
119 const DefaultGeoProc& def = gp.cast<DefaultGeoProc>();
120 b->add32(def.fFlags);
121 }
52 122
53 virtual void setData(const GrGLProgramDataManager&, const GrProcessor&) SK_OVERRIDE {} 123 virtual void setData(const GrGLProgramDataManager&, const GrProcessor&) SK_OVERRIDE {}
54 124
55 private: 125 private:
56 typedef GrGLGeometryProcessor INHERITED; 126 typedef GrGLGeometryProcessor INHERITED;
57 }; 127 };
58 128
59 private: 129 private:
60 DefaultGeoProc(bool hasCoverageAttribute) : fHasCoverageAttribute(hasCoverag eAttribute) {} 130 DefaultGeoProc(uint32_t gpTypeFlags)
131 : fInPosition(NULL)
132 , fInColor(NULL)
133 , fInLocalCoords(NULL)
134 , fInCoverage(NULL)
135 , fFlags(gpTypeFlags) {
136 bool hasColor = SkToBool(gpTypeFlags & GrDefaultGeoProcFactory::kColor_G PType);
137 bool hasLocalCoord = SkToBool(gpTypeFlags & GrDefaultGeoProcFactory::kLo calCoord_GPType);
138 bool hasCoverage = SkToBool(gpTypeFlags & GrDefaultGeoProcFactory::kCove rage_GPType);
139 fInPosition = &this->addVertexAttrib(GrAttribute("inPosition", kVec2f_Gr VertexAttribType));
140 if (hasColor) {
141 fInColor = &this->addVertexAttrib(GrAttribute("inColor", kVec4ub_GrV ertexAttribType));
142 this->setHasVertexColor();
143 }
144 if (hasLocalCoord) {
145 fInLocalCoords = &this->addVertexAttrib(GrAttribute("inLocalCoord",
146 kVec2f_GrVertexA ttribType));
147 this->setHasLocalCoords();
148 }
149 if (hasCoverage) {
150 fInCoverage = &this->addVertexAttrib(GrAttribute("inCoverage",
151 kFloat_GrVertexAttr ibType));
152 this->setHasVertexCoverage();
153 }
154 }
61 155
62 virtual bool onIsEqual(const GrGeometryProcessor& other) const SK_OVERRIDE { 156 virtual bool onIsEqual(const GrGeometryProcessor& other) const SK_OVERRIDE {
63 return true; 157 const DefaultGeoProc& gp = other.cast<DefaultGeoProc>();
158 return gp.fFlags == this->fFlags;
64 } 159 }
65 160
66 virtual void onComputeInvariantOutput(GrInvariantOutput* inout) const SK_OVE RRIDE { 161 virtual void onComputeInvariantOutput(GrInvariantOutput* inout) const SK_OVE RRIDE {
67 if (fHasCoverageAttribute) { 162 if (fInCoverage) {
68 inout->mulByUnknownAlpha(); 163 inout->mulByUnknownAlpha();
69 } else { 164 } else {
70 inout->mulByKnownAlpha(255); 165 inout->mulByKnownAlpha(255);
71 } 166 }
72 } 167 }
73 168
169 const GrAttribute* fInPosition;
170 const GrAttribute* fInColor;
171 const GrAttribute* fInLocalCoords;
172 const GrAttribute* fInCoverage;
173 uint32_t fFlags;
174
74 GR_DECLARE_GEOMETRY_PROCESSOR_TEST; 175 GR_DECLARE_GEOMETRY_PROCESSOR_TEST;
75 176
76 bool fHasCoverageAttribute;
77
78 typedef GrFragmentProcessor INHERITED; 177 typedef GrFragmentProcessor INHERITED;
79 }; 178 };
80 179
81 GR_DEFINE_GEOMETRY_PROCESSOR_TEST(DefaultGeoProc); 180 GR_DEFINE_GEOMETRY_PROCESSOR_TEST(DefaultGeoProc);
82 181
83 GrGeometryProcessor* DefaultGeoProc::TestCreate(SkRandom* random, 182 GrGeometryProcessor* DefaultGeoProc::TestCreate(SkRandom* random,
84 GrContext*, 183 GrContext*,
85 const GrDrawTargetCaps& caps, 184 const GrDrawTargetCaps& caps,
86 GrTexture*[]) { 185 GrTexture*[]) {
87 return DefaultGeoProc::Create(random->nextBool()); 186 uint32_t flags = 0;
187 flags |= random->nextBool() & GrDefaultGeoProcFactory::kColor_GPType;
188 flags |= random->nextBool() & GrDefaultGeoProcFactory::kCoverage_GPType;
189 flags |= random->nextBool() & GrDefaultGeoProcFactory::kLocalCoord_GPType;
190
191 return DefaultGeoProc::Create(flags);
88 } 192 }
89 193
90 // We use these arrays to customize our default GP. We only need 4 because we o mit coverage if 194 const GrGeometryProcessor* GrDefaultGeoProcFactory::Create(uint32_t gpTypeFlags) {
91 // coverage is not requested in the flags to the create function. 195 return DefaultGeoProc::Create(gpTypeFlags);
92 GrVertexAttrib kDefaultPositionGeoProc[] = {
93 { kVec2f_GrVertexAttribType, 0, kPosition_GrVertexAttribBindin g },
94 { kFloat_GrVertexAttribType, sizeof(SkPoint), kCoverage_GrVertexAttribBindin g },
95 };
96
97 GrVertexAttrib kDefaultPosColorGeoProc[] = {
98 { kVec2f_GrVertexAttribType, 0, kPosition_Gr VertexAttribBinding },
99 { kVec4ub_GrVertexAttribType, sizeof(SkPoint), kColor_GrVer texAttribBinding },
100 { kFloat_GrVertexAttribType, sizeof(SkPoint) + sizeof(GrColor), kCoverage_Gr VertexAttribBinding },
101 };
102
103 GrVertexAttrib kDefaultPosLocalCoordGeoProc[] = {
104 { kVec2f_GrVertexAttribType, 0, kPosition_GrVertexAttribBi nding },
105 { kVec2f_GrVertexAttribType, sizeof(SkPoint), kLocalCoord_GrVertexAttrib Binding },
106 { kFloat_GrVertexAttribType, 2 * sizeof(SkPoint), kCoverage_GrVertexAttribBi nding },
107 };
108
109 GrVertexAttrib kDefaultPosColLocalCoordGeoProc[] = {
110 { kVec2f_GrVertexAttribType, 0, kPositio n_GrVertexAttribBinding },
111 { kVec4ub_GrVertexAttribType, sizeof(SkPoint), kColor_G rVertexAttribBinding },
112 { kVec2f_GrVertexAttribType, sizeof(SkPoint) + sizeof(GrColor), kLocalCo ord_GrVertexAttribBinding },
113 { kFloat_GrVertexAttribType, 2 * sizeof(SkPoint) + sizeof(GrColor), kCoverag e_GrVertexAttribBinding },
114 };
115
116 static size_t get_size(GrDefaultGeoProcFactory::GPType flag) {
117 switch (flag) {
118 case GrDefaultGeoProcFactory::kPosition_GPType:
119 return GrVertexAttribTypeSize(kVec2f_GrVertexAttribType);
120 case GrDefaultGeoProcFactory::kColor_GPType:
121 return GrVertexAttribTypeSize(kVec4ub_GrVertexAttribType);
122 case GrDefaultGeoProcFactory::kLocalCoord_GPType:
123 return GrVertexAttribTypeSize(kVec2f_GrVertexAttribType);
124 case GrDefaultGeoProcFactory::kCoverage_GPType:
125 return GrVertexAttribTypeSize(kFloat_GrVertexAttribType);
126 default:
127 SkFAIL("Should never get here");
128 return 0;
129 }
130 } 196 }
131
132 void GrDefaultGeoProcFactory::SetAttribs(GrDrawState* ds, uint32_t gpTypeFlags) {
133 SkASSERT(ds);
134 // always atleast position in the GP
135 size_t size = get_size(kPosition_GPType);
136 int count = 1;
137
138 bool hasColor = SkToBool(gpTypeFlags & kColor_GPType);
139 bool hasLocalCoord = SkToBool(gpTypeFlags & kLocalCoord_GPType);
140 bool hasCoverage = SkToBool(gpTypeFlags & kCoverage_GPType);
141
142 if (hasColor) {
143 size += get_size(kColor_GPType);
144 count++;
145 if (hasLocalCoord) {
146 size += get_size(kLocalCoord_GPType);
147 count++;
148 if (hasCoverage) {
149 size += get_size(kCoverage_GPType);
150 count++;
151 ds->setVertexAttribs<kDefaultPosColLocalCoordGeoProc>(count, siz e);
152 } else {
153 ds->setVertexAttribs<kDefaultPosColLocalCoordGeoProc>(count, siz e);
154
155 }
156 } else {
157 if (hasCoverage) {
158 size += get_size(kCoverage_GPType);
159 count++;
160 ds->setVertexAttribs<kDefaultPosColorGeoProc>(count, size);
161 } else {
162 ds->setVertexAttribs<kDefaultPosColorGeoProc>(count, size);
163 }
164 }
165 } else if (hasLocalCoord) {
166 size += get_size(kLocalCoord_GPType);
167 count++;
168 if (hasCoverage) {
169 size += get_size(kCoverage_GPType);
170 count++;
171 ds->setVertexAttribs<kDefaultPosLocalCoordGeoProc>(count, size);
172 } else {
173 ds->setVertexAttribs<kDefaultPosLocalCoordGeoProc>(count, size);
174 }
175 } else if (hasCoverage) {
176 size += get_size(kCoverage_GPType);
177 count++;
178 ds->setVertexAttribs<kDefaultPositionGeoProc>(count, size);
179 } else {
180 // Just position
181 ds->setVertexAttribs<kDefaultPositionGeoProc>(count, size);
182 }
183 }
184
185 const GrGeometryProcessor*
186 GrDefaultGeoProcFactory::CreateAndSetAttribs(GrDrawState* ds, uint32_t gpTypeFla gs) {
187 SetAttribs(ds, gpTypeFlags);
188
189 bool hasCoverage = SkToBool(gpTypeFlags & kCoverage_GPType);
190 return DefaultGeoProc::Create(hasCoverage);
191 }
192
193 const GrGeometryProcessor* GrDefaultGeoProcFactory::Create(bool hasAttributeCove rage) {
194 return DefaultGeoProc::Create(hasAttributeCoverage);
195 }
OLDNEW
« no previous file with comments | « src/gpu/GrDefaultGeoProcFactory.h ('k') | src/gpu/GrDefaultPathRenderer.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698