diff options
author | Mauro Persano <mauro.persano@kdab.com> | 2017-06-16 21:49:51 -0300 |
---|---|---|
committer | Mauro Persano <mauro.persano@kdab.com> | 2017-06-28 18:02:41 +0000 |
commit | d8a0b70fccf65e60b7e5d98a891264b7f83d9ab9 (patch) | |
tree | 28626e6da343e47339fd6b04b01d9f723ca00c3e /src/render/geometry | |
parent | f5b8609f26878e8f6aa1c3006ebe59c96f1827b3 (diff) |
QGeometryRenderer: add index buffer byte-offset property
Add property to QGeometryRender to set a byte-offset into the index
buffer. The property will only be valid when the geometry has an index
buffer attribute.
Task-number: QTBUG-60027
Change-Id: I87409b89766e622fd9a4ab8233f0bc0578f15852
Reviewed-by: Paul Lemire <paul.lemire@kdab.com>
Diffstat (limited to 'src/render/geometry')
-rw-r--r-- | src/render/geometry/geometryrenderer.cpp | 6 | ||||
-rw-r--r-- | src/render/geometry/geometryrenderer_p.h | 2 | ||||
-rw-r--r-- | src/render/geometry/qgeometryrenderer.cpp | 29 | ||||
-rw-r--r-- | src/render/geometry/qgeometryrenderer.h | 4 | ||||
-rw-r--r-- | src/render/geometry/qgeometryrenderer_p.h | 2 |
5 files changed, 43 insertions, 0 deletions
diff --git a/src/render/geometry/geometryrenderer.cpp b/src/render/geometry/geometryrenderer.cpp index d69cbcbd9..978ee6252 100644 --- a/src/render/geometry/geometryrenderer.cpp +++ b/src/render/geometry/geometryrenderer.cpp @@ -64,6 +64,7 @@ GeometryRenderer::GeometryRenderer() , m_indexOffset(0) , m_firstInstance(0) , m_firstVertex(0) + , m_indexBufferByteOffset(0) , m_restartIndexValue(-1) , m_verticesPerPatch(0) , m_primitiveRestartEnabled(false) @@ -85,6 +86,7 @@ void GeometryRenderer::cleanup() m_indexOffset = 0; m_firstInstance = 0; m_firstVertex = 0; + m_indexBufferByteOffset = 0; m_restartIndexValue = -1; m_verticesPerPatch = 0; m_primitiveRestartEnabled = false; @@ -111,6 +113,7 @@ void GeometryRenderer::initializeFromPeer(const Qt3DCore::QNodeCreatedChangeBase m_indexOffset = data.indexOffset; m_firstInstance = data.firstInstance; m_firstVertex = data.firstVertex; + m_indexBufferByteOffset = data.indexBufferByteOffset; m_restartIndexValue = data.restartIndexValue; m_verticesPerPatch = data.verticesPerPatch; m_primitiveRestartEnabled = data.primitiveRestart; @@ -146,6 +149,9 @@ void GeometryRenderer::sceneChangeEvent(const Qt3DCore::QSceneChangePtr &e) } else if (propertyName == QByteArrayLiteral("firstVertex")) { m_firstVertex = propertyChange->value().value<int>(); m_dirty = true; + } else if (propertyName == QByteArrayLiteral("indexBufferByteOffset")) { + m_indexBufferByteOffset = propertyChange->value().value<int>(); + m_dirty = true; } else if (propertyName == QByteArrayLiteral("restartIndexValue")) { m_restartIndexValue = propertyChange->value().value<int>(); m_dirty = true; diff --git a/src/render/geometry/geometryrenderer_p.h b/src/render/geometry/geometryrenderer_p.h index 24edf6152..5a7358f00 100644 --- a/src/render/geometry/geometryrenderer_p.h +++ b/src/render/geometry/geometryrenderer_p.h @@ -83,6 +83,7 @@ public: inline int indexOffset() const { return m_indexOffset; } inline int firstInstance() const { return m_firstInstance; } inline int firstVertex() const { return m_firstVertex; } + inline int indexBufferByteOffset() const { return m_indexBufferByteOffset; } inline int restartIndexValue() const { return m_restartIndexValue; } inline int verticesPerPatch() const { return m_verticesPerPatch; } inline bool primitiveRestartEnabled() const { return m_primitiveRestartEnabled; } @@ -105,6 +106,7 @@ private: int m_indexOffset; int m_firstInstance; int m_firstVertex; + int m_indexBufferByteOffset; int m_restartIndexValue; int m_verticesPerPatch; bool m_primitiveRestartEnabled; diff --git a/src/render/geometry/qgeometryrenderer.cpp b/src/render/geometry/qgeometryrenderer.cpp index 443b7cbac..666c72d83 100644 --- a/src/render/geometry/qgeometryrenderer.cpp +++ b/src/render/geometry/qgeometryrenderer.cpp @@ -58,6 +58,7 @@ QGeometryRendererPrivate::QGeometryRendererPrivate() , m_indexOffset(0) , m_firstInstance(0) , m_firstVertex(0) + , m_indexBufferByteOffset(0) , m_restartIndexValue(-1) , m_verticesPerPatch(0) , m_primitiveRestart(false) @@ -145,6 +146,12 @@ QGeometryRendererPrivate::~QGeometryRendererPrivate() */ /*! + \qmlproperty int GeometryRenderer::indexBufferByteOffset + + Holds the byte offset into the index buffer. + */ + +/*! \qmlproperty int GeometryRenderer::restartIndex Holds the restart index. @@ -269,6 +276,17 @@ int QGeometryRenderer::firstVertex() const } /*! + \property QGeometryRenderer::indexBufferByteOffset + + Holds the byte offset into the index buffer. + */ +int QGeometryRenderer::indexBufferByteOffset() const +{ + Q_D(const QGeometryRenderer); + return d->m_indexBufferByteOffset; +} + +/*! \property QGeometryRenderer::restartIndexValue Holds the restart index. @@ -382,6 +400,16 @@ void QGeometryRenderer::setFirstVertex(int firstVertex) emit firstVertexChanged(firstVertex); } +void QGeometryRenderer::setIndexBufferByteOffset(int offset) +{ + Q_D(QGeometryRenderer); + if (d->m_indexBufferByteOffset == offset) + return; + + d->m_indexBufferByteOffset = offset; + emit indexBufferByteOffsetChanged(offset); +} + void QGeometryRenderer::setRestartIndexValue(int index) { Q_D(QGeometryRenderer); @@ -482,6 +510,7 @@ Qt3DCore::QNodeCreatedChangeBasePtr QGeometryRenderer::createNodeCreationChange( data.indexOffset = d->m_indexOffset; data.firstInstance = d->m_firstInstance; data.firstVertex = d->m_firstVertex; + data.indexBufferByteOffset = d->m_indexBufferByteOffset; data.restartIndexValue = d->m_restartIndexValue; data.verticesPerPatch = d->m_verticesPerPatch; data.primitiveRestart = d->m_primitiveRestart; diff --git a/src/render/geometry/qgeometryrenderer.h b/src/render/geometry/qgeometryrenderer.h index 28d580990..704e2f89f 100644 --- a/src/render/geometry/qgeometryrenderer.h +++ b/src/render/geometry/qgeometryrenderer.h @@ -61,6 +61,7 @@ class QT3DRENDERSHARED_EXPORT QGeometryRenderer : public Qt3DCore::QComponent Q_PROPERTY(int indexOffset READ indexOffset WRITE setIndexOffset NOTIFY indexOffsetChanged) Q_PROPERTY(int firstInstance READ firstInstance WRITE setFirstInstance NOTIFY firstInstanceChanged) Q_PROPERTY(int firstVertex READ firstVertex WRITE setFirstVertex NOTIFY firstVertexChanged) + Q_PROPERTY(int indexBufferByteOffset READ indexBufferByteOffset WRITE setIndexBufferByteOffset NOTIFY indexBufferByteOffsetChanged) Q_PROPERTY(int restartIndexValue READ restartIndexValue WRITE setRestartIndexValue NOTIFY restartIndexValueChanged) Q_PROPERTY(int verticesPerPatch READ verticesPerPatch WRITE setVerticesPerPatch NOTIFY verticesPerPatchChanged) Q_PROPERTY(bool primitiveRestartEnabled READ primitiveRestartEnabled WRITE setPrimitiveRestartEnabled NOTIFY primitiveRestartEnabledChanged) @@ -95,6 +96,7 @@ public: int indexOffset() const; int firstInstance() const; int firstVertex() const; + int indexBufferByteOffset() const; int restartIndexValue() const; int verticesPerPatch() const; bool primitiveRestartEnabled() const; @@ -110,6 +112,7 @@ public Q_SLOTS: void setIndexOffset(int indexOffset); void setFirstInstance(int firstInstance); void setFirstVertex(int firstVertex); + void setIndexBufferByteOffset(int offset); void setRestartIndexValue(int index); void setVerticesPerPatch(int verticesPerPatch); void setPrimitiveRestartEnabled(bool enabled); @@ -122,6 +125,7 @@ Q_SIGNALS: void indexOffsetChanged(int indexOffset); void firstInstanceChanged(int firstInstance); void firstVertexChanged(int firstVertex); + void indexBufferByteOffsetChanged(int offset); void restartIndexValueChanged(int restartIndexValue); void verticesPerPatchChanged(int verticesPerPatch); void primitiveRestartEnabledChanged(bool primitiveRestartEnabled); diff --git a/src/render/geometry/qgeometryrenderer_p.h b/src/render/geometry/qgeometryrenderer_p.h index 324dc9609..8096b4a6b 100644 --- a/src/render/geometry/qgeometryrenderer_p.h +++ b/src/render/geometry/qgeometryrenderer_p.h @@ -75,6 +75,7 @@ public: int m_indexOffset; int m_firstInstance; int m_firstVertex; + int m_indexBufferByteOffset; int m_restartIndexValue; int m_verticesPerPatch; bool m_primitiveRestart; @@ -90,6 +91,7 @@ struct QGeometryRendererData int indexOffset; int firstInstance; int firstVertex; + int indexBufferByteOffset; int restartIndexValue; int verticesPerPatch; bool primitiveRestart; |