Files
2025-09-28 17:05:51 +08:00

104 lines
2.2 KiB
QML

// Copyright (c) Daniel Gakwaya.
// SPDX-License-Identifier: MIT
import QtQuick
import QtQuick.Window
Window {
visible: true
width: 640
height: 480
title: qsTr("ListView and ListModel Demo")
ListView {
id: mListViewId
anchors.fill: parent
model: mModelId
//delegate: delegateId
delegate: Rectangle {
id: rectangleId
width: parent.width
height: 50
color: "beige"
border.color: "yellowgreen"
radius: 10
Text {
id: textId
anchors.centerIn: parent
font.pointSize: 20
text: country + " : " + capital
}
MouseArea {
anchors.fill: parent
onClicked: {
console.log("Clicked on: "+ capital + ", "+ country)
}
}
}
}
ListModel {
id: mModelId
ListElement {
country: "Rwanda"
capital: "Kigali"
}
ListElement {
country: "Germany"; capital: "Berlin"
}
ListElement {
country: "Japan"; capital: "Tokyo"
}
ListElement {
country :"Nigeria"; capital: "Lagos"
}
ListElement {
country: "Ghana"; capital: "Accra"
}
ListElement {
country: "Kenya"; capital: "Nairobi"
}
ListElement {
country: "India"; capital: "New Delhi"
}
ListElement {
country: "Uganda"; capital: "Kampala"
}
}
Component {
id: delegateId
Rectangle {
id: rectangleId
width: parent.width
height: 50
color: "dodgerblue"
border.color: "black"
radius: 15
Text {
id: textId
anchors.centerIn: parent
font.pointSize: 20
text: country + ": " + capital
}
MouseArea {
anchors.fill: parent
onClicked: {
console.log("Clicked on: "+ capital + ", "+ country)
}
}
}
}
}