diff options
author | Sergio Ahumada <sergio.ahumada@digia.com> | 2013-08-06 16:07:23 +0200 |
---|---|---|
committer | The Qt Project <gerrit-noreply@qt-project.org> | 2013-08-06 18:26:47 +0200 |
commit | f1b9ba8c6ee6b991ef4e513bc4f39045fd55d1e6 (patch) | |
tree | cd587156a07344e98aca0cd1511075fe272bfec5 /tests/auto/quick/qquickflickable | |
parent | 27deff6d2b5a9eb1d98cd7b377ab934a35086664 (diff) | |
parent | 1d3b9db5b54d8ae99c6b149c8d3d91eda19b5838 (diff) |
Merge "Merge branch 'stable' into dev" into refs/staging/dev
Diffstat (limited to 'tests/auto/quick/qquickflickable')
-rw-r--r-- | tests/auto/quick/qquickflickable/data/ratios.qml | 71 | ||||
-rw-r--r-- | tests/auto/quick/qquickflickable/tst_qquickflickable.cpp | 23 |
2 files changed, 94 insertions, 0 deletions
diff --git a/tests/auto/quick/qquickflickable/data/ratios.qml b/tests/auto/quick/qquickflickable/data/ratios.qml new file mode 100644 index 0000000000..1291cada72 --- /dev/null +++ b/tests/auto/quick/qquickflickable/data/ratios.qml @@ -0,0 +1,71 @@ +/**************************************************************************** +** +** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies). +** Contact: http://www.qt-project.org/legal +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** 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 Digia. For licensing terms and +** conditions see http://qt.digia.com/licensing. For further information +** use the contact form at http://qt.digia.com/contact-us. +** +** GNU Lesser General Public License Usage +** Alternatively, this file may be used under the terms of the GNU Lesser +** General Public License version 2.1 as published by the Free Software +** Foundation and appearing in the file LICENSE.LGPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU Lesser General Public License version 2.1 requirements +** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. +** +** In addition, as a special exception, Digia gives you certain additional +** rights. These rights are described in the Digia Qt LGPL Exception +** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3.0 as published by the Free Software +** Foundation and appearing in the file LICENSE.GPL included in the +** packaging of this file. Please review the following information to +** ensure the GNU General Public License version 3.0 requirements will be +** met: http://www.gnu.org/copyleft/gpl.html. +** +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +import QtQuick 2.0 + +Rectangle { + width: 400 + height: 400 + + property bool forceNoFlicking: true + property double heightRatioIs: flickable.visibleArea.heightRatio + property double heightRatioShould: flickable.height / flickable.contentHeight + property double widthRatioIs: flickable.visibleArea.widthRatio + property double widthRatioShould: flickable.height / flickable.contentWidth + + Flickable { + id: flickable + flickableDirection: Flickable.AutoFlickDirection + width: forceNoFlicking ? contentItem.width /* so xflick() returns false */ : 20 + height: forceNoFlicking ? contentItem.height /* likewise */ : 20 + contentHeight: contentItem.height + contentWidth: contentItem.width + clip: true + + Rectangle { + id: contentItem + color: "red" + width: 300 + height: 300 + } + } +} + diff --git a/tests/auto/quick/qquickflickable/tst_qquickflickable.cpp b/tests/auto/quick/qquickflickable/tst_qquickflickable.cpp index 3575dfa012..a8055b3467 100644 --- a/tests/auto/quick/qquickflickable/tst_qquickflickable.cpp +++ b/tests/auto/quick/qquickflickable/tst_qquickflickable.cpp @@ -67,6 +67,7 @@ private slots: void create(); void horizontalViewportSize(); void verticalViewportSize(); + void visibleAreaRatiosUpdate(); void properties(); void boundsBehavior(); void rebound(); @@ -158,6 +159,28 @@ void tst_qquickflickable::verticalViewportSize() delete obj; } +void tst_qquickflickable::visibleAreaRatiosUpdate() +{ + QQmlEngine engine; + QQmlComponent c(&engine, testFileUrl("ratios.qml")); + QQuickItem *obj = qobject_cast<QQuickItem*>(c.create()); + + QVERIFY(obj != 0); + // check initial ratio values + QCOMPARE(obj->property("heightRatioIs").toDouble(), obj->property("heightRatioShould").toDouble()); + QCOMPARE(obj->property("widthRatioIs").toDouble(), obj->property("widthRatioShould").toDouble()); + // change flickable geometry so that flicking is enabled (content size > flickable size) + obj->setProperty("forceNoFlicking", false); + QCOMPARE(obj->property("heightRatioIs").toDouble(), obj->property("heightRatioShould").toDouble()); + QCOMPARE(obj->property("widthRatioIs").toDouble(), obj->property("widthRatioShould").toDouble()); + // change flickable geometry so that flicking is disabled (content size == flickable size) + obj->setProperty("forceNoFlicking", true); + QCOMPARE(obj->property("heightRatioIs").toDouble(), obj->property("heightRatioShould").toDouble()); + QCOMPARE(obj->property("widthRatioIs").toDouble(), obj->property("widthRatioShould").toDouble()); + + delete obj; +} + void tst_qquickflickable::properties() { QQmlEngine engine; |