@SuhasKrishanamurthy, thanks for your help, but the GridView component has fixed cell's width and height. Items' height can grow up, but if it will be greater than cell's size, the collision occures. If I adjusted GridView's cell size depending on size of largest item, there were too much free space between small items. The following code lays items out with collision:
GridView {
id: gridView
width: 600
height: 400
cellWidth: 200
cellHeight: 100
flow: GridView.FlowTopToBottom
model: ListModel {
ListElement {
value: "Lorem ipsum dolor sit amet, consectetur adipiscing elit"
}
ListElement {
value: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
ListElement {
value: "Lorem ipsum dolor sit amet"
}
}
// orientation: Qt.Horizontal // GridView doesn't have this property
boundsBehavior: Flickable.StopAtBounds
clip: true
delegate: Item {
width: gridView.cellWidth
height: contentItem.implicitHeight
required property string value
Rectangle {
id: contentItem
width: parent.width
color: "lightgray"
implicitHeight: tex.implicitHeight + 20
Text {
id: tex
text: value
wrapMode: Text.WordWrap
anchors.margins: 10
anchors.fill: parent
}
}
}
}
[image: 5511da81-8d79-4306-a3e0-805fb1a8683a.png]
The desired behavior is lay items out onto the first column until it has free space and then turn into the next column (see picture in the question). Unfortunately, GridView lays item out strictly as a grid.
This is partially implemented with Flow + Repeater layout:
[image: 0887646e-c6a2-4106-b30c-ff9f8b07a38f.png]