Eu tenho um GridLayout preenchido por um Repetidor (um TableView não atender minhas necessidades), dentro de uma Flickable para que eu possa percorrer o conteúdo.
Eu quero o meu GridLayout para ter um cabeçalho, que eu posso facilmente adicionando Text
s antes de minha Repetidor como este:
import QtQuick 2.0
import QtQuick.Layouts 1.12
ColumnLayout {
width: 200
height: 200
Flickable {
Layout.fillWidth: true
Layout.preferredHeight: 200
contentWidth: width
contentHeight: grid.height
clip: true
GridLayout {
id: grid
columns: 3
columnSpacing: 10
function reparentChildren(source, target) {
while (source.children.length) {
source.children[0].parent = target;
}
}
// Header
Text {
text: "Header 0"
}
Text {
text: "Header 1"
}
Text {
text: "Header 2"
}
// Data
Repeater {
model: 50
Item {
Component.onCompleted: grid.reparentChildren(this, grid)
Text {
text: "Column 0, %1".arg(modelData)
}
Text {
text: "Column 1, %1".arg(modelData)
}
Text {
text: "Column 2, %1".arg(modelData)
}
}
}
}
}
}
No entanto, eu gostaria que o meu cabeçalho para ser "pegajoso" / "congelados", isto é, permanecem visíveis durante a rolagem da Flickable. Eu posso criar meu cabeçalho fora do Flickable, no entanto, o GridLayout não me dá a linha final tamanhos, por isso eu não posso posição do meu cabeçalho textos.