| Absolute File Name: | /home/opencoverage/opencoverage/guest-scripts/qtdeclarative/src/qtdeclarative/src/quick/scenegraph/qsgbasicinternalimagenode.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 "qsgbasicinternalimagenode_p.h" | - | ||||||||||||||||||||||||
| 41 | - | |||||||||||||||||||||||||
| 42 | #include <QtCore/qvarlengtharray.h> | - | ||||||||||||||||||||||||
| 43 | #include <QtCore/qmath.h> | - | ||||||||||||||||||||||||
| 44 | - | |||||||||||||||||||||||||
| 45 | QT_BEGIN_NAMESPACE | - | ||||||||||||||||||||||||
| 46 | - | |||||||||||||||||||||||||
| 47 | namespace | - | ||||||||||||||||||||||||
| 48 | { | - | ||||||||||||||||||||||||
| 49 | struct SmoothVertex | - | ||||||||||||||||||||||||
| 50 | { | - | ||||||||||||||||||||||||
| 51 | float x, y, u, v; | - | ||||||||||||||||||||||||
| 52 | float dx, dy, du, dv; | - | ||||||||||||||||||||||||
| 53 | }; | - | ||||||||||||||||||||||||
| 54 | - | |||||||||||||||||||||||||
| 55 | const QSGGeometry::AttributeSet &smoothAttributeSet() | - | ||||||||||||||||||||||||
| 56 | { | - | ||||||||||||||||||||||||
| 57 | static QSGGeometry::Attribute data[] = { | - | ||||||||||||||||||||||||
| 58 | QSGGeometry::Attribute::createWithAttributeType(0, 2, QSGGeometry::FloatType, QSGGeometry::PositionAttribute), | - | ||||||||||||||||||||||||
| 59 | QSGGeometry::Attribute::createWithAttributeType(1, 2, QSGGeometry::FloatType, QSGGeometry::TexCoordAttribute), | - | ||||||||||||||||||||||||
| 60 | QSGGeometry::Attribute::createWithAttributeType(2, 2, QSGGeometry::FloatType, QSGGeometry::TexCoord1Attribute), | - | ||||||||||||||||||||||||
| 61 | QSGGeometry::Attribute::createWithAttributeType(3, 2, QSGGeometry::FloatType, QSGGeometry::TexCoord2Attribute) | - | ||||||||||||||||||||||||
| 62 | }; | - | ||||||||||||||||||||||||
| 63 | static QSGGeometry::AttributeSet attrs = { 4, sizeof(SmoothVertex), data }; | - | ||||||||||||||||||||||||
| 64 | return attrs; never executed: return attrs; | 0 | ||||||||||||||||||||||||
| 65 | } | - | ||||||||||||||||||||||||
| 66 | } | - | ||||||||||||||||||||||||
| 67 | - | |||||||||||||||||||||||||
| 68 | QSGBasicInternalImageNode::QSGBasicInternalImageNode() | - | ||||||||||||||||||||||||
| 69 | : m_innerSourceRect(0, 0, 1, 1) | - | ||||||||||||||||||||||||
| 70 | , m_subSourceRect(0, 0, 1, 1) | - | ||||||||||||||||||||||||
| 71 | , m_antialiasing(false) | - | ||||||||||||||||||||||||
| 72 | , m_mirror(false) | - | ||||||||||||||||||||||||
| 73 | , m_dirtyGeometry(false) | - | ||||||||||||||||||||||||
| 74 | , m_geometry(QSGGeometry::defaultAttributes_TexturedPoint2D(), 4) | - | ||||||||||||||||||||||||
| 75 | , m_dynamicTexture(nullptr) | - | ||||||||||||||||||||||||
| 76 | { | - | ||||||||||||||||||||||||
| 77 | setGeometry(&m_geometry); | - | ||||||||||||||||||||||||
| 78 | - | |||||||||||||||||||||||||
| 79 | #ifdef QSG_RUNTIME_DESCRIPTION | - | ||||||||||||||||||||||||
| 80 | qsgnode_set_description(this, QLatin1String("internalimage")); | - | ||||||||||||||||||||||||
| 81 | #endif | - | ||||||||||||||||||||||||
| 82 | } executed 5189 times by 10 tests: end of blockExecuted by:
| 5189 | ||||||||||||||||||||||||
| 83 | - | |||||||||||||||||||||||||
| 84 | void QSGBasicInternalImageNode::setTargetRect(const QRectF &rect) | - | ||||||||||||||||||||||||
| 85 | { | - | ||||||||||||||||||||||||
| 86 | if (rect == m_targetRect)
| 98-5207 | ||||||||||||||||||||||||
| 87 | return; executed 98 times by 2 tests: return;Executed by:
| 98 | ||||||||||||||||||||||||
| 88 | m_targetRect = rect; | - | ||||||||||||||||||||||||
| 89 | m_dirtyGeometry = true; | - | ||||||||||||||||||||||||
| 90 | } executed 5207 times by 10 tests: end of blockExecuted by:
| 5207 | ||||||||||||||||||||||||
| 91 | - | |||||||||||||||||||||||||
| 92 | void QSGBasicInternalImageNode::setInnerTargetRect(const QRectF &rect) | - | ||||||||||||||||||||||||
| 93 | { | - | ||||||||||||||||||||||||
| 94 | if (rect == m_innerTargetRect)
| 98-5207 | ||||||||||||||||||||||||
| 95 | return; executed 98 times by 2 tests: return;Executed by:
| 98 | ||||||||||||||||||||||||
| 96 | m_innerTargetRect = rect; | - | ||||||||||||||||||||||||
| 97 | m_dirtyGeometry = true; | - | ||||||||||||||||||||||||
| 98 | } executed 5207 times by 10 tests: end of blockExecuted by:
| 5207 | ||||||||||||||||||||||||
| 99 | - | |||||||||||||||||||||||||
| 100 | void QSGBasicInternalImageNode::setInnerSourceRect(const QRectF &rect) | - | ||||||||||||||||||||||||
| 101 | { | - | ||||||||||||||||||||||||
| 102 | if (rect == m_innerSourceRect)
| 0-70 | ||||||||||||||||||||||||
| 103 | return; never executed: return; | 0 | ||||||||||||||||||||||||
| 104 | m_innerSourceRect = rect; | - | ||||||||||||||||||||||||
| 105 | m_dirtyGeometry = true; | - | ||||||||||||||||||||||||
| 106 | } executed 70 times by 2 tests: end of blockExecuted by:
| 70 | ||||||||||||||||||||||||
| 107 | - | |||||||||||||||||||||||||
| 108 | void QSGBasicInternalImageNode::setSubSourceRect(const QRectF &rect) | - | ||||||||||||||||||||||||
| 109 | { | - | ||||||||||||||||||||||||
| 110 | if (rect == m_subSourceRect)
| 26-5129 | ||||||||||||||||||||||||
| 111 | return; executed 5129 times by 8 tests: return;Executed by:
| 5129 | ||||||||||||||||||||||||
| 112 | m_subSourceRect = rect; | - | ||||||||||||||||||||||||
| 113 | m_dirtyGeometry = true; | - | ||||||||||||||||||||||||
| 114 | } executed 26 times by 2 tests: end of blockExecuted by:
| 26 | ||||||||||||||||||||||||
| 115 | - | |||||||||||||||||||||||||
| 116 | void QSGBasicInternalImageNode::setTexture(QSGTexture *texture) | - | ||||||||||||||||||||||||
| 117 | { | - | ||||||||||||||||||||||||
| 118 | Q_ASSERT(texture); | - | ||||||||||||||||||||||||
| 119 | - | |||||||||||||||||||||||||
| 120 | setMaterialTexture(texture); | - | ||||||||||||||||||||||||
| 121 | updateMaterialBlending(); | - | ||||||||||||||||||||||||
| 122 | - | |||||||||||||||||||||||||
| 123 | markDirty(DirtyMaterial); | - | ||||||||||||||||||||||||
| 124 | - | |||||||||||||||||||||||||
| 125 | // Because the texture can be a different part of the atlas, we need to update it... | - | ||||||||||||||||||||||||
| 126 | m_dirtyGeometry = true; | - | ||||||||||||||||||||||||
| 127 | } executed 5245 times by 10 tests: end of blockExecuted by:
| 5245 | ||||||||||||||||||||||||
| 128 | - | |||||||||||||||||||||||||
| 129 | void QSGBasicInternalImageNode::setAntialiasing(bool antialiasing) | - | ||||||||||||||||||||||||
| 130 | { | - | ||||||||||||||||||||||||
| 131 | if (antialiasing == m_antialiasing)
| 0-5155 | ||||||||||||||||||||||||
| 132 | return; executed 5155 times by 8 tests: return;Executed by:
| 5155 | ||||||||||||||||||||||||
| 133 | m_antialiasing = antialiasing; | - | ||||||||||||||||||||||||
| 134 | if (m_antialiasing) {
| 0 | ||||||||||||||||||||||||
| 135 | setGeometry(new QSGGeometry(smoothAttributeSet(), 0)); | - | ||||||||||||||||||||||||
| 136 | setFlag(OwnsGeometry, true); | - | ||||||||||||||||||||||||
| 137 | } else { never executed: end of block | 0 | ||||||||||||||||||||||||
| 138 | setGeometry(&m_geometry); | - | ||||||||||||||||||||||||
| 139 | setFlag(OwnsGeometry, false); | - | ||||||||||||||||||||||||
| 140 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 141 | updateMaterialAntialiasing(); | - | ||||||||||||||||||||||||
| 142 | m_dirtyGeometry = true; | - | ||||||||||||||||||||||||
| 143 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 144 | - | |||||||||||||||||||||||||
| 145 | void QSGBasicInternalImageNode::setMirror(bool mirror) | - | ||||||||||||||||||||||||
| 146 | { | - | ||||||||||||||||||||||||
| 147 | if (mirror == m_mirror)
| 22-5133 | ||||||||||||||||||||||||
| 148 | return; executed 5133 times by 8 tests: return;Executed by:
| 5133 | ||||||||||||||||||||||||
| 149 | m_mirror = mirror; | - | ||||||||||||||||||||||||
| 150 | m_dirtyGeometry = true; | - | ||||||||||||||||||||||||
| 151 | } executed 22 times by 3 tests: end of blockExecuted by:
| 22 | ||||||||||||||||||||||||
| 152 | - | |||||||||||||||||||||||||
| 153 | - | |||||||||||||||||||||||||
| 154 | void QSGBasicInternalImageNode::update() | - | ||||||||||||||||||||||||
| 155 | { | - | ||||||||||||||||||||||||
| 156 | if (m_dirtyGeometry)
| 56-5249 | ||||||||||||||||||||||||
| 157 | updateGeometry(); executed 5249 times by 10 tests: updateGeometry();Executed by:
| 5249 | ||||||||||||||||||||||||
| 158 | } executed 5305 times by 10 tests: end of blockExecuted by:
| 5305 | ||||||||||||||||||||||||
| 159 | - | |||||||||||||||||||||||||
| 160 | void QSGBasicInternalImageNode::preprocess() | - | ||||||||||||||||||||||||
| 161 | { | - | ||||||||||||||||||||||||
| 162 | bool doDirty = false; | - | ||||||||||||||||||||||||
| 163 | QSGDynamicTexture *t = qobject_cast<QSGDynamicTexture *>(materialTexture()); | - | ||||||||||||||||||||||||
| 164 | if (t) {
| 0-126 | ||||||||||||||||||||||||
| 165 | doDirty = t->updateTexture(); | - | ||||||||||||||||||||||||
| 166 | if (doDirty) {
| 31-95 | ||||||||||||||||||||||||
| 167 | // The geometry may need updating. This is expensive however, so do | - | ||||||||||||||||||||||||
| 168 | // it only when something relevant has changed. | - | ||||||||||||||||||||||||
| 169 | if (t != m_dynamicTexture
| 0-31 | ||||||||||||||||||||||||
| 170 | || t->textureSize() != m_dynamicTextureSize
| 0 | ||||||||||||||||||||||||
| 171 | || t->normalizedTextureSubRect() != m_dynamicTextureSubRect) {
| 0 | ||||||||||||||||||||||||
| 172 | updateGeometry(); | - | ||||||||||||||||||||||||
| 173 | m_dynamicTextureSize = t->textureSize(); | - | ||||||||||||||||||||||||
| 174 | m_dynamicTextureSubRect = t->normalizedTextureSubRect(); | - | ||||||||||||||||||||||||
| 175 | } executed 31 times by 2 tests: end of blockExecuted by:
| 31 | ||||||||||||||||||||||||
| 176 | } executed 31 times by 2 tests: end of blockExecuted by:
| 31 | ||||||||||||||||||||||||
| 177 | } executed 126 times by 2 tests: end of blockExecuted by:
| 126 | ||||||||||||||||||||||||
| 178 | m_dynamicTexture = t; | - | ||||||||||||||||||||||||
| 179 | - | |||||||||||||||||||||||||
| 180 | if (updateMaterialBlending())
| 0-126 | ||||||||||||||||||||||||
| 181 | doDirty = true; never executed: doDirty = true; | 0 | ||||||||||||||||||||||||
| 182 | - | |||||||||||||||||||||||||
| 183 | if (doDirty)
| 31-95 | ||||||||||||||||||||||||
| 184 | markDirty(DirtyMaterial); executed 31 times by 2 tests: markDirty(DirtyMaterial);Executed by:
| 31 | ||||||||||||||||||||||||
| 185 | } executed 126 times by 2 tests: end of blockExecuted by:
| 126 | ||||||||||||||||||||||||
| 186 | - | |||||||||||||||||||||||||
| 187 | namespace { | - | ||||||||||||||||||||||||
| 188 | struct X { float x, tx; }; | - | ||||||||||||||||||||||||
| 189 | struct Y { float y, ty; }; | - | ||||||||||||||||||||||||
| 190 | } | - | ||||||||||||||||||||||||
| 191 | - | |||||||||||||||||||||||||
| 192 | static inline void appendQuad(quint16 **indices, quint16 topLeft, quint16 topRight, | - | ||||||||||||||||||||||||
| 193 | quint16 bottomLeft, quint16 bottomRight) | - | ||||||||||||||||||||||||
| 194 | { | - | ||||||||||||||||||||||||
| 195 | *(*indices)++ = topLeft; | - | ||||||||||||||||||||||||
| 196 | *(*indices)++ = bottomLeft; | - | ||||||||||||||||||||||||
| 197 | *(*indices)++ = bottomRight; | - | ||||||||||||||||||||||||
| 198 | *(*indices)++ = bottomRight; | - | ||||||||||||||||||||||||
| 199 | *(*indices)++ = topRight; | - | ||||||||||||||||||||||||
| 200 | *(*indices)++ = topLeft; | - | ||||||||||||||||||||||||
| 201 | } executed 636 times by 2 tests: end of blockExecuted by:
| 636 | ||||||||||||||||||||||||
| 202 | - | |||||||||||||||||||||||||
| 203 | QSGGeometry *QSGBasicInternalImageNode::updateGeometry(const QRectF &targetRect, | - | ||||||||||||||||||||||||
| 204 | const QRectF &innerTargetRect, | - | ||||||||||||||||||||||||
| 205 | const QRectF &sourceRect, | - | ||||||||||||||||||||||||
| 206 | const QRectF &innerSourceRect, | - | ||||||||||||||||||||||||
| 207 | const QRectF &subSourceRect, | - | ||||||||||||||||||||||||
| 208 | QSGGeometry *geometry, | - | ||||||||||||||||||||||||
| 209 | bool mirror, | - | ||||||||||||||||||||||||
| 210 | bool antialiasing) | - | ||||||||||||||||||||||||
| 211 | { | - | ||||||||||||||||||||||||
| 212 | int floorLeft = qFloor(subSourceRect.left()); | - | ||||||||||||||||||||||||
| 213 | int ceilRight = qCeil(subSourceRect.right()); | - | ||||||||||||||||||||||||
| 214 | int floorTop = qFloor(subSourceRect.top()); | - | ||||||||||||||||||||||||
| 215 | int ceilBottom = qCeil(subSourceRect.bottom()); | - | ||||||||||||||||||||||||
| 216 | int hTiles = ceilRight - floorLeft; | - | ||||||||||||||||||||||||
| 217 | int vTiles = ceilBottom - floorTop; | - | ||||||||||||||||||||||||
| 218 | - | |||||||||||||||||||||||||
| 219 | int hCells = hTiles; | - | ||||||||||||||||||||||||
| 220 | int vCells = vTiles; | - | ||||||||||||||||||||||||
| 221 | if (innerTargetRect.width() == 0)
| 0-72 | ||||||||||||||||||||||||
| 222 | hCells = 0; never executed: hCells = 0; | 0 | ||||||||||||||||||||||||
| 223 | if (innerTargetRect.left() != targetRect.left())
| 2-70 | ||||||||||||||||||||||||
| 224 | ++hCells; executed 70 times by 2 tests: ++hCells;Executed by:
| 70 | ||||||||||||||||||||||||
| 225 | if (innerTargetRect.right() != targetRect.right())
| 2-70 | ||||||||||||||||||||||||
| 226 | ++hCells; executed 70 times by 2 tests: ++hCells;Executed by:
| 70 | ||||||||||||||||||||||||
| 227 | if (innerTargetRect.height() == 0)
| 0-72 | ||||||||||||||||||||||||
| 228 | vCells = 0; never executed: vCells = 0; | 0 | ||||||||||||||||||||||||
| 229 | if (innerTargetRect.top() != targetRect.top())
| 0-72 | ||||||||||||||||||||||||
| 230 | ++vCells; executed 72 times by 2 tests: ++vCells;Executed by:
| 72 | ||||||||||||||||||||||||
| 231 | if (innerTargetRect.bottom() != targetRect.bottom())
| 0-72 | ||||||||||||||||||||||||
| 232 | ++vCells; executed 72 times by 2 tests: ++vCells;Executed by:
| 72 | ||||||||||||||||||||||||
| 233 | QVarLengthArray<X, 32> xData(2 * hCells); | - | ||||||||||||||||||||||||
| 234 | QVarLengthArray<Y, 32> yData(2 * vCells); | - | ||||||||||||||||||||||||
| 235 | X *xs = xData.data(); | - | ||||||||||||||||||||||||
| 236 | Y *ys = yData.data(); | - | ||||||||||||||||||||||||
| 237 | - | |||||||||||||||||||||||||
| 238 | if (innerTargetRect.left() != targetRect.left()) {
| 2-70 | ||||||||||||||||||||||||
| 239 | xs[0].x = targetRect.left(); | - | ||||||||||||||||||||||||
| 240 | xs[0].tx = sourceRect.left(); | - | ||||||||||||||||||||||||
| 241 | xs[1].x = innerTargetRect.left(); | - | ||||||||||||||||||||||||
| 242 | xs[1].tx = innerSourceRect.left(); | - | ||||||||||||||||||||||||
| 243 | xs += 2; | - | ||||||||||||||||||||||||
| 244 | } executed 70 times by 2 tests: end of blockExecuted by:
| 70 | ||||||||||||||||||||||||
| 245 | if (innerTargetRect.width() != 0) {
| 0-72 | ||||||||||||||||||||||||
| 246 | xs[0].x = innerTargetRect.left(); | - | ||||||||||||||||||||||||
| 247 | xs[0].tx = innerSourceRect.x() + (subSourceRect.left() - floorLeft) * innerSourceRect.width(); | - | ||||||||||||||||||||||||
| 248 | ++xs; | - | ||||||||||||||||||||||||
| 249 | float b = innerTargetRect.width() / subSourceRect.width(); | - | ||||||||||||||||||||||||
| 250 | float a = innerTargetRect.x() - subSourceRect.x() * b; | - | ||||||||||||||||||||||||
| 251 | for (int i = floorLeft + 1; i <= ceilRight - 1; ++i) {
| 0-72 | ||||||||||||||||||||||||
| 252 | xs[0].x = xs[1].x = a + b * i; | - | ||||||||||||||||||||||||
| 253 | xs[0].tx = innerSourceRect.right(); | - | ||||||||||||||||||||||||
| 254 | xs[1].tx = innerSourceRect.left(); | - | ||||||||||||||||||||||||
| 255 | xs += 2; | - | ||||||||||||||||||||||||
| 256 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 257 | xs[0].x = innerTargetRect.right(); | - | ||||||||||||||||||||||||
| 258 | xs[0].tx = innerSourceRect.x() + (subSourceRect.right() - ceilRight + 1) * innerSourceRect.width(); | - | ||||||||||||||||||||||||
| 259 | ++xs; | - | ||||||||||||||||||||||||
| 260 | } executed 72 times by 2 tests: end of blockExecuted by:
| 72 | ||||||||||||||||||||||||
| 261 | if (innerTargetRect.right() != targetRect.right()) {
| 2-70 | ||||||||||||||||||||||||
| 262 | xs[0].x = innerTargetRect.right(); | - | ||||||||||||||||||||||||
| 263 | xs[0].tx = innerSourceRect.right(); | - | ||||||||||||||||||||||||
| 264 | xs[1].x = targetRect.right(); | - | ||||||||||||||||||||||||
| 265 | xs[1].tx = sourceRect.right(); | - | ||||||||||||||||||||||||
| 266 | xs += 2; | - | ||||||||||||||||||||||||
| 267 | } executed 70 times by 2 tests: end of blockExecuted by:
| 70 | ||||||||||||||||||||||||
| 268 | Q_ASSERT(xs == xData.data() + xData.size()); | - | ||||||||||||||||||||||||
| 269 | if (mirror) {
| 2-70 | ||||||||||||||||||||||||
| 270 | float leftPlusRight = targetRect.left() + targetRect.right(); | - | ||||||||||||||||||||||||
| 271 | int count = xData.size(); | - | ||||||||||||||||||||||||
| 272 | xs = xData.data(); | - | ||||||||||||||||||||||||
| 273 | for (int i = 0; i < count >> 1; ++i)
| 2-6 | ||||||||||||||||||||||||
| 274 | qSwap(xs[i], xs[count - 1 - i]); executed 6 times by 1 test: qSwap(xs[i], xs[count - 1 - i]);Executed by:
| 6 | ||||||||||||||||||||||||
| 275 | for (int i = 0; i < count; ++i)
| 2-12 | ||||||||||||||||||||||||
| 276 | xs[i].x = leftPlusRight - xs[i].x; executed 12 times by 1 test: xs[i].x = leftPlusRight - xs[i].x;Executed by:
| 12 | ||||||||||||||||||||||||
| 277 | } executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 278 | - | |||||||||||||||||||||||||
| 279 | if (innerTargetRect.top() != targetRect.top()) {
| 0-72 | ||||||||||||||||||||||||
| 280 | ys[0].y = targetRect.top(); | - | ||||||||||||||||||||||||
| 281 | ys[0].ty = sourceRect.top(); | - | ||||||||||||||||||||||||
| 282 | ys[1].y = innerTargetRect.top(); | - | ||||||||||||||||||||||||
| 283 | ys[1].ty = innerSourceRect.top(); | - | ||||||||||||||||||||||||
| 284 | ys += 2; | - | ||||||||||||||||||||||||
| 285 | } executed 72 times by 2 tests: end of blockExecuted by:
| 72 | ||||||||||||||||||||||||
| 286 | if (innerTargetRect.height() != 0) {
| 0-72 | ||||||||||||||||||||||||
| 287 | ys[0].y = innerTargetRect.top(); | - | ||||||||||||||||||||||||
| 288 | ys[0].ty = innerSourceRect.y() + (subSourceRect.top() - floorTop) * innerSourceRect.height(); | - | ||||||||||||||||||||||||
| 289 | ++ys; | - | ||||||||||||||||||||||||
| 290 | float b = innerTargetRect.height() / subSourceRect.height(); | - | ||||||||||||||||||||||||
| 291 | float a = innerTargetRect.y() - subSourceRect.y() * b; | - | ||||||||||||||||||||||||
| 292 | for (int i = floorTop + 1; i <= ceilBottom - 1; ++i) {
| 0-72 | ||||||||||||||||||||||||
| 293 | ys[0].y = ys[1].y = a + b * i; | - | ||||||||||||||||||||||||
| 294 | ys[0].ty = innerSourceRect.bottom(); | - | ||||||||||||||||||||||||
| 295 | ys[1].ty = innerSourceRect.top(); | - | ||||||||||||||||||||||||
| 296 | ys += 2; | - | ||||||||||||||||||||||||
| 297 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 298 | ys[0].y = innerTargetRect.bottom(); | - | ||||||||||||||||||||||||
| 299 | ys[0].ty = innerSourceRect.y() + (subSourceRect.bottom() - ceilBottom + 1) * innerSourceRect.height(); | - | ||||||||||||||||||||||||
| 300 | ++ys; | - | ||||||||||||||||||||||||
| 301 | } executed 72 times by 2 tests: end of blockExecuted by:
| 72 | ||||||||||||||||||||||||
| 302 | if (innerTargetRect.bottom() != targetRect.bottom()) {
| 0-72 | ||||||||||||||||||||||||
| 303 | ys[0].y = innerTargetRect.bottom(); | - | ||||||||||||||||||||||||
| 304 | ys[0].ty = innerSourceRect.bottom(); | - | ||||||||||||||||||||||||
| 305 | ys[1].y = targetRect.bottom(); | - | ||||||||||||||||||||||||
| 306 | ys[1].ty = sourceRect.bottom(); | - | ||||||||||||||||||||||||
| 307 | ys += 2; | - | ||||||||||||||||||||||||
| 308 | } executed 72 times by 2 tests: end of blockExecuted by:
| 72 | ||||||||||||||||||||||||
| 309 | Q_ASSERT(ys == yData.data() + yData.size()); | - | ||||||||||||||||||||||||
| 310 | - | |||||||||||||||||||||||||
| 311 | if (antialiasing) {
| 0-72 | ||||||||||||||||||||||||
| 312 | QSGGeometry *g = geometry; | - | ||||||||||||||||||||||||
| 313 | Q_ASSERT(g); | - | ||||||||||||||||||||||||
| 314 | - | |||||||||||||||||||||||||
| 315 | g->allocate(hCells * vCells * 4 + (hCells + vCells - 1) * 4, | - | ||||||||||||||||||||||||
| 316 | hCells * vCells * 6 + (hCells + vCells) * 12); | - | ||||||||||||||||||||||||
| 317 | g->setDrawingMode(QSGGeometry::DrawTriangles); | - | ||||||||||||||||||||||||
| 318 | SmoothVertex *vertices = reinterpret_cast<SmoothVertex *>(g->vertexData()); | - | ||||||||||||||||||||||||
| 319 | memset(vertices, 0, g->vertexCount() * g->sizeOfVertex()); | - | ||||||||||||||||||||||||
| 320 | quint16 *indices = g->indexDataAsUShort(); | - | ||||||||||||||||||||||||
| 321 | - | |||||||||||||||||||||||||
| 322 | // The deltas are how much the fuzziness can reach into the image. | - | ||||||||||||||||||||||||
| 323 | // Only the border vertices are moved by the vertex shader, so the fuzziness | - | ||||||||||||||||||||||||
| 324 | // can't reach further into the image than the closest interior vertices. | - | ||||||||||||||||||||||||
| 325 | float leftDx = xData.at(1).x - xData.at(0).x; | - | ||||||||||||||||||||||||
| 326 | float rightDx = xData.at(xData.size() - 1).x - xData.at(xData.size() - 2).x; | - | ||||||||||||||||||||||||
| 327 | float topDy = yData.at(1).y - yData.at(0).y; | - | ||||||||||||||||||||||||
| 328 | float bottomDy = yData.at(yData.size() - 1).y - yData.at(yData.size() - 2).y; | - | ||||||||||||||||||||||||
| 329 | - | |||||||||||||||||||||||||
| 330 | float leftDu = xData.at(1).tx - xData.at(0).tx; | - | ||||||||||||||||||||||||
| 331 | float rightDu = xData.at(xData.size() - 1).tx - xData.at(xData.size() - 2).tx; | - | ||||||||||||||||||||||||
| 332 | float topDv = yData.at(1).ty - yData.at(0).ty; | - | ||||||||||||||||||||||||
| 333 | float bottomDv = yData.at(yData.size() - 1).ty - yData.at(yData.size() - 2).ty; | - | ||||||||||||||||||||||||
| 334 | - | |||||||||||||||||||||||||
| 335 | if (hCells == 1) {
| 0 | ||||||||||||||||||||||||
| 336 | leftDx = rightDx *= 0.5f; | - | ||||||||||||||||||||||||
| 337 | leftDu = rightDu *= 0.5f; | - | ||||||||||||||||||||||||
| 338 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 339 | if (vCells == 1) {
| 0 | ||||||||||||||||||||||||
| 340 | topDy = bottomDy *= 0.5f; | - | ||||||||||||||||||||||||
| 341 | topDv = bottomDv *= 0.5f; | - | ||||||||||||||||||||||||
| 342 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 343 | - | |||||||||||||||||||||||||
| 344 | // This delta is how much the fuzziness can reach out from the image. | - | ||||||||||||||||||||||||
| 345 | float delta = float(qAbs(targetRect.width()) < qAbs(targetRect.height()) | - | ||||||||||||||||||||||||
| 346 | ? targetRect.width() : targetRect.height()) * 0.5f; | - | ||||||||||||||||||||||||
| 347 | - | |||||||||||||||||||||||||
| 348 | quint16 index = 0; | - | ||||||||||||||||||||||||
| 349 | ys = yData.data(); | - | ||||||||||||||||||||||||
| 350 | for (int j = 0; j < vCells; ++j, ys += 2) {
| 0 | ||||||||||||||||||||||||
| 351 | xs = xData.data(); | - | ||||||||||||||||||||||||
| 352 | bool isTop = j == 0; | - | ||||||||||||||||||||||||
| 353 | bool isBottom = j == vCells - 1; | - | ||||||||||||||||||||||||
| 354 | for (int i = 0; i < hCells; ++i, xs += 2) {
| 0 | ||||||||||||||||||||||||
| 355 | bool isLeft = i == 0; | - | ||||||||||||||||||||||||
| 356 | bool isRight = i == hCells - 1; | - | ||||||||||||||||||||||||
| 357 | - | |||||||||||||||||||||||||
| 358 | SmoothVertex *v = vertices + index; | - | ||||||||||||||||||||||||
| 359 | - | |||||||||||||||||||||||||
| 360 | quint16 topLeft = index; | - | ||||||||||||||||||||||||
| 361 | for (int k = (isTop || isLeft ? 2 : 1); k--; ++v, ++index) {
| 0 | ||||||||||||||||||||||||
| 362 | v->x = xs[0].x; | - | ||||||||||||||||||||||||
| 363 | v->u = xs[0].tx; | - | ||||||||||||||||||||||||
| 364 | v->y = ys[0].y; | - | ||||||||||||||||||||||||
| 365 | v->v = ys[0].ty; | - | ||||||||||||||||||||||||
| 366 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 367 | - | |||||||||||||||||||||||||
| 368 | quint16 topRight = index; | - | ||||||||||||||||||||||||
| 369 | for (int k = (isTop || isRight ? 2 : 1); k--; ++v, ++index) {
| 0 | ||||||||||||||||||||||||
| 370 | v->x = xs[1].x; | - | ||||||||||||||||||||||||
| 371 | v->u = xs[1].tx; | - | ||||||||||||||||||||||||
| 372 | v->y = ys[0].y; | - | ||||||||||||||||||||||||
| 373 | v->v = ys[0].ty; | - | ||||||||||||||||||||||||
| 374 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 375 | - | |||||||||||||||||||||||||
| 376 | quint16 bottomLeft = index; | - | ||||||||||||||||||||||||
| 377 | for (int k = (isBottom || isLeft ? 2 : 1); k--; ++v, ++index) {
| 0 | ||||||||||||||||||||||||
| 378 | v->x = xs[0].x; | - | ||||||||||||||||||||||||
| 379 | v->u = xs[0].tx; | - | ||||||||||||||||||||||||
| 380 | v->y = ys[1].y; | - | ||||||||||||||||||||||||
| 381 | v->v = ys[1].ty; | - | ||||||||||||||||||||||||
| 382 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 383 | - | |||||||||||||||||||||||||
| 384 | quint16 bottomRight = index; | - | ||||||||||||||||||||||||
| 385 | for (int k = (isBottom || isRight ? 2 : 1); k--; ++v, ++index) {
| 0 | ||||||||||||||||||||||||
| 386 | v->x = xs[1].x; | - | ||||||||||||||||||||||||
| 387 | v->u = xs[1].tx; | - | ||||||||||||||||||||||||
| 388 | v->y = ys[1].y; | - | ||||||||||||||||||||||||
| 389 | v->v = ys[1].ty; | - | ||||||||||||||||||||||||
| 390 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 391 | - | |||||||||||||||||||||||||
| 392 | appendQuad(&indices, topLeft, topRight, bottomLeft, bottomRight); | - | ||||||||||||||||||||||||
| 393 | - | |||||||||||||||||||||||||
| 394 | if (isTop) {
| 0 | ||||||||||||||||||||||||
| 395 | vertices[topLeft].dy = vertices[topRight].dy = topDy; | - | ||||||||||||||||||||||||
| 396 | vertices[topLeft].dv = vertices[topRight].dv = topDv; | - | ||||||||||||||||||||||||
| 397 | vertices[topLeft + 1].dy = vertices[topRight + 1].dy = -delta; | - | ||||||||||||||||||||||||
| 398 | appendQuad(&indices, topLeft + 1, topRight + 1, topLeft, topRight); | - | ||||||||||||||||||||||||
| 399 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 400 | - | |||||||||||||||||||||||||
| 401 | if (isBottom) {
| 0 | ||||||||||||||||||||||||
| 402 | vertices[bottomLeft].dy = vertices[bottomRight].dy = -bottomDy; | - | ||||||||||||||||||||||||
| 403 | vertices[bottomLeft].dv = vertices[bottomRight].dv = -bottomDv; | - | ||||||||||||||||||||||||
| 404 | vertices[bottomLeft + 1].dy = vertices[bottomRight + 1].dy = delta; | - | ||||||||||||||||||||||||
| 405 | appendQuad(&indices, bottomLeft, bottomRight, bottomLeft + 1, bottomRight + 1); | - | ||||||||||||||||||||||||
| 406 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 407 | - | |||||||||||||||||||||||||
| 408 | if (isLeft) {
| 0 | ||||||||||||||||||||||||
| 409 | vertices[topLeft].dx = vertices[bottomLeft].dx = leftDx; | - | ||||||||||||||||||||||||
| 410 | vertices[topLeft].du = vertices[bottomLeft].du = leftDu; | - | ||||||||||||||||||||||||
| 411 | vertices[topLeft + 1].dx = vertices[bottomLeft + 1].dx = -delta; | - | ||||||||||||||||||||||||
| 412 | appendQuad(&indices, topLeft + 1, topLeft, bottomLeft + 1, bottomLeft); | - | ||||||||||||||||||||||||
| 413 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 414 | - | |||||||||||||||||||||||||
| 415 | if (isRight) {
| 0 | ||||||||||||||||||||||||
| 416 | vertices[topRight].dx = vertices[bottomRight].dx = -rightDx; | - | ||||||||||||||||||||||||
| 417 | vertices[topRight].du = vertices[bottomRight].du = -rightDu; | - | ||||||||||||||||||||||||
| 418 | vertices[topRight + 1].dx = vertices[bottomRight + 1].dx = delta; | - | ||||||||||||||||||||||||
| 419 | appendQuad(&indices, topRight, topRight + 1, bottomRight, bottomRight + 1); | - | ||||||||||||||||||||||||
| 420 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 421 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 422 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 423 | - | |||||||||||||||||||||||||
| 424 | Q_ASSERT(index == g->vertexCount()); | - | ||||||||||||||||||||||||
| 425 | Q_ASSERT(indices - g->indexCount() == g->indexData()); | - | ||||||||||||||||||||||||
| 426 | } else { never executed: end of block | 0 | ||||||||||||||||||||||||
| 427 | if (!geometry) {
| 2-70 | ||||||||||||||||||||||||
| 428 | geometry = new QSGGeometry(QSGGeometry::defaultAttributes_TexturedPoint2D(), | - | ||||||||||||||||||||||||
| 429 | hCells * vCells * 4, hCells * vCells * 6, | - | ||||||||||||||||||||||||
| 430 | QSGGeometry::UnsignedShortType); | - | ||||||||||||||||||||||||
| 431 | } else { executed 2 times by 1 test: end of blockExecuted by:
| 2 | ||||||||||||||||||||||||
| 432 | geometry->allocate(hCells * vCells * 4, hCells * vCells * 6); | - | ||||||||||||||||||||||||
| 433 | } executed 70 times by 2 tests: end of blockExecuted by:
| 70 | ||||||||||||||||||||||||
| 434 | geometry->setDrawingMode(QSGGeometry::DrawTriangles); | - | ||||||||||||||||||||||||
| 435 | QSGGeometry::TexturedPoint2D *vertices = geometry->vertexDataAsTexturedPoint2D(); | - | ||||||||||||||||||||||||
| 436 | ys = yData.data(); | - | ||||||||||||||||||||||||
| 437 | for (int j = 0; j < vCells; ++j, ys += 2) {
| 72-216 | ||||||||||||||||||||||||
| 438 | xs = xData.data(); | - | ||||||||||||||||||||||||
| 439 | for (int i = 0; i < hCells; ++i, xs += 2) {
| 216-636 | ||||||||||||||||||||||||
| 440 | vertices[0].x = vertices[2].x = xs[0].x; | - | ||||||||||||||||||||||||
| 441 | vertices[0].tx = vertices[2].tx = xs[0].tx; | - | ||||||||||||||||||||||||
| 442 | vertices[1].x = vertices[3].x = xs[1].x; | - | ||||||||||||||||||||||||
| 443 | vertices[1].tx = vertices[3].tx = xs[1].tx; | - | ||||||||||||||||||||||||
| 444 | - | |||||||||||||||||||||||||
| 445 | vertices[0].y = vertices[1].y = ys[0].y; | - | ||||||||||||||||||||||||
| 446 | vertices[0].ty = vertices[1].ty = ys[0].ty; | - | ||||||||||||||||||||||||
| 447 | vertices[2].y = vertices[3].y = ys[1].y; | - | ||||||||||||||||||||||||
| 448 | vertices[2].ty = vertices[3].ty = ys[1].ty; | - | ||||||||||||||||||||||||
| 449 | - | |||||||||||||||||||||||||
| 450 | vertices += 4; | - | ||||||||||||||||||||||||
| 451 | } executed 636 times by 2 tests: end of blockExecuted by:
| 636 | ||||||||||||||||||||||||
| 452 | } executed 216 times by 2 tests: end of blockExecuted by:
| 216 | ||||||||||||||||||||||||
| 453 | - | |||||||||||||||||||||||||
| 454 | quint16 *indices = geometry->indexDataAsUShort(); | - | ||||||||||||||||||||||||
| 455 | for (int i = 0; i < 4 * vCells * hCells; i += 4)
| 72-636 | ||||||||||||||||||||||||
| 456 | appendQuad(&indices, i, i + 1, i + 2, i + 3); executed 636 times by 2 tests: appendQuad(&indices, i, i + 1, i + 2, i + 3);Executed by:
| 636 | ||||||||||||||||||||||||
| 457 | } executed 72 times by 2 tests: end of blockExecuted by:
| 72 | ||||||||||||||||||||||||
| 458 | return geometry; executed 72 times by 2 tests: return geometry;Executed by:
| 72 | ||||||||||||||||||||||||
| 459 | } | - | ||||||||||||||||||||||||
| 460 | - | |||||||||||||||||||||||||
| 461 | void QSGBasicInternalImageNode::updateGeometry() | - | ||||||||||||||||||||||||
| 462 | { | - | ||||||||||||||||||||||||
| 463 | Q_ASSERT(!m_targetRect.isEmpty()); | - | ||||||||||||||||||||||||
| 464 | const QSGTexture *t = materialTexture(); | - | ||||||||||||||||||||||||
| 465 | if (!t) {
| 0-5280 | ||||||||||||||||||||||||
| 466 | QSGGeometry *g = geometry(); | - | ||||||||||||||||||||||||
| 467 | g->allocate(4); | - | ||||||||||||||||||||||||
| 468 | g->setDrawingMode(QSGGeometry::DrawTriangleStrip); | - | ||||||||||||||||||||||||
| 469 | memset(g->vertexData(), 0, g->sizeOfVertex() * 4); | - | ||||||||||||||||||||||||
| 470 | } else { never executed: end of block | 0 | ||||||||||||||||||||||||
| 471 | QRectF sourceRect = t->normalizedTextureSubRect(); | - | ||||||||||||||||||||||||
| 472 | - | |||||||||||||||||||||||||
| 473 | QRectF innerSourceRect(sourceRect.x() + m_innerSourceRect.x() * sourceRect.width(), | - | ||||||||||||||||||||||||
| 474 | sourceRect.y() + m_innerSourceRect.y() * sourceRect.height(), | - | ||||||||||||||||||||||||
| 475 | m_innerSourceRect.width() * sourceRect.width(), | - | ||||||||||||||||||||||||
| 476 | m_innerSourceRect.height() * sourceRect.height()); | - | ||||||||||||||||||||||||
| 477 | - | |||||||||||||||||||||||||
| 478 | bool hasMargins = m_targetRect != m_innerTargetRect; | - | ||||||||||||||||||||||||
| 479 | - | |||||||||||||||||||||||||
| 480 | int floorLeft = qFloor(m_subSourceRect.left()); | - | ||||||||||||||||||||||||
| 481 | int ceilRight = qCeil(m_subSourceRect.right()); | - | ||||||||||||||||||||||||
| 482 | int floorTop = qFloor(m_subSourceRect.top()); | - | ||||||||||||||||||||||||
| 483 | int ceilBottom = qCeil(m_subSourceRect.bottom()); | - | ||||||||||||||||||||||||
| 484 | int hTiles = ceilRight - floorLeft; | - | ||||||||||||||||||||||||
| 485 | int vTiles = ceilBottom - floorTop; | - | ||||||||||||||||||||||||
| 486 | - | |||||||||||||||||||||||||
| 487 | bool hasTiles = hTiles != 1 || vTiles != 1;
| 4-5274 | ||||||||||||||||||||||||
| 488 | bool fullTexture = innerSourceRect == QRectF(0, 0, 1, 1); | - | ||||||||||||||||||||||||
| 489 | - | |||||||||||||||||||||||||
| 490 | // An image can be rendered as a single quad if: | - | ||||||||||||||||||||||||
| 491 | // - There are no margins, and either: | - | ||||||||||||||||||||||||
| 492 | // - the image isn't repeated | - | ||||||||||||||||||||||||
| 493 | // - the source rectangle fills the entire texture so that texture wrapping can be used, | - | ||||||||||||||||||||||||
| 494 | // and NPOT is supported | - | ||||||||||||||||||||||||
| 495 | if (!hasMargins && (!hasTiles || (fullTexture && supportsWrap(t->textureSize())))) {
| 0-5210 | ||||||||||||||||||||||||
| 496 | QRectF sr; | - | ||||||||||||||||||||||||
| 497 | if (!fullTexture) {
| 263-4947 | ||||||||||||||||||||||||
| 498 | sr = QRectF(innerSourceRect.x() + (m_subSourceRect.left() - floorLeft) * innerSourceRect.width(), | - | ||||||||||||||||||||||||
| 499 | innerSourceRect.y() + (m_subSourceRect.top() - floorTop) * innerSourceRect.height(), | - | ||||||||||||||||||||||||
| 500 | m_subSourceRect.width() * innerSourceRect.width(), | - | ||||||||||||||||||||||||
| 501 | m_subSourceRect.height() * innerSourceRect.height()); | - | ||||||||||||||||||||||||
| 502 | } else { executed 4947 times by 9 tests: end of blockExecuted by:
| 4947 | ||||||||||||||||||||||||
| 503 | sr = QRectF(m_subSourceRect.left() - floorLeft, m_subSourceRect.top() - floorTop, | - | ||||||||||||||||||||||||
| 504 | m_subSourceRect.width(), m_subSourceRect.height()); | - | ||||||||||||||||||||||||
| 505 | } executed 263 times by 5 tests: end of blockExecuted by:
| 263 | ||||||||||||||||||||||||
| 506 | if (m_mirror) {
| 22-5188 | ||||||||||||||||||||||||
| 507 | qreal oldLeft = sr.left(); | - | ||||||||||||||||||||||||
| 508 | sr.setLeft(sr.right()); | - | ||||||||||||||||||||||||
| 509 | sr.setRight(oldLeft); | - | ||||||||||||||||||||||||
| 510 | } executed 22 times by 2 tests: end of blockExecuted by:
| 22 | ||||||||||||||||||||||||
| 511 | - | |||||||||||||||||||||||||
| 512 | if (m_antialiasing) {
| 0-5210 | ||||||||||||||||||||||||
| 513 | QSGGeometry *g = geometry(); | - | ||||||||||||||||||||||||
| 514 | Q_ASSERT(g != &m_geometry); | - | ||||||||||||||||||||||||
| 515 | g->allocate(8, 14); | - | ||||||||||||||||||||||||
| 516 | g->setDrawingMode(QSGGeometry::DrawTriangleStrip); | - | ||||||||||||||||||||||||
| 517 | SmoothVertex *vertices = reinterpret_cast<SmoothVertex *>(g->vertexData()); | - | ||||||||||||||||||||||||
| 518 | float delta = float(qAbs(m_targetRect.width()) < qAbs(m_targetRect.height()) | - | ||||||||||||||||||||||||
| 519 | ? m_targetRect.width() : m_targetRect.height()) * 0.5f; | - | ||||||||||||||||||||||||
| 520 | float sx = float(sr.width() / m_targetRect.width()); | - | ||||||||||||||||||||||||
| 521 | float sy = float(sr.height() / m_targetRect.height()); | - | ||||||||||||||||||||||||
| 522 | for (int d = -1; d <= 1; d += 2) {
| 0 | ||||||||||||||||||||||||
| 523 | for (int j = 0; j < 2; ++j) {
| 0 | ||||||||||||||||||||||||
| 524 | for (int i = 0; i < 2; ++i, ++vertices) {
| 0 | ||||||||||||||||||||||||
| 525 | vertices->x = m_targetRect.x() + i * m_targetRect.width(); | - | ||||||||||||||||||||||||
| 526 | vertices->y = m_targetRect.y() + j * m_targetRect.height(); | - | ||||||||||||||||||||||||
| 527 | vertices->u = sr.x() + i * sr.width(); | - | ||||||||||||||||||||||||
| 528 | vertices->v = sr.y() + j * sr.height(); | - | ||||||||||||||||||||||||
| 529 | vertices->dx = (i == 0 ? delta : -delta) * d;
| 0 | ||||||||||||||||||||||||
| 530 | vertices->dy = (j == 0 ? delta : -delta) * d;
| 0 | ||||||||||||||||||||||||
| 531 | vertices->du = (d < 0 ? 0 : vertices->dx * sx);
| 0 | ||||||||||||||||||||||||
| 532 | vertices->dv = (d < 0 ? 0 : vertices->dy * sy);
| 0 | ||||||||||||||||||||||||
| 533 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 534 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 535 | } never executed: end of block | 0 | ||||||||||||||||||||||||
| 536 | Q_ASSERT(vertices - g->vertexCount() == g->vertexData()); | - | ||||||||||||||||||||||||
| 537 | static const quint16 indices[] = { | - | ||||||||||||||||||||||||
| 538 | 0, 4, 1, 5, 3, 7, 2, 6, 0, 4, | - | ||||||||||||||||||||||||
| 539 | 4, 6, 5, 7 | - | ||||||||||||||||||||||||
| 540 | }; | - | ||||||||||||||||||||||||
| 541 | Q_ASSERT(g->sizeOfIndex() * g->indexCount() == sizeof(indices)); | - | ||||||||||||||||||||||||
| 542 | memcpy(g->indexDataAsUShort(), indices, sizeof(indices)); | - | ||||||||||||||||||||||||
| 543 | } else { never executed: end of block | 0 | ||||||||||||||||||||||||
| 544 | m_geometry.allocate(4); | - | ||||||||||||||||||||||||
| 545 | m_geometry.setDrawingMode(QSGGeometry::DrawTriangleStrip); | - | ||||||||||||||||||||||||
| 546 | QSGGeometry::updateTexturedRectGeometry(&m_geometry, m_targetRect, sr); | - | ||||||||||||||||||||||||
| 547 | } executed 5210 times by 10 tests: end of blockExecuted by:
| 5210 | ||||||||||||||||||||||||
| 548 | } else { | - | ||||||||||||||||||||||||
| 549 | QSGGeometry *g = m_antialiasing ? geometry() : &m_geometry;
| 0-70 | ||||||||||||||||||||||||
| 550 | updateGeometry(m_targetRect, m_innerTargetRect, | - | ||||||||||||||||||||||||
| 551 | sourceRect, innerSourceRect, m_subSourceRect, | - | ||||||||||||||||||||||||
| 552 | g, m_mirror, m_antialiasing); | - | ||||||||||||||||||||||||
| 553 | } executed 70 times by 2 tests: end of blockExecuted by:
| 70 | ||||||||||||||||||||||||
| 554 | } | - | ||||||||||||||||||||||||
| 555 | markDirty(DirtyGeometry); | - | ||||||||||||||||||||||||
| 556 | m_dirtyGeometry = false; | - | ||||||||||||||||||||||||
| 557 | } executed 5280 times by 10 tests: end of blockExecuted by:
| 5280 | ||||||||||||||||||||||||
| 558 | - | |||||||||||||||||||||||||
| 559 | QT_END_NAMESPACE | - | ||||||||||||||||||||||||
| Source code | Switch to Preprocessed file |