summaryrefslogtreecommitdiffstats
path: root/src/render/geometry
diff options
context:
space:
mode:
authorMauro Persano <mauro.persano@kdab.com>2017-06-16 21:49:51 -0300
committerMauro Persano <mauro.persano@kdab.com>2017-06-28 18:02:41 +0000
commitd8a0b70fccf65e60b7e5d98a891264b7f83d9ab9 (patch)
tree28626e6da343e47339fd6b04b01d9f723ca00c3e /src/render/geometry
parentf5b8609f26878e8f6aa1c3006ebe59c96f1827b3 (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.cpp6
-rw-r--r--src/render/geometry/geometryrenderer_p.h2
-rw-r--r--src/render/geometry/qgeometryrenderer.cpp29
-rw-r--r--src/render/geometry/qgeometryrenderer.h4
-rw-r--r--src/render/geometry/qgeometryrenderer_p.h2
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;