OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 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 "GrAAFillRectBatch.h" | 8 #include "GrAAFillRectBatch.h" |
9 | 9 |
| 10 #include "GrBatchFlushState.h" |
10 #include "GrColor.h" | 11 #include "GrColor.h" |
11 #include "GrDefaultGeoProcFactory.h" | 12 #include "GrDefaultGeoProcFactory.h" |
12 #include "GrResourceKey.h" | 13 #include "GrResourceKey.h" |
13 #include "GrResourceProvider.h" | 14 #include "GrResourceProvider.h" |
14 #include "GrTypes.h" | 15 #include "GrTypes.h" |
15 #include "GrVertexBatch.h" | 16 #include "GrVertexBatch.h" |
16 #include "SkMatrix.h" | 17 #include "SkMatrix.h" |
17 #include "SkRect.h" | 18 #include "SkRect.h" |
18 | 19 |
19 GR_DECLARE_STATIC_UNIQUE_KEY(gAAFillRectIndexBufferKey); | 20 GR_DECLARE_STATIC_UNIQUE_KEY(gAAFillRectIndexBufferKey); |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
89 opt.getOverrideColorIfSet(&fGeoData[0].fColor); | 90 opt.getOverrideColorIfSet(&fGeoData[0].fColor); |
90 | 91 |
91 // setup batch properties | 92 // setup batch properties |
92 fBatch.fColorIgnored = !opt.readsColor(); | 93 fBatch.fColorIgnored = !opt.readsColor(); |
93 fBatch.fColor = fGeoData[0].fColor; | 94 fBatch.fColor = fGeoData[0].fColor; |
94 fBatch.fUsesLocalCoords = opt.readsLocalCoords(); | 95 fBatch.fUsesLocalCoords = opt.readsLocalCoords(); |
95 fBatch.fCoverageIgnored = !opt.readsCoverage(); | 96 fBatch.fCoverageIgnored = !opt.readsCoverage(); |
96 fBatch.fCanTweakAlphaForCoverage = opt.canTweakAlphaForCoverage(); | 97 fBatch.fCanTweakAlphaForCoverage = opt.canTweakAlphaForCoverage(); |
97 } | 98 } |
98 | 99 |
99 void generateGeometry(GrBatchTarget* batchTarget) override { | 100 void onPrepareDraws(Target* target) override { |
100 bool canTweakAlphaForCoverage = this->canTweakAlphaForCoverage(); | 101 bool canTweakAlphaForCoverage = this->canTweakAlphaForCoverage(); |
101 | 102 |
102 SkAutoTUnref<const GrGeometryProcessor> gp(CreateFillRectGP(canTweakAlph
aForCoverage, | 103 SkAutoTUnref<const GrGeometryProcessor> gp(CreateFillRectGP(canTweakAlph
aForCoverage, |
103 this->viewMa
trix(), | 104 this->viewMa
trix(), |
104 this->usesLo
calCoords(), | 105 this->usesLo
calCoords(), |
105 Base::LocalC
oordsType(), | 106 Base::LocalC
oordsType(), |
106 this->covera
geIgnored())); | 107 this->covera
geIgnored())); |
107 if (!gp) { | 108 if (!gp) { |
108 SkDebugf("Couldn't create GrGeometryProcessor\n"); | 109 SkDebugf("Couldn't create GrGeometryProcessor\n"); |
109 return; | 110 return; |
110 } | 111 } |
111 | 112 |
112 batchTarget->initDraw(gp, this->pipeline()); | 113 target->initDraw(gp, this->pipeline()); |
113 | 114 |
114 size_t vertexStride = gp->getVertexStride(); | 115 size_t vertexStride = gp->getVertexStride(); |
115 SkASSERT(Base::StrideCheck(vertexStride, canTweakAlphaForCoverage, | 116 SkASSERT(Base::StrideCheck(vertexStride, canTweakAlphaForCoverage, |
116 this->usesLocalCoords())); | 117 this->usesLocalCoords())); |
117 int instanceCount = fGeoData.count(); | 118 int instanceCount = fGeoData.count(); |
118 | 119 |
119 SkAutoTUnref<const GrIndexBuffer> indexBuffer(get_index_buffer( | 120 SkAutoTUnref<const GrIndexBuffer> indexBuffer(get_index_buffer(target->r
esourceProvider())); |
120 batchTarget->resourceProvider())); | |
121 InstancedHelper helper; | 121 InstancedHelper helper; |
122 void* vertices = helper.init(batchTarget, kTriangles_GrPrimitiveType, ve
rtexStride, | 122 void* vertices = helper.init(target, kTriangles_GrPrimitiveType, vertexS
tride, |
123 indexBuffer, kVertsPerAAFillRect, kIndicesP
erAAFillRect, | 123 indexBuffer, kVertsPerAAFillRect, kIndicesP
erAAFillRect, |
124 instanceCount); | 124 instanceCount); |
125 if (!vertices || !indexBuffer) { | 125 if (!vertices || !indexBuffer) { |
126 SkDebugf("Could not allocate vertices\n"); | 126 SkDebugf("Could not allocate vertices\n"); |
127 return; | 127 return; |
128 } | 128 } |
129 | 129 |
130 for (int i = 0; i < instanceCount; i++) { | 130 for (int i = 0; i < instanceCount; i++) { |
131 this->generateAAFillRectGeometry(vertices, | 131 this->generateAAFillRectGeometry(vertices, |
132 i * kVertsPerAAFillRect * vertexStr
ide, | 132 i * kVertsPerAAFillRect * vertexStr
ide, |
133 vertexStride, | 133 vertexStride, |
134 fGeoData[i], | 134 fGeoData[i], |
135 canTweakAlphaForCoverage); | 135 canTweakAlphaForCoverage); |
136 } | 136 } |
137 helper.issueDraw(batchTarget); | 137 helper.recordDraw(target); |
138 } | 138 } |
139 | 139 |
140 SkSTArray<1, Geometry, true>* geoData() { return &fGeoData; } | 140 SkSTArray<1, Geometry, true>* geoData() { return &fGeoData; } |
141 | 141 |
142 // to avoid even the initial copy of the struct, we have a getter for the fi
rst item which | 142 // to avoid even the initial copy of the struct, we have a getter for the fi
rst item which |
143 // is used to seed the batch with its initial geometry. After seeding, the
client should call | 143 // is used to seed the batch with its initial geometry. After seeding, the
client should call |
144 // init() so the Batch can initialize itself | 144 // init() so the Batch can initialize itself |
145 Geometry* geometry() { return &fGeoData[0]; } | 145 Geometry* geometry() { return &fGeoData[0]; } |
146 void init() { | 146 void init() { |
147 const Geometry& geo = fGeoData[0]; | 147 const Geometry& geo = fGeoData[0]; |
(...skipping 306 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
454 DRAW_BATCH_TEST_DEFINE(AAFillRectBatchLocalMatrix) { | 454 DRAW_BATCH_TEST_DEFINE(AAFillRectBatchLocalMatrix) { |
455 GrColor color = GrRandomColor(random); | 455 GrColor color = GrRandomColor(random); |
456 SkMatrix viewMatrix = GrTest::TestMatrixInvertible(random); | 456 SkMatrix viewMatrix = GrTest::TestMatrixInvertible(random); |
457 SkMatrix localMatrix = GrTest::TestMatrix(random); | 457 SkMatrix localMatrix = GrTest::TestMatrix(random); |
458 SkRect rect = GrTest::TestRect(random); | 458 SkRect rect = GrTest::TestRect(random); |
459 SkRect devRect = GrTest::TestRect(random); | 459 SkRect devRect = GrTest::TestRect(random); |
460 return GrAAFillRectBatch::Create(color, viewMatrix, localMatrix, rect, devRe
ct); | 460 return GrAAFillRectBatch::Create(color, viewMatrix, localMatrix, rect, devRe
ct); |
461 } | 461 } |
462 | 462 |
463 #endif | 463 #endif |
OLD | NEW |