diff --git a/src/quick/scenegraph/coreapi/qsgnode.cpp b/src/quick/scenegraph/coreapi/qsgnode.cpp index 4c25338ef84bb7856adabce675b3740b380e4bac..0950148c98cd2357f61ec85dfff2f38d0112aceb 100644 --- a/src/quick/scenegraph/coreapi/qsgnode.cpp +++ b/src/quick/scenegraph/coreapi/qsgnode.cpp @@ -135,6 +135,7 @@ static void qt_print_node_count() \value OwnsOpaqueMaterial Only valid for QSGGeometryNode. The node has ownership over the opaque material and will delete it when the node is destroyed or a material is assigned. + \value InternalReserved Reserved for internal use. */ /*! diff --git a/src/quick/scenegraph/coreapi/qsgnode.h b/src/quick/scenegraph/coreapi/qsgnode.h index 86977f7854b6583456a375f6dbbc8e0291a45a01..3dc2a865bd8a78279f2d9014b57d31d477e59227 100644 --- a/src/quick/scenegraph/coreapi/qsgnode.h +++ b/src/quick/scenegraph/coreapi/qsgnode.h @@ -95,9 +95,14 @@ public: // QSGBasicGeometryNode OwnsGeometry = 0x00010000, OwnsMaterial = 0x00020000, - OwnsOpaqueMaterial = 0x00040000 + OwnsOpaqueMaterial = 0x00040000, // Uppermost 8 bits are reserved for internal use. +#ifndef qdoc + IsVisitableNode = 0x01000000 +#else + InternalReserved = 0x01000000 +#endif }; Q_DECLARE_FLAGS(Flags, Flag) diff --git a/src/quick/scenegraph/qsgadaptationlayer.cpp b/src/quick/scenegraph/qsgadaptationlayer.cpp index 9826fa8978311eed3dc1c4a01a3f5aeab8d42fdb..ee077dbaf1108b8536949c40a36fea736a651714 100644 --- a/src/quick/scenegraph/qsgadaptationlayer.cpp +++ b/src/quick/scenegraph/qsgadaptationlayer.cpp @@ -291,4 +291,52 @@ void QSGDistanceFieldGlyphCache::updateTexture(GLuint oldTex, GLuint newTex, con } } +void QSGNodeVisitorEx::visitChildren(QSGNode *node) +{ + for (QSGNode *child = node->firstChild(); child; child = child->nextSibling()) { + switch (child->type()) { + case QSGNode::ClipNodeType: { + QSGClipNode *c = static_cast<QSGClipNode*>(child); + visit(c); + visitChildren(c); + endVisit(c); + break; + } + case QSGNode::TransformNodeType: { + QSGTransformNode *c = static_cast<QSGTransformNode*>(child); + visit(c); + visitChildren(c); + endVisit(c); + break; + } + case QSGNode::OpacityNodeType: { + QSGOpacityNode *c = static_cast<QSGOpacityNode*>(child); + visit(c); + visitChildren(c); + endVisit(c); + break; + } + case QSGNode::GeometryNodeType: { + if (child->flags() & QSGNode::IsVisitableNode) { + QSGVisitableNode *v = static_cast<QSGVisitableNode*>(child); + v->accept(this); + } else { + QSGGeometryNode *c = static_cast<QSGGeometryNode*>(child); + visit(c); + visitChildren(c); + endVisit(c); + } + break; + } + case QSGNode::BasicNodeType: { + visitChildren(child); + break; + } + default: + Q_UNREACHABLE(); + break; + } + } +} + QT_END_NAMESPACE diff --git a/src/quick/scenegraph/qsgadaptationlayer_p.h b/src/quick/scenegraph/qsgadaptationlayer_p.h index f2d7dc07cade7d5ea7e8b1de10e3ea745c4577ee..46531f79fb5a03eae4dbd5de89c36809027c3238 100644 --- a/src/quick/scenegraph/qsgadaptationlayer_p.h +++ b/src/quick/scenegraph/qsgadaptationlayer_p.h @@ -67,8 +67,41 @@ class TextureReference; class QSGDistanceFieldGlyphCacheManager; class QSGDistanceFieldGlyphNode; class QOpenGLContext; +class QSGImageNode; +class QSGRectangleNode; +class QSGGlyphNode; -class Q_QUICK_PRIVATE_EXPORT QSGRectangleNode : public QSGGeometryNode +class Q_QUICK_PRIVATE_EXPORT QSGNodeVisitorEx +{ +public: + virtual void visit(QSGTransformNode *) = 0; + virtual void endVisit(QSGTransformNode *) = 0; + virtual void visit(QSGClipNode *) = 0; + virtual void endVisit(QSGClipNode *) = 0; + virtual void visit(QSGGeometryNode *) = 0; + virtual void endVisit(QSGGeometryNode *) = 0; + virtual void visit(QSGOpacityNode *) = 0; + virtual void endVisit(QSGOpacityNode *) = 0; + virtual void visit(QSGImageNode *) = 0; + virtual void endVisit(QSGImageNode *) = 0; + virtual void visit(QSGRectangleNode *) = 0; + virtual void endVisit(QSGRectangleNode *) = 0; + virtual void visit(QSGGlyphNode *) = 0; + virtual void endVisit(QSGGlyphNode *) = 0; + + void visitChildren(QSGNode *node); +}; + + +class Q_QUICK_PRIVATE_EXPORT QSGVisitableNode : public QSGGeometryNode +{ +public: + QSGVisitableNode() { setFlag(IsVisitableNode); } + + virtual void accept(QSGNodeVisitorEx *) = 0; +}; + +class Q_QUICK_PRIVATE_EXPORT QSGRectangleNode : public QSGVisitableNode { public: virtual void setRect(const QRectF &rect) = 0; @@ -81,10 +114,12 @@ public: virtual void setAligned(bool aligned) = 0; virtual void update() = 0; + + virtual void accept(QSGNodeVisitorEx *visitor) { visitor->visit(this); visitor->visitChildren(this); visitor->endVisit(this); } }; -class Q_QUICK_PRIVATE_EXPORT QSGImageNode : public QSGGeometryNode +class Q_QUICK_PRIVATE_EXPORT QSGImageNode : public QSGVisitableNode { public: virtual void setTargetRect(const QRectF &rect) = 0; @@ -103,10 +138,12 @@ public: virtual void setVerticalWrapMode(QSGTexture::WrapMode wrapMode) = 0; virtual void update() = 0; + + virtual void accept(QSGNodeVisitorEx *visitor) { visitor->visit(this); visitor->visitChildren(this); visitor->endVisit(this); } }; -class Q_QUICK_PRIVATE_EXPORT QSGGlyphNode : public QSGGeometryNode +class Q_QUICK_PRIVATE_EXPORT QSGGlyphNode : public QSGVisitableNode { public: enum AntialiasingMode @@ -134,6 +171,7 @@ public: void setOwnerElement(QQuickItem *ownerElement) { m_ownerElement = ownerElement; } QQuickItem *ownerElement() const { return m_ownerElement; } + virtual void accept(QSGNodeVisitorEx *visitor) { visitor->visit(this); visitor->visitChildren(this); visitor->endVisit(this); } protected: QRectF m_bounding_rect; QQuickItem *m_ownerElement;