523void QQuickWindowPrivate::syncSceneGraph()
527 const bool wasRtDirty = redirect.renderTargetDirty;
528 ensureCustomRenderTarget();
530 QRhiCommandBuffer *cb =
nullptr;
532 if (redirect.commandBuffer)
533 cb = redirect.commandBuffer;
535 cb = swapchain->currentFrameCommandBuffer();
537 context->prepareSync(q->effectiveDevicePixelRatio(), cb, graphicsConfig);
539 animationController->beforeNodeSync();
541 emit q->beforeSynchronizing();
542 runAndClearJobs(&beforeSynchronizingJobs);
544 if (pendingFontUpdate) {
546 invalidateFontData(contentItem);
547 context->invalidateGlyphCaches();
550 if (Q_UNLIKELY(!renderer)) {
551 forceUpdate(contentItem);
553 QSGRootNode *rootNode =
new QSGRootNode;
554 rootNode->appendChildNode(QQuickItemPrivate::get(contentItem)->itemNode());
555 const bool useDepth = graphicsConfig.isDepthBufferEnabledFor2D();
556 const QSGRendererInterface::RenderMode renderMode = useDepth ? QSGRendererInterface::RenderMode2D
557 : QSGRendererInterface::RenderMode2DNoDepthBuffer;
558 renderer = context->createRenderer(renderMode);
559 renderer->setRootNode(rootNode);
560 }
else if (Q_UNLIKELY(wasRtDirty)
561 && q->rendererInterface()->graphicsApi() == QSGRendererInterface::Software) {
562 auto softwareRenderer =
static_cast<QSGSoftwareRenderer *>(renderer);
563 softwareRenderer->markDirty();
568 animationController->afterNodeSync();
570 renderer->setClearColor(clearColor);
572 renderer->setVisualizationMode(visualizationMode);
574 if (pendingFontUpdate) {
575 context->flushGlyphCaches();
576 pendingFontUpdate =
false;
579 emit q->afterSynchronizing();
580 runAndClearJobs(&afterSynchronizingJobs);
619void QQuickWindowPrivate::renderSceneGraph()
625 ensureCustomRenderTarget();
627 QSGRenderTarget sgRenderTarget;
629 QRhiRenderTarget *rt;
630 QRhiRenderPassDescriptor *rp;
631 QRhiCommandBuffer *cb;
632 if (redirect.rt.rt.renderTarget) {
633 rt = redirect.rt.rt.renderTarget;
634 rp = rt->renderPassDescriptor();
636 qWarning(
"Custom render target is set but no renderpass descriptor has been provided.");
639 cb = redirect.commandBuffer;
641 qWarning(
"Custom render target is set but no command buffer has been provided.");
646 qWarning(
"QQuickWindow: No render target (neither swapchain nor custom target was provided)");
649 rt = swapchain->currentFrameRenderTarget();
650 rp = rpDescForSwapchain;
651 cb = swapchain->currentFrameCommandBuffer();
653 sgRenderTarget = QSGRenderTarget(rt, rp, cb);
654 sgRenderTarget.multiViewCount = multiViewCount();
656 sgRenderTarget = QSGRenderTarget(redirect.rt.sw.paintDevice);
659 context->beginNextFrame(renderer,
661 emitBeforeRenderPassRecording,
662 emitAfterRenderPassRecording,
665 animationController->advance();
666 emit q->beforeRendering();
667 runAndClearJobs(&beforeRenderingJobs);
669 const qreal devicePixelRatio = q->effectiveDevicePixelRatio();
671 if (redirect.rt.rt.renderTarget)
672 pixelSize = redirect.rt.rt.renderTarget->pixelSize();
673 else if (redirect.rt.sw.paintDevice)
674 pixelSize = QSize(redirect.rt.sw.paintDevice->width(), redirect.rt.sw.paintDevice->height());
676 pixelSize = swapchain->currentPixelSize();
678 pixelSize = q->size() * devicePixelRatio;
680 renderer->setDevicePixelRatio(devicePixelRatio);
681 renderer->setDeviceRect(QRect(QPoint(0, 0), pixelSize));
682 renderer->setViewportRect(QRect(QPoint(0, 0), pixelSize));
684 QSGAbstractRenderer::MatrixTransformFlags matrixFlags;
685 bool flipY = rhi ? !rhi->isYUpInNDC() :
false;
686 if (!customRenderTarget.isNull() && customRenderTarget.mirrorVertically())
689 matrixFlags |= QSGAbstractRenderer::MatrixTransformFlipY;
691 const QRectF rect(QPointF(0, 0), pixelSize / devicePixelRatio);
692 renderer->setProjectionMatrixToRect(rect, matrixFlags, rhi && !rhi->isYUpInNDC());
694 context->renderNextFrame(renderer);
696 emit q->afterRendering();
697 runAndClearJobs(&afterRenderingJobs);
699 context->endNextFrame(renderer);
701 if (renderer && renderer->hasVisualizationModeWithContinuousUpdate()) {
705 QCoreApplication::postEvent(q,
new QEvent(QEvent::Type(FullUpdateRequest)));
775void QQuickWindowPrivate::init(QQuickWindow *c, QQuickRenderControl *control)
782 contentItem =
new QQuickRootItem;
783 contentItem->setObjectName(q->objectName());
784 QQml_setParent_noEvent(contentItem, c);
785 QQmlEngine::setObjectOwnership(contentItem, QQmlEngine::CppOwnership);
786 QQuickItemPrivate *contentItemPrivate = QQuickItemPrivate::get(contentItem);
787 contentItemPrivate->window = q;
788 contentItemPrivate->windowRefCount = 1;
789 contentItemPrivate->flags |= QQuickItem::ItemIsFocusScope;
790 contentItem->setSize(q->size());
791 deliveryAgent =
new QQuickDeliveryAgent(contentItem);
793 visualizationMode = qgetenv(
"QSG_VISUALIZE");
794 renderControl = control;
796 QQuickRenderControlPrivate::get(renderControl)->window = q;
799 windowManager = QSGRenderLoop::instance();
801 Q_ASSERT(windowManager || renderControl);
803 QObject::connect(
static_cast<QGuiApplication *>(QGuiApplication::instance()),
804 &QGuiApplication::fontDatabaseChanged,
806 &QQuickWindow::handleFontDatabaseChanged);
809 lastReportedItemDevicePixelRatio = q->effectiveDevicePixelRatio();
814 QQuickRenderControlPrivate *renderControlPriv = QQuickRenderControlPrivate::get(renderControl);
815 sg = renderControlPriv->sg;
816 context = renderControlPriv->rc;
818 windowManager->addWindow(q);
819 sg = windowManager->sceneGraphContext();
820 context = windowManager->createRenderContext(sg);
823 q->setSurfaceType(windowManager ? windowManager->windowSurfaceType() : QSurface::OpenGLSurface);
824 q->setFormat(sg->defaultSurfaceFormat());
830 animationController.reset(
new QQuickAnimatorController(q));
833 QObject::connect(context, &QSGRenderContext::initialized, q, &QQuickWindow::sceneGraphInitialized, Qt::DirectConnection),
834 QObject::connect(context, &QSGRenderContext::invalidated, q, &QQuickWindow::sceneGraphInvalidated, Qt::DirectConnection),
835 QObject::connect(context, &QSGRenderContext::invalidated, q, &QQuickWindow::cleanupSceneGraph, Qt::DirectConnection),
837 QObject::connect(q, &QQuickWindow::focusObjectChanged, q, &QQuickWindow::activeFocusItemChanged),
838 QObject::connect(q, &QQuickWindow::screenChanged, q, &QQuickWindow::handleScreenChanged),
839 QObject::connect(qApp, &QGuiApplication::applicationStateChanged, q, &QQuickWindow::handleApplicationStateChanged),
840 QObject::connect(q, &QQuickWindow::frameSwapped, q, &QQuickWindow::runJobsAfterSwap, Qt::DirectConnection),
843 if (QQmlInspectorService *service = QQmlDebugConnector::service<QQmlInspectorService>())
844 service->addWindow(q);
1222QQuickWindow::~QQuickWindow()
1225 d->inDestructor =
true;
1226 if (d->renderControl) {
1227 QQuickRenderControlPrivate::get(d->renderControl)->windowDestroyed();
1228 }
else if (d->windowManager) {
1229 d->windowManager->removeWindow(
this);
1230 d->windowManager->windowDestroyed(
this);
1233 disconnect(
this, &QQuickWindow::focusObjectChanged,
this, &QQuickWindow::activeFocusItemChanged);
1234 disconnect(
this, &QQuickWindow::screenChanged,
this, &QQuickWindow::handleScreenChanged);
1235 disconnect(qApp, &QGuiApplication::applicationStateChanged,
this, &QQuickWindow::handleApplicationStateChanged);
1236 disconnect(
this, &QQuickWindow::frameSwapped,
this, &QQuickWindow::runJobsAfterSwap);
1238 delete d->incubationController; d->incubationController =
nullptr;
1239 QQuickRootItem *root = d->contentItem;
1240 d->contentItem =
nullptr;
1241 root->setParent(
nullptr);
1243 d->deliveryAgent =
nullptr;
1247 const std::lock_guard locker(d->renderJobMutex);
1248 qDeleteAll(std::exchange(d->beforeSynchronizingJobs, {}));
1249 qDeleteAll(std::exchange(d->afterSynchronizingJobs, {}));
1250 qDeleteAll(std::exchange(d->beforeRenderingJobs, {}));
1251 qDeleteAll(std::exchange(d->afterRenderingJobs, {}));;
1252 qDeleteAll(std::exchange(d->afterSwapJobs, {}));
1260 QQuickPixmap::purgeCache();
1262 for (
const QMetaObject::Connection &connection : d->connections)
1263 disconnect(connection);
1461bool QQuickWindow::event(QEvent *event)
1466 QQuickDeliveryAgent *da = d->deliveryAgent;
1467 if (event->isPointerEvent()) {
1469
1470
1471
1472
1473
1474
1475
1476
1477
1478 if (d->windowEventDispatch)
1481 const bool wasAccepted = event->isAccepted();
1482 QScopedValueRollback windowEventDispatchGuard(d->windowEventDispatch,
true);
1483 qCDebug(lcPtr) <<
"dispatching to window functions in case of override" << event;
1484 QWindow::event(event);
1485 if (event->isAccepted() && !wasAccepted)
1489
1490
1491
1492
1493
1494
1495 auto pe =
static_cast<QPointerEvent *>(event);
1496 if (QQuickDeliveryAgentPrivate::isTouchEvent(pe))
1501
1502
1503
1504
1505
1506
1507
1508
1509
1510
1511
1512
1513 if (pe->pointCount()) {
1514 const bool synthMouse = QQuickDeliveryAgentPrivate::isSynthMouse(pe);
1515 if (QQuickDeliveryAgentPrivate::subsceneAgentsExist) {
1519 QFlatMap<QQuickDeliveryAgent*, QList<QEventPoint>> deliveryAgentsNeedingPoints;
1520 QEventPoint::States eventStates;
1522 auto insert = [&](QQuickDeliveryAgent *ptda,
const QEventPoint &pt) {
1523 if (pt.state() == QEventPoint::Pressed && !synthMouse)
1524 pe->clearPassiveGrabbers(pt);
1525 auto &ptList = deliveryAgentsNeedingPoints[ptda];
1526 auto idEquals = [](
auto id) {
return [id] (
const auto &e) {
return e.id() == id; }; };
1527 if (std::none_of(ptList.cbegin(), ptList.cend(), idEquals(pt.id())))
1531 for (
const auto &pt : pe->points()) {
1532 eventStates |= pt.state();
1533 auto epd = QPointingDevicePrivate::get(
const_cast<QPointingDevice*>(pe->pointingDevice()))->queryPointById(pt.id());
1535 bool foundAgent =
false;
1536 if (!epd->exclusiveGrabber.isNull() && !epd->exclusiveGrabberContext.isNull()) {
1537 if (
auto ptda = qobject_cast<QQuickDeliveryAgent *>(epd->exclusiveGrabberContext.data())) {
1539 qCDebug(lcPtr) << pe->type() <<
"point" << pt.id() << pt.state()
1540 <<
"@" << pt.scenePosition() <<
"will be re-delivered via known grabbing agent" << ptda <<
"to" << epd->exclusiveGrabber.data();
1544 for (
auto pgda : epd->passiveGrabbersContext) {
1545 if (
auto ptda = qobject_cast<QQuickDeliveryAgent *>(pgda.data())) {
1547 qCDebug(lcPtr) << pe->type() <<
"point" << pt.id() << pt.state()
1548 <<
"@" << pt.scenePosition() <<
"will be re-delivered via known passive-grabbing agent" << ptda;
1556 for (
auto daAndPoints : deliveryAgentsNeedingPoints) {
1557 if (pe->pointCount() > 1) {
1558 Q_ASSERT(QQuickDeliveryAgentPrivate::isTouchEvent(pe));
1560 QEvent::Type eventType = pe->type();
1561 switch (eventStates) {
1562 case QEventPoint::State::Pressed:
1563 eventType = QEvent::TouchBegin;
1565 case QEventPoint::State::Released:
1566 eventType = QEvent::TouchEnd;
1569 eventType = QEvent::TouchUpdate;
1573 QMutableTouchEvent te(eventType, pe->pointingDevice(), pe->modifiers(), daAndPoints.second);
1574 te.setTimestamp(pe->timestamp());
1576 qCDebug(lcTouch) << daAndPoints.first <<
"shall now receive" << &te;
1577 ret = daAndPoints.first->event(&te) || ret;
1579 qCDebug(lcPtr) << daAndPoints.first <<
"shall now receive" << pe;
1580 ret = daAndPoints.first->event(pe) || ret;
1585 d->deliveryAgentPrivate()->clearGrabbers(pe);
1588 }
else if (!synthMouse) {
1591 for (
const auto &pt : pe->points()) {
1592 if (pt.state() == QEventPoint::Pressed)
1593 pe->clearPassiveGrabbers(pt);
1602 qCDebug(lcHoverTrace) <<
this <<
"some sort of event" << event;
1603 bool ret = (da && da->event(event));
1605 d->deliveryAgentPrivate()->clearGrabbers(pe);
1607 if (pe->type() == QEvent::MouseButtonPress || pe->type() == QEvent::MouseButtonRelease) {
1610 d->maybeSynthesizeContextMenuEvent(
static_cast<QMouseEvent *>(pe));
1615 }
else if (event->isInputEvent()) {
1616 if (da && da->event(event))
1620 switch (event->type()) {
1622 case QEvent::FocusAboutToChange:
1625 case QEvent::InputMethod:
1626 case QEvent::InputMethodQuery:
1627#if QT_CONFIG(quick_draganddrop)
1628 case QEvent::DragEnter:
1629 case QEvent::DragLeave:
1630 case QEvent::DragMove:
1633 if (d->inDestructor)
1635 if (da && da->event(event))
1638 case QEvent::LanguageChange:
1639 case QEvent::LocaleChange:
1641 QCoreApplication::sendEvent(d->contentItem, event);
1643 case QEvent::UpdateRequest:
1644 if (d->windowManager)
1645 d->windowManager->handleUpdateRequest(
this);
1647 case QEvent::PlatformSurface:
1648 if ((
static_cast<QPlatformSurfaceEvent *>(event))->surfaceEventType() == QPlatformSurfaceEvent::SurfaceAboutToBeDestroyed) {
1651 if (d->windowManager)
1652 d->windowManager->hide(
this);
1655 case QEvent::WindowDeactivate:
1656 if (
auto da = d->deliveryAgentPrivate())
1657 da->handleWindowDeactivate(
this);
1659 case QEvent::WindowActivate:
1661 QCoreApplication::sendEvent(d->contentItem, event);
1663 case QEvent::ApplicationPaletteChange:
1664 d->inheritPalette(QGuiApplication::palette());
1666 QCoreApplication::sendEvent(d->contentItem, event);
1668 case QEvent::DevicePixelRatioChange:
1669 physicalDpiChanged();
1671 case QEvent::SafeAreaMarginsChange:
1672 QQuickSafeArea::updateSafeAreasRecursively(d->contentItem);
1674 case QEvent::ChildWindowAdded: {
1675 auto *childEvent =
static_cast<QChildWindowEvent*>(event);
1676 auto *childWindow = childEvent->child();
1677 qCDebug(lcQuickWindow) <<
"Child window" << childWindow <<
"added to" <<
this;
1678 if (childWindow->handle()) {
1684 d->updateChildWindowStackingOrder();
1686 qCDebug(lcQuickWindow) <<
"No platform window yet."
1687 <<
"Deferring child window stacking until surface creation";
1695 if (event->type() == QEvent::Type(QQuickWindowPrivate::FullUpdateRequest))
1697 else if (event->type() == QEvent::Type(QQuickWindowPrivate::TriggerContextCreationFailure))
1698 d->windowManager->handleContextCreationFailure(
this);
1700 if (event->isPointerEvent())
1703 return QWindow::event(event);
2172void QQuickWindowPrivate::updateDirtyNode(QQuickItem *item)
2174 QQuickItemPrivate *itemPriv = QQuickItemPrivate::get(item);
2175 quint32 dirty = itemPriv->dirtyAttributes;
2176 itemPriv->dirtyAttributes = 0;
2178 if ((dirty & QQuickItemPrivate::TransformUpdateMask) ||
2179 (dirty & QQuickItemPrivate::Size && itemPriv->origin() != QQuickItem::TopLeft &&
2180 (itemPriv->scale() != 1. || itemPriv->rotation() != 0.))) {
2184 if (itemPriv->x != 0. || itemPriv->y != 0.)
2185 matrix.translate(itemPriv->x, itemPriv->y);
2187 for (
int ii = itemPriv->transforms.size() - 1; ii >= 0; --ii)
2188 itemPriv->transforms.at(ii)->applyTo(&matrix);
2190 if (itemPriv->scale() != 1. || itemPriv->rotation() != 0.) {
2191 QPointF origin = item->transformOriginPoint();
2192 matrix.translate(origin.x(), origin.y());
2193 if (itemPriv->scale() != 1.)
2194 matrix.scale(itemPriv->scale(), itemPriv->scale());
2195 if (itemPriv->rotation() != 0.)
2196 matrix.rotate(itemPriv->rotation(), 0, 0, 1);
2197 matrix.translate(-origin.x(), -origin.y());
2200 itemPriv->itemNode()->setMatrix(matrix);
2203 const bool clipEffectivelyChanged = dirty & (QQuickItemPrivate::Clip | QQuickItemPrivate::Window);
2204 if (clipEffectivelyChanged) {
2205 QSGNode *parent = itemPriv->opacityNode() ? (QSGNode *)itemPriv->opacityNode()
2206 : (QSGNode *)itemPriv->itemNode();
2207 QSGNode *child = itemPriv->rootNode();
2209 if (
bool initializeClipNode = item->clip() && itemPriv->clipNode() ==
nullptr;
2210 initializeClipNode) {
2211 QQuickDefaultClipNode *clip =
new QQuickDefaultClipNode(item->clipRect());
2212 itemPriv->extra.value().clipNode = clip;
2216 parent->reparentChildNodesTo(clip);
2217 parent->appendChildNode(clip);
2219 parent->removeChildNode(child);
2220 clip->appendChildNode(child);
2221 parent->appendChildNode(clip);
2224 }
else if (
bool updateClipNode = item->clip() && itemPriv->clipNode() !=
nullptr;
2226 QQuickDefaultClipNode *clip = itemPriv->clipNode();
2227 clip->setClipRect(item->clipRect());
2229 }
else if (
bool removeClipNode = !item->clip() && itemPriv->clipNode() !=
nullptr;
2231 QQuickDefaultClipNode *clip = itemPriv->clipNode();
2232 parent->removeChildNode(clip);
2234 clip->removeChildNode(child);
2235 parent->appendChildNode(child);
2237 clip->reparentChildNodesTo(parent);
2240 delete itemPriv->clipNode();
2241 itemPriv->extra->clipNode =
nullptr;
2245 const int effectRefCount = itemPriv->extra.isAllocated() ? itemPriv->extra->effectRefCount : 0;
2246 const bool effectRefEffectivelyChanged =
2247 (dirty & (QQuickItemPrivate::EffectReference | QQuickItemPrivate::Window))
2248 && ((effectRefCount == 0) != (itemPriv->rootNode() ==
nullptr));
2249 if (effectRefEffectivelyChanged) {
2250 if (dirty & QQuickItemPrivate::ChildrenUpdateMask)
2251 itemPriv->childContainerNode()->removeAllChildNodes();
2253 QSGNode *parent = itemPriv->clipNode();
2255 parent = itemPriv->opacityNode();
2257 parent = itemPriv->itemNode();
2259 if (itemPriv->extra.isAllocated() && itemPriv->extra->effectRefCount) {
2260 Q_ASSERT(itemPriv->rootNode() ==
nullptr);
2261 QSGRootNode *root =
new QSGRootNode();
2262 itemPriv->extra->rootNode = root;
2263 parent->reparentChildNodesTo(root);
2264 parent->appendChildNode(root);
2266 Q_ASSERT(itemPriv->rootNode() !=
nullptr);
2267 QSGRootNode *root = itemPriv->rootNode();
2268 parent->removeChildNode(root);
2269 root->reparentChildNodesTo(parent);
2270 delete itemPriv->rootNode();
2271 itemPriv->extra->rootNode =
nullptr;
2275 if (dirty & QQuickItemPrivate::ChildrenUpdateMask) {
2277 bool fetchedPaintNode =
false;
2278 QList<QQuickItem *> orderedChildren = itemPriv->paintOrderChildItems();
2279 int desiredNodesSize = orderedChildren.size() + (itemPriv->paintNode ? 1 : 0);
2287 int desiredNodesProcessed = 0;
2292 QSGNode *groupNode = itemPriv->childContainerNode();
2293 QSGNode *currentNode = groupNode->firstChild();
2294 QSGNode *desiredNode =
nullptr;
2296 while (currentNode && (desiredNode = fetchNextNode(itemPriv, ii, fetchedPaintNode))) {
2297 if (currentNode != desiredNode) {
2300 if (currentNode->nextSibling() == desiredNode) {
2302 groupNode->removeChildNode(currentNode);
2307 if (desiredNode->parent()) {
2308 desiredNode->parent()->removeChildNode(desiredNode);
2310 groupNode->insertChildNodeBefore(desiredNode, currentNode);
2314 currentNode = desiredNode;
2317 currentNode = currentNode->nextSibling();
2318 desiredNodesProcessed++;
2324 if (desiredNodesProcessed < desiredNodesSize) {
2325 while ((desiredNode = fetchNextNode(itemPriv, ii, fetchedPaintNode))) {
2326 if (desiredNode->parent())
2327 desiredNode->parent()->removeChildNode(desiredNode);
2328 groupNode->appendChildNode(desiredNode);
2330 }
else if (currentNode) {
2334 while (currentNode) {
2335 QSGNode *node = currentNode->nextSibling();
2336 groupNode->removeChildNode(currentNode);
2342 if ((dirty & QQuickItemPrivate::Size) && itemPriv->clipNode()) {
2343 itemPriv->clipNode()->setRect(item->clipRect());
2344 itemPriv->clipNode()->update();
2347 if (dirty & (QQuickItemPrivate::OpacityValue | QQuickItemPrivate::Visible
2348 | QQuickItemPrivate::HideReference | QQuickItemPrivate::Window))
2350 qreal opacity = itemPriv->explicitVisible && (!itemPriv->extra.isAllocated() || itemPriv->extra->hideRefCount == 0)
2351 ? itemPriv->opacity() : qreal(0);
2353 if (opacity != 1 && !itemPriv->opacityNode()) {
2354 QSGOpacityNode *node =
new QSGOpacityNode;
2355 itemPriv->extra.value().opacityNode = node;
2357 QSGNode *parent = itemPriv->itemNode();
2358 QSGNode *child = itemPriv->clipNode();
2360 child = itemPriv->rootNode();
2363 parent->removeChildNode(child);
2364 node->appendChildNode(child);
2365 parent->appendChildNode(node);
2367 parent->reparentChildNodesTo(node);
2368 parent->appendChildNode(node);
2371 if (itemPriv->opacityNode())
2372 itemPriv->opacityNode()->setOpacity(opacity);
2375 if (dirty & QQuickItemPrivate::ContentUpdateMask) {
2377 if (itemPriv->flags & QQuickItem::ItemHasContents) {
2378 updatePaintNodeData.transformNode = itemPriv->itemNode();
2379 itemPriv->paintNode = item->updatePaintNode(itemPriv->paintNode, &updatePaintNodeData);
2381 Q_ASSERT(itemPriv->paintNode ==
nullptr ||
2382 itemPriv->paintNode->parent() ==
nullptr ||
2383 itemPriv->paintNode->parent() == itemPriv->childContainerNode());
2385 if (itemPriv->paintNode && itemPriv->paintNode->parent() ==
nullptr) {
2386 QSGNode *before = qquickitem_before_paintNode(itemPriv);
2387 if (before && before->parent()) {
2388 Q_ASSERT(before->parent() == itemPriv->childContainerNode());
2389 itemPriv->childContainerNode()->insertChildNodeAfter(itemPriv->paintNode, before);
2391 itemPriv->childContainerNode()->prependChildNode(itemPriv->paintNode);
2394 }
else if (itemPriv->paintNode) {
2395 delete itemPriv->paintNode;
2396 itemPriv->paintNode =
nullptr;
2403 QList<QSGNode *> nodes;
2404 nodes << itemPriv->itemNodeInstance
2405 << itemPriv->opacityNode()
2406 << itemPriv->clipNode()
2407 << itemPriv->rootNode()
2408 << itemPriv->paintNode;
2409 nodes.removeAll(
nullptr);
2411 Q_ASSERT(nodes.constFirst() == itemPriv->itemNodeInstance);
2412 for (
int i=1; i<nodes.size(); ++i) {
2413 QSGNode *n = nodes.at(i);
2415 Q_ASSERT(n->parent() == nodes.at(i-1));
2417 Q_ASSERT(n == itemPriv->paintNode || n == itemPriv->childContainerNode() || n->childCount() == 1);