diff options
Diffstat (limited to 'src/particles')
-rw-r--r-- | src/particles/qquickimageparticle.cpp | 19 | ||||
-rw-r--r-- | src/particles/qquickmaskextruder.cpp | 6 |
2 files changed, 20 insertions, 5 deletions
diff --git a/src/particles/qquickimageparticle.cpp b/src/particles/qquickimageparticle.cpp index 05c21ecf56..29eb9ecdf2 100644 --- a/src/particles/qquickimageparticle.cpp +++ b/src/particles/qquickimageparticle.cpp @@ -1169,22 +1169,33 @@ bool QQuickImageParticle::loadingSomething() void QQuickImageParticle::mainThreadFetchImageData() { + const QQmlContext *context = nullptr; + QQmlEngine *engine = nullptr; + const auto loadPix = [&](ImageData *image) { + if (!engine) { + context = qmlContext(this); + engine = context->engine(); + } + image->pix.load(engine, context->resolvedUrl(image->source)); + }; + + if (m_image) {//ImageData created on setSource m_image->pix.clear(this); - m_image->pix.load(qmlEngine(this), m_image->source); + loadPix(m_image.get()); } if (m_spriteEngine) m_spriteEngine->startAssemblingImage(); if (m_colorTable) - m_colorTable->pix.load(qmlEngine(this), m_colorTable->source); + loadPix(m_colorTable.get()); if (m_sizeTable) - m_sizeTable->pix.load(qmlEngine(this), m_sizeTable->source); + loadPix(m_sizeTable.get()); if (m_opacityTable) - m_opacityTable->pix.load(qmlEngine(this), m_opacityTable->source); + loadPix(m_opacityTable.get()); m_startedImageLoading = 2; } diff --git a/src/particles/qquickmaskextruder.cpp b/src/particles/qquickmaskextruder.cpp index 2ce3650743..61f9092f0a 100644 --- a/src/particles/qquickmaskextruder.cpp +++ b/src/particles/qquickmaskextruder.cpp @@ -40,9 +40,12 @@ #include "qquickmaskextruder_p.h" #include <QtQml/qqml.h> #include <QtQml/qqmlinfo.h> +#include <QtQml/qqmlcontext.h> + #include <QImage> #include <QDebug> #include <QRandomGenerator> + QT_BEGIN_NAMESPACE /*! \qmltype MaskShape @@ -85,7 +88,8 @@ void QQuickMaskExtruder::startMaskLoading() m_pix.clear(this); if (m_source.isEmpty()) return; - m_pix.load(qmlEngine(this), m_source); + const QQmlContext *context = qmlContext(this); + m_pix.load(context->engine(), context->resolvedUrl(m_source)); if (m_pix.isLoading()) m_pix.connectFinished(this, SLOT(finishMaskLoading())); else |