diff options
-rw-r--r-- | src/extras/text/qdistancefieldglyphcache.cpp | 4 | ||||
-rw-r--r-- | tests/auto/extras/extras.pro | 3 | ||||
-rw-r--r-- | tests/auto/extras/qtext2dentity/qtext2dentity.pro | 13 | ||||
-rw-r--r-- | tests/auto/extras/qtext2dentity/qtext2dentity.qml | 93 | ||||
-rw-r--r-- | tests/auto/extras/qtext2dentity/qtext2dentity.qrc | 5 | ||||
-rw-r--r-- | tests/auto/extras/qtext2dentity/tst_qtext2dentity.cpp | 98 |
6 files changed, 214 insertions, 2 deletions
diff --git a/src/extras/text/qdistancefieldglyphcache.cpp b/src/extras/text/qdistancefieldglyphcache.cpp index 30db3ff4e..a3819b8fe 100644 --- a/src/extras/text/qdistancefieldglyphcache.cpp +++ b/src/extras/text/qdistancefieldglyphcache.cpp @@ -284,7 +284,9 @@ DistanceFieldFont* QDistanceFieldGlyphCache::getOrCreateDistanceFieldFont(const actualFont.setPixelSize(QT_DISTANCEFIELD_BASEFONTSIZE(useDoubleRes) * QT_DISTANCEFIELD_SCALE(useDoubleRes)); // create new font cache - DistanceFieldFont *dff = new DistanceFieldFont(actualFont, useDoubleRes, m_rootNode); + // we set the parent node to nullptr, since the parent node of QTextureAtlasses + // will be set when we pass them to QText2DMaterial later + DistanceFieldFont *dff = new DistanceFieldFont(actualFont, useDoubleRes, nullptr); m_fonts.insert(key, dff); return dff; } diff --git a/tests/auto/extras/extras.pro b/tests/auto/extras/extras.pro index bbdf118b3..e5ae28e97 100644 --- a/tests/auto/extras/extras.pro +++ b/tests/auto/extras/extras.pro @@ -6,5 +6,6 @@ contains(QT_CONFIG, private_tests) { qtorusgeometry \ qforwardrenderer \ qfirstpersoncameracontroller \ - qorbitcameracontroller + qorbitcameracontroller \ + qtext2dentity } diff --git a/tests/auto/extras/qtext2dentity/qtext2dentity.pro b/tests/auto/extras/qtext2dentity/qtext2dentity.pro new file mode 100644 index 000000000..1b8bd0c6f --- /dev/null +++ b/tests/auto/extras/qtext2dentity/qtext2dentity.pro @@ -0,0 +1,13 @@ +TEMPLATE = app + +TARGET = tst_qtext2dentity + +QT += 3dcore 3dcore-private 3dextras 3dquickextras qml testlib + +CONFIG += testcase + +SOURCES += \ + tst_qtext2dentity.cpp + +RESOURCES += qtext2dentity.qrc + diff --git a/tests/auto/extras/qtext2dentity/qtext2dentity.qml b/tests/auto/extras/qtext2dentity/qtext2dentity.qml new file mode 100644 index 000000000..bc699acf6 --- /dev/null +++ b/tests/auto/extras/qtext2dentity/qtext2dentity.qml @@ -0,0 +1,93 @@ +/**************************************************************************** +** +** Copyright (C) 2019 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the Qt3D module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:BSD$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see https://www.qt.io/terms-conditions. For further +** information use the contact form at https://www.qt.io/contact-us. +** +** BSD License Usage +** Alternatively, you may use this file under the terms of the BSD license +** as follows: +** +** "Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are +** met: +** * Redistributions of source code must retain the above copyright +** notice, this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright +** notice, this list of conditions and the following disclaimer in +** the documentation and/or other materials provided with the +** distribution. +** * Neither the name of The Qt Company Ltd nor the names of its +** contributors may be used to endorse or promote products derived +** from this software without specific prior written permission. +** +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE." +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +import Qt3D.Core 2.0 +import Qt3D.Render 2.0 +import Qt3D.Input 2.0 +import Qt3D.Extras 2.9 + +Entity { + id: sceneRoot + property alias text2DEntity: text + Camera { + id: camera + projectionType: CameraLens.PerspectiveProjection + fieldOfView: 45 + aspectRatio: 16/9 + nearPlane : 0.1 + farPlane : 1000.0 + position: Qt.vector3d( 0.0, 0.0, 140.0 ) + upVector: Qt.vector3d( 0.0, 1.0, 0.0 ) + viewCenter: Qt.vector3d( 0.0, 0.0, 0.0 ) + } + + OrbitCameraController { + camera: camera + } + + components: [ + RenderSettings { + activeFrameGraph: ForwardRenderer { + clearColor: Qt.rgba(1, 1, 1, 1) + camera: camera + } + }, + // Event Source will be set by the Qt3DQuickWindow + InputSettings { } + ] + + Text2DEntity { + id: text + text: "foo" + width: 200 + height: 40 + color: "darkgrey" + } +} diff --git a/tests/auto/extras/qtext2dentity/qtext2dentity.qrc b/tests/auto/extras/qtext2dentity/qtext2dentity.qrc new file mode 100644 index 000000000..424d200ae --- /dev/null +++ b/tests/auto/extras/qtext2dentity/qtext2dentity.qrc @@ -0,0 +1,5 @@ +<RCC> + <qresource> + <file>qtext2dentity.qml</file> + </qresource> +</RCC> diff --git a/tests/auto/extras/qtext2dentity/tst_qtext2dentity.cpp b/tests/auto/extras/qtext2dentity/tst_qtext2dentity.cpp new file mode 100644 index 000000000..6fcc2e637 --- /dev/null +++ b/tests/auto/extras/qtext2dentity/tst_qtext2dentity.cpp @@ -0,0 +1,98 @@ +/**************************************************************************** +** +** Copyright (C) 2019 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the Qt3D module of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:BSD$ +** Commercial License Usage +** Licensees holding valid commercial Qt licenses may use this file in +** accordance with the commercial license agreement provided with the +** Software or, alternatively, in accordance with the terms contained in +** a written agreement between you and The Qt Company. For licensing terms +** and conditions see https://www.qt.io/terms-conditions. For further +** information use the contact form at https://www.qt.io/contact-us. +** +** BSD License Usage +** Alternatively, you may use this file under the terms of the BSD license +** as follows: +** +** "Redistribution and use in source and binary forms, with or without +** modification, are permitted provided that the following conditions are +** met: +** * Redistributions of source code must retain the above copyright +** notice, this list of conditions and the following disclaimer. +** * Redistributions in binary form must reproduce the above copyright +** notice, this list of conditions and the following disclaimer in +** the documentation and/or other materials provided with the +** distribution. +** * Neither the name of The Qt Company Ltd nor the names of its +** contributors may be used to endorse or promote products derived +** from this software without specific prior written permission. +** +** +** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE." +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +#include <QtTest/QTest> +#include <Qt3DExtras/QText2DEntity> +#include <Qt3DQuickExtras/qt3dquickwindow.h> +#include <Qt3DQuick/QQmlAspectEngine> +#include <Qt3DCore/private/qnode_p.h> + +QVector<Qt3DCore::QNode *>lookupNodeByClassName(Qt3DCore::QNode *root, const QString &className) +{ + auto children = root->childNodes(); + QVector<Qt3DCore::QNode *> childrenList; + for (auto i : children) { + if (i->metaObject()->className() == className) + childrenList << i; + else + childrenList << lookupNodeByClassName(i, className); + } + return childrenList; +} + +class tst_qtext2dentity : public QObject +{ + Q_OBJECT + +private slots: + void checkChangeArbiter(); +}; + +void tst_qtext2dentity::checkChangeArbiter() +{ +#if !defined(QT_OPENGL_ES_2_ANGLE) + // GIVEN + Qt3DExtras::Quick::Qt3DQuickWindow view; + view.setSource(QUrl("qrc:/qtext2dentity.qml")); + view.show(); + QCoreApplication::processEvents(); + + // THEN + auto rootEntity = view.engine()->aspectEngine()->rootEntity(); + QVERIFY(rootEntity != nullptr); + auto atlases = lookupNodeByClassName(rootEntity.data(), "Qt3DExtras::QTextureAtlas"); + QVERIFY(atlases.length() == 1); + auto atlas = atlases[0]; + QTRY_VERIFY(Qt3DCore::QNodePrivate::get(atlas)->m_changeArbiter); +#endif +} + +QTEST_MAIN(tst_qtext2dentity) +#include "tst_qtext2dentity.moc" |