diff options
author | Brian Salomon <bsalomon@google.com> | 2018-06-18 12:52:47 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2018-06-18 17:13:58 +0000 |
commit | 19c1233c447f625c2522e7ecd0a0adecc629bb2f (patch) | |
tree | 891e06143986ade3aae8d4176ec8b426f70b896f /src/gpu/GrPrimitiveProcessor.cpp | |
parent | 146cf3ce7935019ecc63ce9e93450a8c122880d8 (diff) |
Change how vertex/instance attributes are handled in geometry processors.
* No longer register vertex/instance attributes on base class, just counts
* Separate instance and vertex attributes and remove InputRate and offset
* Make attributes constexpr where possible
Change-Id: I1f1d5e772fa177a96d2aeb805aab7b69f35bfae6
Reviewed-on: https://skia-review.googlesource.com/132405
Commit-Queue: Brian Salomon <bsalomon@google.com>
Reviewed-by: Chris Dalton <csmartdalton@google.com>
Diffstat (limited to 'src/gpu/GrPrimitiveProcessor.cpp')
-rw-r--r-- | src/gpu/GrPrimitiveProcessor.cpp | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/src/gpu/GrPrimitiveProcessor.cpp b/src/gpu/GrPrimitiveProcessor.cpp index 7d1e1a644e..db79fb1052 100644 --- a/src/gpu/GrPrimitiveProcessor.cpp +++ b/src/gpu/GrPrimitiveProcessor.cpp @@ -17,6 +17,58 @@ enum MatrixType { kGeneral_MatrixType = 1, }; +GrPrimitiveProcessor::GrPrimitiveProcessor(ClassID classID) : GrResourceIOProcessor(classID) {} + +const GrPrimitiveProcessor::Attribute& GrPrimitiveProcessor::vertexAttribute(int i) const { + SkASSERT(i >= 0 && i < this->numVertexAttributes()); + const auto& result = this->onVertexAttribute(i); + SkASSERT(result.isInitialized()); + return result; +} + +const GrPrimitiveProcessor::Attribute& GrPrimitiveProcessor::instanceAttribute(int i) const { + SkASSERT(i >= 0 && i < this->numInstanceAttributes()); + const auto& result = this->onInstanceAttribute(i); + SkASSERT(result.isInitialized()); + return result; +} + +#ifdef SK_DEBUG +size_t GrPrimitiveProcessor::debugOnly_vertexStride() const { + size_t stride = 0; + for (int i = 0; i < fVertexAttributeCnt; ++i) { + stride += this->vertexAttribute(i).sizeAlign4(); + } + return stride; +} + +size_t GrPrimitiveProcessor::debugOnly_instanceStride() const { + size_t stride = 0; + for (int i = 0; i < fInstanceAttributeCnt; ++i) { + stride += this->instanceAttribute(i).sizeAlign4(); + } + return stride; +} + +size_t GrPrimitiveProcessor::debugOnly_vertexAttributeOffset(int i) const { + SkASSERT(i >= 0 && i < fVertexAttributeCnt); + size_t offset = 0; + for (int j = 0; j < i; ++j) { + offset += this->vertexAttribute(j).sizeAlign4(); + } + return offset; +} + +size_t GrPrimitiveProcessor::debugOnly_instanceAttributeOffset(int i) const { + SkASSERT(i >= 0 && i < fInstanceAttributeCnt); + size_t offset = 0; + for (int j = 0; j < i; ++j) { + offset += this->instanceAttribute(j).sizeAlign4(); + } + return offset; +} +#endif + uint32_t GrPrimitiveProcessor::getTransformKey(const SkTArray<const GrCoordTransform*, true>& coords, int numCoords) const { |