diff options
Diffstat (limited to 'tests/manual/pointer/rubberbandOnTable.qml')
-rw-r--r-- | tests/manual/pointer/rubberbandOnTable.qml | 86 |
1 files changed, 86 insertions, 0 deletions
diff --git a/tests/manual/pointer/rubberbandOnTable.qml b/tests/manual/pointer/rubberbandOnTable.qml new file mode 100644 index 0000000000..177568d41e --- /dev/null +++ b/tests/manual/pointer/rubberbandOnTable.qml @@ -0,0 +1,86 @@ +/**************************************************************************** +** +** Copyright (C) 2019 The Qt Company Ltd. +** Contact: https://www.qt.io/licensing/ +** +** This file is part of the manual tests of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:GPL-EXCEPT$ +** 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. +** +** GNU General Public License Usage +** Alternatively, this file may be used under the terms of the GNU +** General Public License version 3 as published by the Free Software +** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT +** included in the packaging of this file. Please review the following +** information to ensure the GNU General Public License requirements will +** be met: https://www.gnu.org/licenses/gpl-3.0.html. +** +** $QT_END_LICENSE$ +** +****************************************************************************/ + +import QtQuick 2.12 + +TableView { + id: root + objectName: "root" + width: 480 + height: 480 + columnSpacing: 2 + rowSpacing: 2 + // TODO use TableModel when it's ready, to test with multiple columns + model: 10 + + delegate: Rectangle { + id: tableDelegate + objectName: "itemview delegate" + color: delegateTap.pressed ? "wheat" : "beige" + implicitWidth: 200 + implicitHeight: 140 + + Rectangle { + objectName: "button" + anchors.centerIn: parent + border.color: "tomato" + border.width: 10 + color: buttonTap.pressed ? "goldenrod" : "beige" + width: 100 + height: 100 + TapHandler { + id: buttonTap + objectName: "buttonTap" + } + } + + TapHandler { + id: delegateTap + objectName: "delegateTap" + } + } + + DragHandler { + id: rubberBandDrag + objectName: "rubberBandDrag" + target: null + acceptedDevices: PointerDevice.Mouse + } + Rectangle { + visible: rubberBandDrag.active + x: Math.min(rubberBandDrag.centroid.position.x, rubberBandDrag.centroid.pressPosition.x) + y: Math.min(rubberBandDrag.centroid.position.y, rubberBandDrag.centroid.pressPosition.y) + width: Math.abs(rubberBandDrag.centroid.position.x - rubberBandDrag.centroid.pressPosition.x) + height: Math.abs(rubberBandDrag.centroid.position.y - rubberBandDrag.centroid.pressPosition.y) + color: "transparent" + border.color: "black" + z: 1000 + } + + Component.onCompleted: contentItem.objectName = "TableView's contentItem" +} |