1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
// Copyright (C) 2019 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
import QtQuick 2.14
import QtQml.Models 2.14
Item {
id: root
width: 400
height: 400
readonly property int rectCount: 3
property var rectColors: ["red", "green", "blue"]
property alias listView1: listView1
property alias listView2: listView2
function moveRedRectToModel2() {
var appItem = objectModel1.get(0)
objectModel1.remove(0, 1)
objectModel2.insert(0, appItem)
}
function moveRedRectToModel1() {
var appItem = objectModel2.get(0)
objectModel2.remove(0, 1)
objectModel1.insert(0, appItem)
}
ObjectModel {
id: objectModel1
objectName: "objectModel1"
Component.onCompleted: {
for (var i = 0; i < root.rectCount; i++) {
var outerRect = rectComponent.createObject(null, {
"objectName": root.rectColors[i] + "Rect",
"color": root.rectColors[i]
})
objectModel1.append(outerRect)
}
}
}
ObjectModel {
id: objectModel2
objectName: "objectModel2"
}
ListView {
id: listView1
objectName: "listView1"
anchors.left: parent.left
anchors.top: parent.top
height: 100
width: 100
anchors.margins: 20
clip: true
cacheBuffer: 0
model: objectModel1
orientation: ListView.Horizontal
spacing: 20
Component.onCompleted: contentItem.objectName = "listView1ContentItem"
}
ListView {
id: listView2
objectName: "listView2"
anchors.right: parent.right
anchors.top: parent.top
height: 100
width: 100
anchors.margins: 20
clip: true
cacheBuffer: 0
model: objectModel2
orientation: ListView.Horizontal
spacing: 20
Component.onCompleted: contentItem.objectName = "listView2ContentItem"
}
Component {
id: rectComponent
Rectangle {
height: 100
width: 100
opacity: 0.2
}
}
}
|