| Absolute File Name: | /home/opencoverage/opencoverage/guest-scripts/qtdeclarative/src/qtdeclarative/src/quick/items/qquickpainteditem.cpp |
| Source code | Switch to Preprocessed file |
| Line | Source | Count | ||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | /**************************************************************************** | - | ||||||||||||||||||
| 2 | ** | - | ||||||||||||||||||
| 3 | ** Copyright (C) 2016 The Qt Company Ltd. | - | ||||||||||||||||||
| 4 | ** Contact: https://www.qt.io/licensing/ | - | ||||||||||||||||||
| 5 | ** | - | ||||||||||||||||||
| 6 | ** This file is part of the QtQuick module of the Qt Toolkit. | - | ||||||||||||||||||
| 7 | ** | - | ||||||||||||||||||
| 8 | ** $QT_BEGIN_LICENSE:LGPL$ | - | ||||||||||||||||||
| 9 | ** Commercial License Usage | - | ||||||||||||||||||
| 10 | ** Licensees holding valid commercial Qt licenses may use this file in | - | ||||||||||||||||||
| 11 | ** accordance with the commercial license agreement provided with the | - | ||||||||||||||||||
| 12 | ** Software or, alternatively, in accordance with the terms contained in | - | ||||||||||||||||||
| 13 | ** a written agreement between you and The Qt Company. For licensing terms | - | ||||||||||||||||||
| 14 | ** and conditions see https://www.qt.io/terms-conditions. For further | - | ||||||||||||||||||
| 15 | ** information use the contact form at https://www.qt.io/contact-us. | - | ||||||||||||||||||
| 16 | ** | - | ||||||||||||||||||
| 17 | ** GNU Lesser General Public License Usage | - | ||||||||||||||||||
| 18 | ** Alternatively, this file may be used under the terms of the GNU Lesser | - | ||||||||||||||||||
| 19 | ** General Public License version 3 as published by the Free Software | - | ||||||||||||||||||
| 20 | ** Foundation and appearing in the file LICENSE.LGPL3 included in the | - | ||||||||||||||||||
| 21 | ** packaging of this file. Please review the following information to | - | ||||||||||||||||||
| 22 | ** ensure the GNU Lesser General Public License version 3 requirements | - | ||||||||||||||||||
| 23 | ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. | - | ||||||||||||||||||
| 24 | ** | - | ||||||||||||||||||
| 25 | ** GNU General Public License Usage | - | ||||||||||||||||||
| 26 | ** Alternatively, this file may be used under the terms of the GNU | - | ||||||||||||||||||
| 27 | ** General Public License version 2.0 or (at your option) the GNU General | - | ||||||||||||||||||
| 28 | ** Public license version 3 or any later version approved by the KDE Free | - | ||||||||||||||||||
| 29 | ** Qt Foundation. The licenses are as published by the Free Software | - | ||||||||||||||||||
| 30 | ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 | - | ||||||||||||||||||
| 31 | ** included in the packaging of this file. Please review the following | - | ||||||||||||||||||
| 32 | ** information to ensure the GNU General Public License requirements will | - | ||||||||||||||||||
| 33 | ** be met: https://www.gnu.org/licenses/gpl-2.0.html and | - | ||||||||||||||||||
| 34 | ** https://www.gnu.org/licenses/gpl-3.0.html. | - | ||||||||||||||||||
| 35 | ** | - | ||||||||||||||||||
| 36 | ** $QT_END_LICENSE$ | - | ||||||||||||||||||
| 37 | ** | - | ||||||||||||||||||
| 38 | ****************************************************************************/ | - | ||||||||||||||||||
| 39 | - | |||||||||||||||||||
| 40 | #include "qquickpainteditem.h" | - | ||||||||||||||||||
| 41 | #include <private/qquickpainteditem_p.h> | - | ||||||||||||||||||
| 42 | - | |||||||||||||||||||
| 43 | #include <QtQuick/private/qsgdefaultpainternode_p.h> | - | ||||||||||||||||||
| 44 | #include <QtQuick/private/qsgcontext_p.h> | - | ||||||||||||||||||
| 45 | #include <private/qsgadaptationlayer_p.h> | - | ||||||||||||||||||
| 46 | #include <qsgtextureprovider.h> | - | ||||||||||||||||||
| 47 | - | |||||||||||||||||||
| 48 | #include <qmath.h> | - | ||||||||||||||||||
| 49 | - | |||||||||||||||||||
| 50 | QT_BEGIN_NAMESPACE | - | ||||||||||||||||||
| 51 | - | |||||||||||||||||||
| 52 | class QQuickPaintedItemTextureProvider : public QSGTextureProvider | - | ||||||||||||||||||
| 53 | { | - | ||||||||||||||||||
| 54 | public: | - | ||||||||||||||||||
| 55 | QSGPainterNode *node; | - | ||||||||||||||||||
| 56 | QSGTexture *texture() const override { return node ? node->texture() : nullptr; } never executed: return node ? node->texture() : nullptr; | 0 | ||||||||||||||||||
| 57 | void fireTextureChanged() { emit textureChanged(); } never executed: end of block | 0 | ||||||||||||||||||
| 58 | }; | - | ||||||||||||||||||
| 59 | - | |||||||||||||||||||
| 60 | /*! | - | ||||||||||||||||||
| 61 | \class QQuickPaintedItem | - | ||||||||||||||||||
| 62 | \brief The QQuickPaintedItem class provides a way to use the QPainter API in the | - | ||||||||||||||||||
| 63 | QML Scene Graph. | - | ||||||||||||||||||
| 64 | - | |||||||||||||||||||
| 65 | \inmodule QtQuick | - | ||||||||||||||||||
| 66 | - | |||||||||||||||||||
| 67 | The QQuickPaintedItem makes it possible to use the QPainter API with the | - | ||||||||||||||||||
| 68 | QML Scene Graph. It sets up a textured rectangle in the Scene Graph and | - | ||||||||||||||||||
| 69 | uses a QPainter to paint onto the texture. The render target can be either | - | ||||||||||||||||||
| 70 | a QImage or, when OpenGL is in use, a QOpenGLFramebufferObject. When the | - | ||||||||||||||||||
| 71 | render target is a QImage, QPainter first renders into the image then the | - | ||||||||||||||||||
| 72 | content is uploaded to the texture. When a QOpenGLFramebufferObject is | - | ||||||||||||||||||
| 73 | used, QPainter paints directly onto the texture. Call update() to trigger a | - | ||||||||||||||||||
| 74 | repaint. | - | ||||||||||||||||||
| 75 | - | |||||||||||||||||||
| 76 | To enable QPainter to do anti-aliased rendering, use setAntialiasing(). | - | ||||||||||||||||||
| 77 | - | |||||||||||||||||||
| 78 | To write your own painted item, you first create a subclass of | - | ||||||||||||||||||
| 79 | QQuickPaintedItem, and then start by implementing its only pure virtual | - | ||||||||||||||||||
| 80 | public function: paint(), which implements the actual painting. The | - | ||||||||||||||||||
| 81 | painting will be inside the rectangle spanning from 0,0 to | - | ||||||||||||||||||
| 82 | width(),height(). | - | ||||||||||||||||||
| 83 | - | |||||||||||||||||||
| 84 | \note It important to understand the performance implications such items | - | ||||||||||||||||||
| 85 | can incur. See QQuickPaintedItem::RenderTarget and | - | ||||||||||||||||||
| 86 | QQuickPaintedItem::renderTarget. | - | ||||||||||||||||||
| 87 | */ | - | ||||||||||||||||||
| 88 | - | |||||||||||||||||||
| 89 | /*! | - | ||||||||||||||||||
| 90 | \enum QQuickPaintedItem::RenderTarget | - | ||||||||||||||||||
| 91 | - | |||||||||||||||||||
| 92 | This enum describes QQuickPaintedItem's render targets. The render target is the | - | ||||||||||||||||||
| 93 | surface QPainter paints onto before the item is rendered on screen. | - | ||||||||||||||||||
| 94 | - | |||||||||||||||||||
| 95 | \value Image The default; QPainter paints into a QImage using the raster paint engine. | - | ||||||||||||||||||
| 96 | The image's content needs to be uploaded to graphics memory afterward, this operation | - | ||||||||||||||||||
| 97 | can potentially be slow if the item is large. This render target allows high quality | - | ||||||||||||||||||
| 98 | anti-aliasing and fast item resizing. | - | ||||||||||||||||||
| 99 | - | |||||||||||||||||||
| 100 | \value FramebufferObject QPainter paints into a QOpenGLFramebufferObject using the GL | - | ||||||||||||||||||
| 101 | paint engine. Painting can be faster as no texture upload is required, but anti-aliasing | - | ||||||||||||||||||
| 102 | quality is not as good as if using an image. This render target allows faster rendering | - | ||||||||||||||||||
| 103 | in some cases, but you should avoid using it if the item is resized often. | - | ||||||||||||||||||
| 104 | - | |||||||||||||||||||
| 105 | \value InvertedYFramebufferObject Exactly as for FramebufferObject above, except once | - | ||||||||||||||||||
| 106 | the painting is done, prior to rendering the painted image is flipped about the | - | ||||||||||||||||||
| 107 | x-axis so that the top-most pixels are now at the bottom. Since this is done with the | - | ||||||||||||||||||
| 108 | OpenGL texture coordinates it is a much faster way to achieve this effect than using a | - | ||||||||||||||||||
| 109 | painter transform. | - | ||||||||||||||||||
| 110 | - | |||||||||||||||||||
| 111 | \sa setRenderTarget() | - | ||||||||||||||||||
| 112 | */ | - | ||||||||||||||||||
| 113 | - | |||||||||||||||||||
| 114 | /*! | - | ||||||||||||||||||
| 115 | \enum QQuickPaintedItem::PerformanceHint | - | ||||||||||||||||||
| 116 | - | |||||||||||||||||||
| 117 | This enum describes flags that you can enable to improve rendering | - | ||||||||||||||||||
| 118 | performance in QQuickPaintedItem. By default, none of these flags are set. | - | ||||||||||||||||||
| 119 | - | |||||||||||||||||||
| 120 | \value FastFBOResizing Resizing an FBO can be a costly operation on a few | - | ||||||||||||||||||
| 121 | OpenGL driver implementations. To work around this, one can set this flag | - | ||||||||||||||||||
| 122 | to let the QQuickPaintedItem allocate one large framebuffer object and | - | ||||||||||||||||||
| 123 | instead draw into a subregion of it. This saves the resize at the cost of | - | ||||||||||||||||||
| 124 | using more memory. Please note that this is not a common problem. | - | ||||||||||||||||||
| 125 | - | |||||||||||||||||||
| 126 | */ | - | ||||||||||||||||||
| 127 | - | |||||||||||||||||||
| 128 | /*! | - | ||||||||||||||||||
| 129 | \internal | - | ||||||||||||||||||
| 130 | */ | - | ||||||||||||||||||
| 131 | QQuickPaintedItemPrivate::QQuickPaintedItemPrivate() | - | ||||||||||||||||||
| 132 | : QQuickItemPrivate() | - | ||||||||||||||||||
| 133 | , contentsScale(1.0) | - | ||||||||||||||||||
| 134 | , fillColor(Qt::transparent) | - | ||||||||||||||||||
| 135 | , renderTarget(QQuickPaintedItem::Image) | - | ||||||||||||||||||
| 136 | , performanceHints(nullptr) | - | ||||||||||||||||||
| 137 | , opaquePainting(false) | - | ||||||||||||||||||
| 138 | , antialiasing(false) | - | ||||||||||||||||||
| 139 | , mipmap(false) | - | ||||||||||||||||||
| 140 | , textureProvider(nullptr) | - | ||||||||||||||||||
| 141 | , node(nullptr) | - | ||||||||||||||||||
| 142 | { | - | ||||||||||||||||||
| 143 | } executed 20 times by 1 test: end of blockExecuted by:
| 20 | ||||||||||||||||||
| 144 | - | |||||||||||||||||||
| 145 | /*! | - | ||||||||||||||||||
| 146 | Constructs a QQuickPaintedItem with the given \a parent item. | - | ||||||||||||||||||
| 147 | */ | - | ||||||||||||||||||
| 148 | QQuickPaintedItem::QQuickPaintedItem(QQuickItem *parent) | - | ||||||||||||||||||
| 149 | : QQuickItem(*(new QQuickPaintedItemPrivate), parent) | - | ||||||||||||||||||
| 150 | { | - | ||||||||||||||||||
| 151 | setFlag(ItemHasContents); | - | ||||||||||||||||||
| 152 | } executed 20 times by 1 test: end of blockExecuted by:
| 20 | ||||||||||||||||||
| 153 | - | |||||||||||||||||||
| 154 | /*! | - | ||||||||||||||||||
| 155 | \internal | - | ||||||||||||||||||
| 156 | */ | - | ||||||||||||||||||
| 157 | QQuickPaintedItem::QQuickPaintedItem(QQuickPaintedItemPrivate &dd, QQuickItem *parent) | - | ||||||||||||||||||
| 158 | : QQuickItem(dd, parent) | - | ||||||||||||||||||
| 159 | { | - | ||||||||||||||||||
| 160 | setFlag(ItemHasContents); | - | ||||||||||||||||||
| 161 | } never executed: end of block | 0 | ||||||||||||||||||
| 162 | - | |||||||||||||||||||
| 163 | /*! | - | ||||||||||||||||||
| 164 | Destroys the QQuickPaintedItem. | - | ||||||||||||||||||
| 165 | */ | - | ||||||||||||||||||
| 166 | QQuickPaintedItem::~QQuickPaintedItem() | - | ||||||||||||||||||
| 167 | { | - | ||||||||||||||||||
| 168 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 169 | if (d->textureProvider)
| 0-20 | ||||||||||||||||||
| 170 | QQuickWindowQObjectCleanupJob::schedule(window(), d->textureProvider); never executed: QQuickWindowQObjectCleanupJob::schedule(window(), d->textureProvider); | 0 | ||||||||||||||||||
| 171 | } executed 20 times by 1 test: end of blockExecuted by:
| 20 | ||||||||||||||||||
| 172 | - | |||||||||||||||||||
| 173 | /*! | - | ||||||||||||||||||
| 174 | Schedules a redraw of the area covered by \a rect in this item. You can call this function | - | ||||||||||||||||||
| 175 | whenever your item needs to be redrawn, such as if it changes appearance or size. | - | ||||||||||||||||||
| 176 | - | |||||||||||||||||||
| 177 | This function does not cause an immediate paint; instead it schedules a paint request that | - | ||||||||||||||||||
| 178 | is processed by the QML Scene Graph when the next frame is rendered. The item will only be | - | ||||||||||||||||||
| 179 | redrawn if it is visible. | - | ||||||||||||||||||
| 180 | - | |||||||||||||||||||
| 181 | \sa paint() | - | ||||||||||||||||||
| 182 | */ | - | ||||||||||||||||||
| 183 | void QQuickPaintedItem::update(const QRect &rect) | - | ||||||||||||||||||
| 184 | { | - | ||||||||||||||||||
| 185 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 186 | - | |||||||||||||||||||
| 187 | if (rect.isNull() && !d->dirtyRect.isNull())
| 0-52 | ||||||||||||||||||
| 188 | d->dirtyRect = contentsBoundingRect().toAlignedRect(); never executed: d->dirtyRect = contentsBoundingRect().toAlignedRect(); | 0 | ||||||||||||||||||
| 189 | else | - | ||||||||||||||||||
| 190 | d->dirtyRect |= (contentsBoundingRect() & rect).toAlignedRect(); executed 58 times by 1 test: d->dirtyRect |= (contentsBoundingRect() & rect).toAlignedRect();Executed by:
| 58 | ||||||||||||||||||
| 191 | QQuickItem::update(); | - | ||||||||||||||||||
| 192 | } executed 58 times by 1 test: end of blockExecuted by:
| 58 | ||||||||||||||||||
| 193 | - | |||||||||||||||||||
| 194 | /*! | - | ||||||||||||||||||
| 195 | Returns true if this item is opaque; otherwise, false is returned. | - | ||||||||||||||||||
| 196 | - | |||||||||||||||||||
| 197 | By default, painted items are not opaque. | - | ||||||||||||||||||
| 198 | - | |||||||||||||||||||
| 199 | \sa setOpaquePainting() | - | ||||||||||||||||||
| 200 | */ | - | ||||||||||||||||||
| 201 | bool QQuickPaintedItem::opaquePainting() const | - | ||||||||||||||||||
| 202 | { | - | ||||||||||||||||||
| 203 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 204 | return d->opaquePainting; executed 10 times by 1 test: return d->opaquePainting;Executed by:
| 10 | ||||||||||||||||||
| 205 | } | - | ||||||||||||||||||
| 206 | - | |||||||||||||||||||
| 207 | /*! | - | ||||||||||||||||||
| 208 | If \a opaque is true, the item is opaque; otherwise, it is considered as translucent. | - | ||||||||||||||||||
| 209 | - | |||||||||||||||||||
| 210 | Opaque items are not blended with the rest of the scene, you should set this to true | - | ||||||||||||||||||
| 211 | if the content of the item is opaque to speed up rendering. | - | ||||||||||||||||||
| 212 | - | |||||||||||||||||||
| 213 | By default, painted items are not opaque. | - | ||||||||||||||||||
| 214 | - | |||||||||||||||||||
| 215 | \sa opaquePainting() | - | ||||||||||||||||||
| 216 | */ | - | ||||||||||||||||||
| 217 | void QQuickPaintedItem::setOpaquePainting(bool opaque) | - | ||||||||||||||||||
| 218 | { | - | ||||||||||||||||||
| 219 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 220 | - | |||||||||||||||||||
| 221 | if (d->opaquePainting == opaque)
| 4 | ||||||||||||||||||
| 222 | return; executed 4 times by 1 test: return;Executed by:
| 4 | ||||||||||||||||||
| 223 | - | |||||||||||||||||||
| 224 | d->opaquePainting = opaque; | - | ||||||||||||||||||
| 225 | QQuickItem::update(); | - | ||||||||||||||||||
| 226 | } executed 4 times by 1 test: end of blockExecuted by:
| 4 | ||||||||||||||||||
| 227 | - | |||||||||||||||||||
| 228 | /*! | - | ||||||||||||||||||
| 229 | Returns true if antialiased painting is enabled; otherwise, false is returned. | - | ||||||||||||||||||
| 230 | - | |||||||||||||||||||
| 231 | By default, antialiasing is not enabled. | - | ||||||||||||||||||
| 232 | - | |||||||||||||||||||
| 233 | \sa setAntialiasing() | - | ||||||||||||||||||
| 234 | */ | - | ||||||||||||||||||
| 235 | bool QQuickPaintedItem::antialiasing() const | - | ||||||||||||||||||
| 236 | { | - | ||||||||||||||||||
| 237 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 238 | return d->antialiasing; executed 10 times by 1 test: return d->antialiasing;Executed by:
| 10 | ||||||||||||||||||
| 239 | } | - | ||||||||||||||||||
| 240 | - | |||||||||||||||||||
| 241 | /*! | - | ||||||||||||||||||
| 242 | If \a enable is true, antialiased painting is enabled. | - | ||||||||||||||||||
| 243 | - | |||||||||||||||||||
| 244 | By default, antialiasing is not enabled. | - | ||||||||||||||||||
| 245 | - | |||||||||||||||||||
| 246 | \sa antialiasing() | - | ||||||||||||||||||
| 247 | */ | - | ||||||||||||||||||
| 248 | void QQuickPaintedItem::setAntialiasing(bool enable) | - | ||||||||||||||||||
| 249 | { | - | ||||||||||||||||||
| 250 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 251 | - | |||||||||||||||||||
| 252 | if (d->antialiasing == enable)
| 4 | ||||||||||||||||||
| 253 | return; executed 4 times by 1 test: return;Executed by:
| 4 | ||||||||||||||||||
| 254 | - | |||||||||||||||||||
| 255 | d->antialiasing = enable; | - | ||||||||||||||||||
| 256 | update(); | - | ||||||||||||||||||
| 257 | } executed 4 times by 1 test: end of blockExecuted by:
| 4 | ||||||||||||||||||
| 258 | - | |||||||||||||||||||
| 259 | /*! | - | ||||||||||||||||||
| 260 | Returns true if mipmaps are enabled; otherwise, false is returned. | - | ||||||||||||||||||
| 261 | - | |||||||||||||||||||
| 262 | By default, mipmapping is not enabled. | - | ||||||||||||||||||
| 263 | - | |||||||||||||||||||
| 264 | \sa setMipmap() | - | ||||||||||||||||||
| 265 | */ | - | ||||||||||||||||||
| 266 | bool QQuickPaintedItem::mipmap() const | - | ||||||||||||||||||
| 267 | { | - | ||||||||||||||||||
| 268 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 269 | return d->mipmap; executed 10 times by 1 test: return d->mipmap;Executed by:
| 10 | ||||||||||||||||||
| 270 | } | - | ||||||||||||||||||
| 271 | - | |||||||||||||||||||
| 272 | /*! | - | ||||||||||||||||||
| 273 | If \a enable is true, mipmapping is enabled on the associated texture. | - | ||||||||||||||||||
| 274 | - | |||||||||||||||||||
| 275 | Mipmapping increases rendering speed and reduces aliasing artifacts when the item is | - | ||||||||||||||||||
| 276 | scaled down. | - | ||||||||||||||||||
| 277 | - | |||||||||||||||||||
| 278 | By default, mipmapping is not enabled. | - | ||||||||||||||||||
| 279 | - | |||||||||||||||||||
| 280 | \sa mipmap() | - | ||||||||||||||||||
| 281 | */ | - | ||||||||||||||||||
| 282 | void QQuickPaintedItem::setMipmap(bool enable) | - | ||||||||||||||||||
| 283 | { | - | ||||||||||||||||||
| 284 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 285 | - | |||||||||||||||||||
| 286 | if (d->mipmap == enable)
| 4 | ||||||||||||||||||
| 287 | return; executed 4 times by 1 test: return;Executed by:
| 4 | ||||||||||||||||||
| 288 | - | |||||||||||||||||||
| 289 | d->mipmap = enable; | - | ||||||||||||||||||
| 290 | update(); | - | ||||||||||||||||||
| 291 | } executed 4 times by 1 test: end of blockExecuted by:
| 4 | ||||||||||||||||||
| 292 | - | |||||||||||||||||||
| 293 | /*! | - | ||||||||||||||||||
| 294 | Returns the performance hints. | - | ||||||||||||||||||
| 295 | - | |||||||||||||||||||
| 296 | By default, no performance hint is enabled. | - | ||||||||||||||||||
| 297 | - | |||||||||||||||||||
| 298 | \sa setPerformanceHint(), setPerformanceHints() | - | ||||||||||||||||||
| 299 | */ | - | ||||||||||||||||||
| 300 | QQuickPaintedItem::PerformanceHints QQuickPaintedItem::performanceHints() const | - | ||||||||||||||||||
| 301 | { | - | ||||||||||||||||||
| 302 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 303 | return d->performanceHints; executed 10 times by 1 test: return d->performanceHints;Executed by:
| 10 | ||||||||||||||||||
| 304 | } | - | ||||||||||||||||||
| 305 | - | |||||||||||||||||||
| 306 | /*! | - | ||||||||||||||||||
| 307 | Sets the given performance \a hint on the item if \a enabled is true; | - | ||||||||||||||||||
| 308 | otherwise clears the performance hint. | - | ||||||||||||||||||
| 309 | - | |||||||||||||||||||
| 310 | By default, no performance hint is enabled/ | - | ||||||||||||||||||
| 311 | - | |||||||||||||||||||
| 312 | \sa setPerformanceHints(), performanceHints() | - | ||||||||||||||||||
| 313 | */ | - | ||||||||||||||||||
| 314 | void QQuickPaintedItem::setPerformanceHint(QQuickPaintedItem::PerformanceHint hint, bool enabled) | - | ||||||||||||||||||
| 315 | { | - | ||||||||||||||||||
| 316 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 317 | PerformanceHints oldHints = d->performanceHints; | - | ||||||||||||||||||
| 318 | if (enabled)
| 2 | ||||||||||||||||||
| 319 | d->performanceHints |= hint; executed 2 times by 1 test: d->performanceHints |= hint;Executed by:
| 2 | ||||||||||||||||||
| 320 | else | - | ||||||||||||||||||
| 321 | d->performanceHints &= ~hint; executed 2 times by 1 test: d->performanceHints &= ~hint;Executed by:
| 2 | ||||||||||||||||||
| 322 | if (oldHints != d->performanceHints)
| 2 | ||||||||||||||||||
| 323 | update(); executed 2 times by 1 test: update();Executed by:
| 2 | ||||||||||||||||||
| 324 | } executed 4 times by 1 test: end of blockExecuted by:
| 4 | ||||||||||||||||||
| 325 | - | |||||||||||||||||||
| 326 | /*! | - | ||||||||||||||||||
| 327 | Sets the performance hints to \a hints | - | ||||||||||||||||||
| 328 | - | |||||||||||||||||||
| 329 | By default, no performance hint is enabled/ | - | ||||||||||||||||||
| 330 | - | |||||||||||||||||||
| 331 | \sa setPerformanceHint(), performanceHints() | - | ||||||||||||||||||
| 332 | */ | - | ||||||||||||||||||
| 333 | void QQuickPaintedItem::setPerformanceHints(QQuickPaintedItem::PerformanceHints hints) | - | ||||||||||||||||||
| 334 | { | - | ||||||||||||||||||
| 335 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 336 | if (d->performanceHints == hints)
| 2 | ||||||||||||||||||
| 337 | return; executed 2 times by 1 test: return;Executed by:
| 2 | ||||||||||||||||||
| 338 | d->performanceHints = hints; | - | ||||||||||||||||||
| 339 | update(); | - | ||||||||||||||||||
| 340 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||
| 341 | - | |||||||||||||||||||
| 342 | QSize QQuickPaintedItem::textureSize() const | - | ||||||||||||||||||
| 343 | { | - | ||||||||||||||||||
| 344 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 345 | return d->textureSize; never executed: return d->textureSize; | 0 | ||||||||||||||||||
| 346 | } | - | ||||||||||||||||||
| 347 | - | |||||||||||||||||||
| 348 | /*! | - | ||||||||||||||||||
| 349 | \property QQuickPaintedItem::textureSize | - | ||||||||||||||||||
| 350 | - | |||||||||||||||||||
| 351 | \brief Defines the size of the texture. | - | ||||||||||||||||||
| 352 | - | |||||||||||||||||||
| 353 | Changing the texture's size does not affect the coordinate system used in | - | ||||||||||||||||||
| 354 | paint(). A scale factor is instead applied so painting should still happen | - | ||||||||||||||||||
| 355 | inside 0,0 to width(),height(). | - | ||||||||||||||||||
| 356 | - | |||||||||||||||||||
| 357 | By default, the texture size will have the same size as this item. | - | ||||||||||||||||||
| 358 | - | |||||||||||||||||||
| 359 | \note If the item is on a window with a device pixel ratio different from | - | ||||||||||||||||||
| 360 | 1, this scale factor will be implicitly applied to the texture size. | - | ||||||||||||||||||
| 361 | - | |||||||||||||||||||
| 362 | */ | - | ||||||||||||||||||
| 363 | void QQuickPaintedItem::setTextureSize(const QSize &size) | - | ||||||||||||||||||
| 364 | { | - | ||||||||||||||||||
| 365 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 366 | if (d->textureSize == size)
| 0 | ||||||||||||||||||
| 367 | return; never executed: return; | 0 | ||||||||||||||||||
| 368 | d->textureSize = size; | - | ||||||||||||||||||
| 369 | emit textureSizeChanged(); | - | ||||||||||||||||||
| 370 | } never executed: end of block | 0 | ||||||||||||||||||
| 371 | - | |||||||||||||||||||
| 372 | #if QT_VERSION >= 0x060000 | - | ||||||||||||||||||
| 373 | #warning "Remove: QQuickPaintedItem::contentsBoundingRect, contentsScale, contentsSize. Also remove them from qsgadaptationlayer_p.h and qsgdefaultpainternode.h/cpp." | - | ||||||||||||||||||
| 374 | #endif | - | ||||||||||||||||||
| 375 | - | |||||||||||||||||||
| 376 | /*! | - | ||||||||||||||||||
| 377 | \obsolete | - | ||||||||||||||||||
| 378 | - | |||||||||||||||||||
| 379 | This function is provided for compatibility, use size in combination | - | ||||||||||||||||||
| 380 | with textureSize to decide the size of what you are drawing. | - | ||||||||||||||||||
| 381 | - | |||||||||||||||||||
| 382 | \sa width(), height(), textureSize() | - | ||||||||||||||||||
| 383 | */ | - | ||||||||||||||||||
| 384 | QRectF QQuickPaintedItem::contentsBoundingRect() const | - | ||||||||||||||||||
| 385 | { | - | ||||||||||||||||||
| 386 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 387 | - | |||||||||||||||||||
| 388 | qreal w = d->width; | - | ||||||||||||||||||
| 389 | QSizeF sz = d->contentsSize * d->contentsScale; | - | ||||||||||||||||||
| 390 | if (w < sz.width())
| 8-72 | ||||||||||||||||||
| 391 | w = sz.width(); executed 8 times by 1 test: w = sz.width();Executed by:
| 8 | ||||||||||||||||||
| 392 | qreal h = d->height; | - | ||||||||||||||||||
| 393 | if (h < sz.height())
| 20-60 | ||||||||||||||||||
| 394 | h = sz.height(); executed 20 times by 1 test: h = sz.height();Executed by:
| 20 | ||||||||||||||||||
| 395 | - | |||||||||||||||||||
| 396 | return QRectF(0, 0, w, h); executed 80 times by 1 test: return QRectF(0, 0, w, h);Executed by:
| 80 | ||||||||||||||||||
| 397 | } | - | ||||||||||||||||||
| 398 | - | |||||||||||||||||||
| 399 | /*! | - | ||||||||||||||||||
| 400 | \property QQuickPaintedItem::contentsSize | - | ||||||||||||||||||
| 401 | \brief Obsolete method for setting the contents size. | - | ||||||||||||||||||
| 402 | \obsolete | - | ||||||||||||||||||
| 403 | - | |||||||||||||||||||
| 404 | This function is provided for compatibility, use size in combination | - | ||||||||||||||||||
| 405 | with textureSize to decide the size of what you are drawing. | - | ||||||||||||||||||
| 406 | - | |||||||||||||||||||
| 407 | \sa width(), height(), textureSize() | - | ||||||||||||||||||
| 408 | */ | - | ||||||||||||||||||
| 409 | QSize QQuickPaintedItem::contentsSize() const | - | ||||||||||||||||||
| 410 | { | - | ||||||||||||||||||
| 411 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 412 | return d->contentsSize; executed 10 times by 1 test: return d->contentsSize;Executed by:
| 10 | ||||||||||||||||||
| 413 | } | - | ||||||||||||||||||
| 414 | - | |||||||||||||||||||
| 415 | void QQuickPaintedItem::setContentsSize(const QSize &size) | - | ||||||||||||||||||
| 416 | { | - | ||||||||||||||||||
| 417 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 418 | - | |||||||||||||||||||
| 419 | if (d->contentsSize == size)
| 4-8 | ||||||||||||||||||
| 420 | return; executed 4 times by 1 test: return;Executed by:
| 4 | ||||||||||||||||||
| 421 | - | |||||||||||||||||||
| 422 | d->contentsSize = size; | - | ||||||||||||||||||
| 423 | update(); | - | ||||||||||||||||||
| 424 | - | |||||||||||||||||||
| 425 | emit contentsSizeChanged(); | - | ||||||||||||||||||
| 426 | } executed 8 times by 1 test: end of blockExecuted by:
| 8 | ||||||||||||||||||
| 427 | - | |||||||||||||||||||
| 428 | /*! | - | ||||||||||||||||||
| 429 | \obsolete | - | ||||||||||||||||||
| 430 | This convenience function is equivalent to calling setContentsSize(QSize()). | - | ||||||||||||||||||
| 431 | */ | - | ||||||||||||||||||
| 432 | void QQuickPaintedItem::resetContentsSize() | - | ||||||||||||||||||
| 433 | { | - | ||||||||||||||||||
| 434 | setContentsSize(QSize()); | - | ||||||||||||||||||
| 435 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||
| 436 | - | |||||||||||||||||||
| 437 | /*! | - | ||||||||||||||||||
| 438 | \property QQuickPaintedItem::contentsScale | - | ||||||||||||||||||
| 439 | \brief Obsolete method for scaling the contents. | - | ||||||||||||||||||
| 440 | \obsolete | - | ||||||||||||||||||
| 441 | - | |||||||||||||||||||
| 442 | This function is provided for compatibility, use size() in combination | - | ||||||||||||||||||
| 443 | with textureSize() to decide the size of what you are drawing. | - | ||||||||||||||||||
| 444 | - | |||||||||||||||||||
| 445 | \sa width(), height(), textureSize() | - | ||||||||||||||||||
| 446 | */ | - | ||||||||||||||||||
| 447 | qreal QQuickPaintedItem::contentsScale() const | - | ||||||||||||||||||
| 448 | { | - | ||||||||||||||||||
| 449 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 450 | return d->contentsScale; executed 10 times by 1 test: return d->contentsScale;Executed by:
| 10 | ||||||||||||||||||
| 451 | } | - | ||||||||||||||||||
| 452 | - | |||||||||||||||||||
| 453 | void QQuickPaintedItem::setContentsScale(qreal scale) | - | ||||||||||||||||||
| 454 | { | - | ||||||||||||||||||
| 455 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 456 | - | |||||||||||||||||||
| 457 | if (d->contentsScale == scale)
| 4-8 | ||||||||||||||||||
| 458 | return; executed 4 times by 1 test: return;Executed by:
| 4 | ||||||||||||||||||
| 459 | - | |||||||||||||||||||
| 460 | d->contentsScale = scale; | - | ||||||||||||||||||
| 461 | update(); | - | ||||||||||||||||||
| 462 | - | |||||||||||||||||||
| 463 | emit contentsScaleChanged(); | - | ||||||||||||||||||
| 464 | } executed 8 times by 1 test: end of blockExecuted by:
| 8 | ||||||||||||||||||
| 465 | - | |||||||||||||||||||
| 466 | /*! | - | ||||||||||||||||||
| 467 | \property QQuickPaintedItem::fillColor | - | ||||||||||||||||||
| 468 | \brief The item's background fill color. | - | ||||||||||||||||||
| 469 | - | |||||||||||||||||||
| 470 | By default, the fill color is set to Qt::transparent. | - | ||||||||||||||||||
| 471 | */ | - | ||||||||||||||||||
| 472 | QColor QQuickPaintedItem::fillColor() const | - | ||||||||||||||||||
| 473 | { | - | ||||||||||||||||||
| 474 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 475 | return d->fillColor; executed 10 times by 1 test: return d->fillColor;Executed by:
| 10 | ||||||||||||||||||
| 476 | } | - | ||||||||||||||||||
| 477 | - | |||||||||||||||||||
| 478 | void QQuickPaintedItem::setFillColor(const QColor &c) | - | ||||||||||||||||||
| 479 | { | - | ||||||||||||||||||
| 480 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 481 | - | |||||||||||||||||||
| 482 | if (d->fillColor == c)
| 4 | ||||||||||||||||||
| 483 | return; executed 4 times by 1 test: return;Executed by:
| 4 | ||||||||||||||||||
| 484 | - | |||||||||||||||||||
| 485 | d->fillColor = c; | - | ||||||||||||||||||
| 486 | update(); | - | ||||||||||||||||||
| 487 | - | |||||||||||||||||||
| 488 | emit fillColorChanged(); | - | ||||||||||||||||||
| 489 | } executed 4 times by 1 test: end of blockExecuted by:
| 4 | ||||||||||||||||||
| 490 | - | |||||||||||||||||||
| 491 | /*! | - | ||||||||||||||||||
| 492 | \property QQuickPaintedItem::renderTarget | - | ||||||||||||||||||
| 493 | \brief The item's render target. | - | ||||||||||||||||||
| 494 | - | |||||||||||||||||||
| 495 | This property defines which render target the QPainter renders into, it can be either | - | ||||||||||||||||||
| 496 | QQuickPaintedItem::Image, QQuickPaintedItem::FramebufferObject or QQuickPaintedItem::InvertedYFramebufferObject. | - | ||||||||||||||||||
| 497 | - | |||||||||||||||||||
| 498 | Each has certain benefits, typically performance versus quality. Using a framebuffer | - | ||||||||||||||||||
| 499 | object avoids a costly upload of the image contents to the texture in graphics memory, | - | ||||||||||||||||||
| 500 | while using an image enables high quality anti-aliasing. | - | ||||||||||||||||||
| 501 | - | |||||||||||||||||||
| 502 | \warning Resizing a framebuffer object is a costly operation, avoid using | - | ||||||||||||||||||
| 503 | the QQuickPaintedItem::FramebufferObject render target if the item gets resized often. | - | ||||||||||||||||||
| 504 | - | |||||||||||||||||||
| 505 | By default, the render target is QQuickPaintedItem::Image. | - | ||||||||||||||||||
| 506 | - | |||||||||||||||||||
| 507 | \note Some Qt Quick backends may not support all render target options. For | - | ||||||||||||||||||
| 508 | example, it is likely that non-OpenGL backends will lack support for | - | ||||||||||||||||||
| 509 | QQuickPaintedItem::FramebufferObject and | - | ||||||||||||||||||
| 510 | QQuickPaintedItem::InvertedYFramebufferObject. Requesting these will then | - | ||||||||||||||||||
| 511 | be ignored. | - | ||||||||||||||||||
| 512 | */ | - | ||||||||||||||||||
| 513 | QQuickPaintedItem::RenderTarget QQuickPaintedItem::renderTarget() const | - | ||||||||||||||||||
| 514 | { | - | ||||||||||||||||||
| 515 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 516 | return d->renderTarget; executed 10 times by 1 test: return d->renderTarget;Executed by:
| 10 | ||||||||||||||||||
| 517 | } | - | ||||||||||||||||||
| 518 | - | |||||||||||||||||||
| 519 | void QQuickPaintedItem::setRenderTarget(RenderTarget target) | - | ||||||||||||||||||
| 520 | { | - | ||||||||||||||||||
| 521 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 522 | - | |||||||||||||||||||
| 523 | if (d->renderTarget == target)
| 4 | ||||||||||||||||||
| 524 | return; executed 4 times by 1 test: return;Executed by:
| 4 | ||||||||||||||||||
| 525 | - | |||||||||||||||||||
| 526 | d->renderTarget = target; | - | ||||||||||||||||||
| 527 | update(); | - | ||||||||||||||||||
| 528 | - | |||||||||||||||||||
| 529 | emit renderTargetChanged(); | - | ||||||||||||||||||
| 530 | } executed 4 times by 1 test: end of blockExecuted by:
| 4 | ||||||||||||||||||
| 531 | - | |||||||||||||||||||
| 532 | /*! | - | ||||||||||||||||||
| 533 | \fn virtual void QQuickPaintedItem::paint(QPainter *painter) = 0 | - | ||||||||||||||||||
| 534 | - | |||||||||||||||||||
| 535 | This function, which is usually called by the QML Scene Graph, paints the | - | ||||||||||||||||||
| 536 | contents of an item in local coordinates. | - | ||||||||||||||||||
| 537 | - | |||||||||||||||||||
| 538 | The underlying texture will have a size defined by textureSize when set, | - | ||||||||||||||||||
| 539 | or the item's size, multiplied by the window's device pixel ratio. | - | ||||||||||||||||||
| 540 | - | |||||||||||||||||||
| 541 | The function is called after the item has been filled with the fillColor. | - | ||||||||||||||||||
| 542 | - | |||||||||||||||||||
| 543 | Reimplement this function in a QQuickPaintedItem subclass to provide the | - | ||||||||||||||||||
| 544 | item's painting implementation, using \a painter. | - | ||||||||||||||||||
| 545 | - | |||||||||||||||||||
| 546 | \note The QML Scene Graph uses two separate threads, the main thread does things such as | - | ||||||||||||||||||
| 547 | processing events or updating animations while a second thread does the actual OpenGL rendering. | - | ||||||||||||||||||
| 548 | As a consequence, paint() is not called from the main GUI thread but from the GL enabled | - | ||||||||||||||||||
| 549 | renderer thread. At the moment paint() is called, the GUI thread is blocked and this is | - | ||||||||||||||||||
| 550 | therefore thread-safe. | - | ||||||||||||||||||
| 551 | - | |||||||||||||||||||
| 552 | \warning Extreme caution must be used when creating QObjects, emitting signals, starting | - | ||||||||||||||||||
| 553 | timers and similar inside this function as these will have affinity to the rendering thread. | - | ||||||||||||||||||
| 554 | - | |||||||||||||||||||
| 555 | \sa width(), height(), textureSize | - | ||||||||||||||||||
| 556 | */ | - | ||||||||||||||||||
| 557 | - | |||||||||||||||||||
| 558 | /*! | - | ||||||||||||||||||
| 559 | \reimp | - | ||||||||||||||||||
| 560 | */ | - | ||||||||||||||||||
| 561 | QSGNode *QQuickPaintedItem::updatePaintNode(QSGNode *oldNode, UpdatePaintNodeData *data) | - | ||||||||||||||||||
| 562 | { | - | ||||||||||||||||||
| 563 | Q_UNUSED(data); | - | ||||||||||||||||||
| 564 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 565 | - | |||||||||||||||||||
| 566 | if (width() <= 0 || height() <= 0) {
| 0-50 | ||||||||||||||||||
| 567 | delete oldNode; | - | ||||||||||||||||||
| 568 | if (d->textureProvider) {
| 0-2 | ||||||||||||||||||
| 569 | d->textureProvider->node = nullptr; | - | ||||||||||||||||||
| 570 | d->textureProvider->fireTextureChanged(); | - | ||||||||||||||||||
| 571 | } never executed: end of block | 0 | ||||||||||||||||||
| 572 | return nullptr; executed 2 times by 1 test: return nullptr;Executed by:
| 2 | ||||||||||||||||||
| 573 | } | - | ||||||||||||||||||
| 574 | - | |||||||||||||||||||
| 575 | QSGPainterNode *node = static_cast<QSGPainterNode *>(oldNode); | - | ||||||||||||||||||
| 576 | if (!node) {
| 16-34 | ||||||||||||||||||
| 577 | node = d->sceneGraphContext()->createPainterNode(this); | - | ||||||||||||||||||
| 578 | d->node = node; | - | ||||||||||||||||||
| 579 | } executed 16 times by 1 test: end of blockExecuted by:
| 16 | ||||||||||||||||||
| 580 | - | |||||||||||||||||||
| 581 | bool hasTextureSize = d->textureSize.width() > 0 && d->textureSize.height() > 0;
| 0-50 | ||||||||||||||||||
| 582 | - | |||||||||||||||||||
| 583 | // Use the compat mode if any of the compat things are set and | - | ||||||||||||||||||
| 584 | // textureSize is 0x0. | - | ||||||||||||||||||
| 585 | if (!hasTextureSize
| 0-50 | ||||||||||||||||||
| 586 | && (d->contentsScale != 1
| 10-40 | ||||||||||||||||||
| 587 | || (d->contentsSize.width() > 0 && d->contentsSize.height() > 0))) {
| 0-38 | ||||||||||||||||||
| 588 | QRectF br = contentsBoundingRect(); | - | ||||||||||||||||||
| 589 | node->setContentsScale(d->contentsScale); | - | ||||||||||||||||||
| 590 | QSize size = QSize(qRound(br.width()), qRound(br.height())); | - | ||||||||||||||||||
| 591 | node->setSize(size); | - | ||||||||||||||||||
| 592 | node->setTextureSize(size); | - | ||||||||||||||||||
| 593 | } else { executed 12 times by 1 test: end of blockExecuted by:
| 12 | ||||||||||||||||||
| 594 | // The default, use textureSize or item's size * device pixel ratio | - | ||||||||||||||||||
| 595 | node->setContentsScale(1); | - | ||||||||||||||||||
| 596 | QSize itemSize(qRound(width()), qRound(height())); | - | ||||||||||||||||||
| 597 | node->setSize(itemSize); | - | ||||||||||||||||||
| 598 | QSize textureSize = (hasTextureSize ? d->textureSize : itemSize)
| 0-38 | ||||||||||||||||||
| 599 | * window()->effectiveDevicePixelRatio(); | - | ||||||||||||||||||
| 600 | node->setTextureSize(textureSize); | - | ||||||||||||||||||
| 601 | } executed 38 times by 1 test: end of blockExecuted by:
| 38 | ||||||||||||||||||
| 602 | - | |||||||||||||||||||
| 603 | node->setPreferredRenderTarget(d->renderTarget); | - | ||||||||||||||||||
| 604 | node->setFastFBOResizing(d->performanceHints & FastFBOResizing); | - | ||||||||||||||||||
| 605 | node->setSmoothPainting(d->antialiasing); | - | ||||||||||||||||||
| 606 | node->setLinearFiltering(d->smooth); | - | ||||||||||||||||||
| 607 | node->setMipmapping(d->mipmap); | - | ||||||||||||||||||
| 608 | node->setOpaquePainting(d->opaquePainting); | - | ||||||||||||||||||
| 609 | node->setFillColor(d->fillColor); | - | ||||||||||||||||||
| 610 | node->setDirty(d->dirtyRect); | - | ||||||||||||||||||
| 611 | node->update(); | - | ||||||||||||||||||
| 612 | - | |||||||||||||||||||
| 613 | d->dirtyRect = QRect(); | - | ||||||||||||||||||
| 614 | - | |||||||||||||||||||
| 615 | if (d->textureProvider) {
| 0-50 | ||||||||||||||||||
| 616 | d->textureProvider->node = node; | - | ||||||||||||||||||
| 617 | d->textureProvider->fireTextureChanged(); | - | ||||||||||||||||||
| 618 | } never executed: end of block | 0 | ||||||||||||||||||
| 619 | - | |||||||||||||||||||
| 620 | return node; executed 50 times by 1 test: return node;Executed by:
| 50 | ||||||||||||||||||
| 621 | } | - | ||||||||||||||||||
| 622 | - | |||||||||||||||||||
| 623 | /*! | - | ||||||||||||||||||
| 624 | \reimp | - | ||||||||||||||||||
| 625 | */ | - | ||||||||||||||||||
| 626 | void QQuickPaintedItem::releaseResources() | - | ||||||||||||||||||
| 627 | { | - | ||||||||||||||||||
| 628 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 629 | if (d->textureProvider) {
| 0 | ||||||||||||||||||
| 630 | QQuickWindowQObjectCleanupJob::schedule(window(), d->textureProvider); | - | ||||||||||||||||||
| 631 | d->textureProvider = nullptr; | - | ||||||||||||||||||
| 632 | } never executed: end of block | 0 | ||||||||||||||||||
| 633 | d->node = nullptr; // Managed by the scene graph, just clear the pointer. | - | ||||||||||||||||||
| 634 | } never executed: end of block | 0 | ||||||||||||||||||
| 635 | - | |||||||||||||||||||
| 636 | void QQuickPaintedItem::invalidateSceneGraph() | - | ||||||||||||||||||
| 637 | { | - | ||||||||||||||||||
| 638 | Q_D(QQuickPaintedItem); | - | ||||||||||||||||||
| 639 | delete d->textureProvider; | - | ||||||||||||||||||
| 640 | d->textureProvider = nullptr; | - | ||||||||||||||||||
| 641 | d->node = nullptr; // Managed by the scene graph, just clear the pointer | - | ||||||||||||||||||
| 642 | } never executed: end of block | 0 | ||||||||||||||||||
| 643 | - | |||||||||||||||||||
| 644 | /*! | - | ||||||||||||||||||
| 645 | \reimp | - | ||||||||||||||||||
| 646 | */ | - | ||||||||||||||||||
| 647 | bool QQuickPaintedItem::isTextureProvider() const | - | ||||||||||||||||||
| 648 | { | - | ||||||||||||||||||
| 649 | return true; never executed: return true; | 0 | ||||||||||||||||||
| 650 | } | - | ||||||||||||||||||
| 651 | - | |||||||||||||||||||
| 652 | /*! | - | ||||||||||||||||||
| 653 | \reimp | - | ||||||||||||||||||
| 654 | */ | - | ||||||||||||||||||
| 655 | QSGTextureProvider *QQuickPaintedItem::textureProvider() const | - | ||||||||||||||||||
| 656 | { | - | ||||||||||||||||||
| 657 | // When Item::layer::enabled == true, QQuickItem will be a texture | - | ||||||||||||||||||
| 658 | // provider. In this case we should prefer to return the layer rather | - | ||||||||||||||||||
| 659 | // than the image itself. The layer will include any children and any | - | ||||||||||||||||||
| 660 | // the image's wrap and fill mode. | - | ||||||||||||||||||
| 661 | if (QQuickItem::isTextureProvider())
| 0 | ||||||||||||||||||
| 662 | return QQuickItem::textureProvider(); never executed: return QQuickItem::textureProvider(); | 0 | ||||||||||||||||||
| 663 | - | |||||||||||||||||||
| 664 | Q_D(const QQuickPaintedItem); | - | ||||||||||||||||||
| 665 | #if QT_CONFIG(opengl) | - | ||||||||||||||||||
| 666 | QQuickWindow *w = window(); | - | ||||||||||||||||||
| 667 | if (!w || !w->openglContext() || QThread::currentThread() != w->openglContext()->thread()) {
| 0 | ||||||||||||||||||
| 668 | qWarning("QQuickPaintedItem::textureProvider: can only be queried on the rendering thread of an exposed window"); | - | ||||||||||||||||||
| 669 | return nullptr; never executed: return nullptr; | 0 | ||||||||||||||||||
| 670 | } | - | ||||||||||||||||||
| 671 | #endif | - | ||||||||||||||||||
| 672 | if (!d->textureProvider)
| 0 | ||||||||||||||||||
| 673 | d->textureProvider = new QQuickPaintedItemTextureProvider(); never executed: d->textureProvider = new QQuickPaintedItemTextureProvider(); | 0 | ||||||||||||||||||
| 674 | d->textureProvider->node = d->node; | - | ||||||||||||||||||
| 675 | return d->textureProvider; never executed: return d->textureProvider; | 0 | ||||||||||||||||||
| 676 | } | - | ||||||||||||||||||
| 677 | - | |||||||||||||||||||
| 678 | - | |||||||||||||||||||
| 679 | /*! | - | ||||||||||||||||||
| 680 | \reimp | - | ||||||||||||||||||
| 681 | */ | - | ||||||||||||||||||
| 682 | void QQuickPaintedItem::itemChange(ItemChange change, const ItemChangeData &value) | - | ||||||||||||||||||
| 683 | { | - | ||||||||||||||||||
| 684 | if (change == ItemDevicePixelRatioHasChanged)
| 0-32 | ||||||||||||||||||
| 685 | update(); never executed: update(); | 0 | ||||||||||||||||||
| 686 | QQuickItem::itemChange(change, value); | - | ||||||||||||||||||
| 687 | } executed 32 times by 1 test: end of blockExecuted by:
| 32 | ||||||||||||||||||
| 688 | - | |||||||||||||||||||
| 689 | QT_END_NAMESPACE | - | ||||||||||||||||||
| 690 | - | |||||||||||||||||||
| 691 | #include "moc_qquickpainteditem.cpp" | - | ||||||||||||||||||
| Source code | Switch to Preprocessed file |