SwipeDelegate QML Type▲
-
Import Statement: import QtQuick.Controls
-
Inherits:: ItemDelegate
-
Group: SwipeDelegate is part of qtquickcontrols-delegates
I. Detailed Description▲
SwipeDelegate presents a view item that can be swiped left or right to expose more options or information. It is used as a delegate in views such as ListView.
In the following example, SwipeDelegate is used in a ListView to allow items to be removed from it by swiping to the left:
Sélectionnez
ListView
{
id
:
listView
anchors.fill
:
parent
model
:
ListModel
{
ListElement
{
sender
:
"Bob Bobbleton"
; title
:
"How are you going?"
}
ListElement
{
sender
:
"Rug Emporium"
; title
:
"SALE! All rugs MUST go!"
}
ListElement
{
sender
:
"Electric Co."
; title
:
"Electricity bill 15/07/2016 overdue"
}
ListElement
{
sender
:
"Tips"
; title
:
"Five ways this tip will save your life"
}
}
delegate
:
SwipeDelegate {
id
:
swipeDelegate
text
:
sender +
" - "
+
title
width
:
listView.width
required property
string
sender
required property
string
title
required property
int
index
ListView.onRemove
:
SequentialAnimation
{
PropertyAction
{
target
:
swipeDelegate
property
:
"ListView.delayRemove"
value
:
true
}
NumberAnimation
{
target
:
swipeDelegate
property
:
"height"
to
:
0
easing.type
:
Easing.InOutQuad
}
PropertyAction
{
target
:
swipeDelegate
property
:
"ListView.delayRemove"
value
:
false
}
}
swipe.right
:
Label
{
id
:
deleteLabel
text
:
qsTr("Delete"
)
color
:
"white"
verticalAlignment
:
Label.AlignVCenter
padding
:
12
height
:
parent.height
anchors.right
:
parent.right
SwipeDelegate.onClicked
:
listView.model.remove(index
)
background
:
Rectangle
{
color
:
deleteLabel.SwipeDelegate.pressed ? Qt.darker("tomato"
, 1.1) :
"tomato"
}
}