blob: 6d7b1c4e21eacd3e3f1e015a2dd7b5f88a92585b (
plain)
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 BSD-3-Clause
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
}
}
}
|