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
|
// Copyright (C) 2017 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
import QtQuick 2.0
Item {
visible: true
width: 640
height: 480
property ListView listView
Loader {
id: loader
anchors.fill: parent
asynchronous: true
sourceComponent: comp
onStatusChanged: {
if (status == Loader.Ready) {
// Assign the listview to the root prop late, so
// that the c++ part doesn't start before everything is ready.
listView = item.listView
}
}
}
Component {
id: comp
Item {
property alias listView: listView
ListView {
id: listView
model: ListModel {
id: listModel
ListElement { title: "one" }
ListElement { title: "two" }
}
anchors.fill: parent
orientation: ListView.Horizontal
delegate: Item {
id: delegateRoot
objectName: "delegate"
width: 200
height: 200
Component.onCompleted: {
if (index === listModel.count - 1) {
// Add a new item while the outer Loader is still incubating async. If the new model item
// incubates using e.g QQmlIncubator::AsynchronousIfNested, it will also be loaded async, which
// is not currently supported (the item will not be added to the listview, or end up the wrong
// position, depending on its index and the current state of the refill/layout logic in
// QQuickListView).
// We add the new item here at the last delegates Component.onCompleted to hit the point in time
// when the listview is not expecting any more async items. In that case, the item will only be
// added to the list of visible items if incubated synchronously, which gives us something we
// can test for in the auto-test.
listModel.insert(0, {title: "zero"});
}
}
Rectangle {
anchors.fill: parent
border.width: 1
Text {
anchors.centerIn: parent
text: index
}
}
}
}
}
}
}
|