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 #ifndef GrVertexBatch_DEFINED | 8 #ifndef GrVertexBatch_DEFINED |
9 #define GrVertexBatch_DEFINED | 9 #define GrVertexBatch_DEFINED |
10 | 10 |
11 #include "GrDrawBatch.h" | 11 #include "GrDrawBatch.h" |
| 12 #include "GrMesh.h" |
12 #include "GrPrimitiveProcessor.h" | 13 #include "GrPrimitiveProcessor.h" |
13 #include "GrPendingProgramElement.h" | 14 #include "GrPendingProgramElement.h" |
14 #include "GrVertices.h" | |
15 | 15 |
16 #include "SkTLList.h" | 16 #include "SkTLList.h" |
17 | 17 |
18 class GrBatchFlushState; | 18 class GrBatchFlushState; |
19 | 19 |
20 /** | 20 /** |
21 * Base class for vertex-based GrBatches. | 21 * Base class for vertex-based GrBatches. |
22 */ | 22 */ |
23 class GrVertexBatch : public GrDrawBatch { | 23 class GrVertexBatch : public GrDrawBatch { |
24 public: | 24 public: |
25 class Target; | 25 class Target; |
26 | 26 |
27 GrVertexBatch(uint32_t classID); | 27 GrVertexBatch(uint32_t classID); |
28 | 28 |
29 protected: | 29 protected: |
30 /** Helper for rendering instances using an instanced index index buffer. Th
is class creates the | 30 /** Helper for rendering instances using an instanced index index buffer. Th
is class creates the |
31 space for the vertices and flushes the draws to the batch target. */ | 31 space for the vertices and flushes the draws to the batch target. */ |
32 class InstancedHelper { | 32 class InstancedHelper { |
33 public: | 33 public: |
34 InstancedHelper() {} | 34 InstancedHelper() {} |
35 /** Returns the allocated storage for the vertices. The caller should po
pulate the before | 35 /** Returns the allocated storage for the vertices. The caller should po
pulate the before |
36 vertices before calling issueDraws(). */ | 36 vertices before calling issueDraws(). */ |
37 void* init(Target*, GrPrimitiveType, size_t vertexStride, | 37 void* init(Target*, GrPrimitiveType, size_t vertexStride, |
38 const GrIndexBuffer*, int verticesPerInstance, int indicesPer
Instance, | 38 const GrIndexBuffer*, int verticesPerInstance, int indicesPer
Instance, |
39 int instancesToDraw); | 39 int instancesToDraw); |
40 | 40 |
41 /** Call after init() to issue draws to the batch target.*/ | 41 /** Call after init() to issue draws to the batch target.*/ |
42 void recordDraw(Target* target); | 42 void recordDraw(Target* target); |
43 private: | 43 private: |
44 GrVertices fVertices; | 44 GrMesh fMesh; |
45 }; | 45 }; |
46 | 46 |
47 static const int kVerticesPerQuad = 4; | 47 static const int kVerticesPerQuad = 4; |
48 static const int kIndicesPerQuad = 6; | 48 static const int kIndicesPerQuad = 6; |
49 | 49 |
50 /** A specialization of InstanceHelper for quad rendering. */ | 50 /** A specialization of InstanceHelper for quad rendering. */ |
51 class QuadHelper : private InstancedHelper { | 51 class QuadHelper : private InstancedHelper { |
52 public: | 52 public: |
53 QuadHelper() : INHERITED() {} | 53 QuadHelper() : INHERITED() {} |
54 /** Finds the cached quad index buffer and reserves vertex space. Return
s nullptr on failure | 54 /** Finds the cached quad index buffer and reserves vertex space. Return
s nullptr on failure |
55 and on sucess a pointer to the vertex data that the caller should po
pulate before | 55 and on sucess a pointer to the vertex data that the caller should po
pulate before |
56 calling issueDraws(). */ | 56 calling issueDraws(). */ |
57 void* init(Target* batchTarget, size_t vertexStride, int quadsToDraw); | 57 void* init(Target* batchTarget, size_t vertexStride, int quadsToDraw); |
58 | 58 |
59 using InstancedHelper::recordDraw; | 59 using InstancedHelper::recordDraw; |
60 private: | 60 private: |
61 typedef InstancedHelper INHERITED; | 61 typedef InstancedHelper INHERITED; |
62 }; | 62 }; |
63 | 63 |
64 private: | 64 private: |
65 void onPrepare(GrBatchFlushState* state) final; | 65 void onPrepare(GrBatchFlushState* state) final; |
66 void onDraw(GrBatchFlushState* state) final; | 66 void onDraw(GrBatchFlushState* state) final; |
67 | 67 |
68 virtual void onPrepareDraws(Target*) const = 0; | 68 virtual void onPrepareDraws(Target*) const = 0; |
69 | 69 |
70 // A set of contiguous draws with no inline uploads between them that all us
e the same | 70 // A set of contiguous draws with no inline uploads between them that all us
e the same |
71 // primitive processor. All the draws in a DrawArray share a primitive proce
ssor and use the | 71 // primitive processor. All the draws in a DrawArray share a primitive proce
ssor and use the |
72 // the batch's GrPipeline. | 72 // the batch's GrPipeline. |
73 struct DrawArray { | 73 struct DrawArray { |
74 SkSTArray<1, GrVertices, true> fDraws; | 74 SkSTArray<1, GrMesh, true> fDraws; |
75 GrPendingProgramElement<const GrPrimitiveProcessor> fPrimitiveProcessor; | 75 GrPendingProgramElement<const GrPrimitiveProcessor> fPrimitiveProcessor; |
76 }; | 76 }; |
77 | 77 |
78 // Array of DrawArray. There may be inline uploads between each DrawArray an
d each DrawArray | 78 // Array of DrawArray. There may be inline uploads between each DrawArray an
d each DrawArray |
79 // may use a different primitive processor. | 79 // may use a different primitive processor. |
80 typedef SkTLList<DrawArray, 4> DrawArrayList; | 80 typedef SkTLList<DrawArray, 4> DrawArrayList; |
81 DrawArrayList fDrawArrays; | 81 DrawArrayList fDrawArrays; |
82 | 82 |
83 typedef GrDrawBatch INHERITED; | 83 typedef GrDrawBatch INHERITED; |
84 }; | 84 }; |
85 | 85 |
86 #endif | 86 #endif |
OLD | NEW |