mirror of
https://github.com/zhuzichu520/FluentUI.git
synced 2025-01-23 12:24:34 +08:00
49 lines
1.2 KiB
QML
49 lines
1.2 KiB
QML
import QtQuick 2.12
|
|
import QtQuick.Controls 2.12
|
|
|
|
FluRectangle {
|
|
id: control
|
|
|
|
width: 150
|
|
height: 5
|
|
radius: [3,3,3,3]
|
|
clip: true
|
|
color: FluTheme.isDark ? Qt.rgba(41/255,41/255,41/255,1) : Qt.rgba(214/255,214/255,214/255,1)
|
|
property real progress: 0.5
|
|
property bool indeterminate: true
|
|
|
|
Component.onCompleted: {
|
|
if(indeterminate){
|
|
bar.x = -control.width*0.5
|
|
behavior.enabled = true
|
|
bar.x = control.width
|
|
}else{
|
|
bar.x = 0
|
|
}
|
|
}
|
|
|
|
Rectangle{
|
|
id:bar
|
|
radius: 3
|
|
width: control.width*progress
|
|
height: control.height
|
|
color:FluTheme.isDark ? FluTheme.primaryColor.lighter : FluTheme.primaryColor.dark
|
|
|
|
Behavior on x{
|
|
id:behavior
|
|
enabled: false
|
|
NumberAnimation{
|
|
duration: 1000
|
|
onRunningChanged: {
|
|
if(!running){
|
|
behavior.enabled = false
|
|
bar.x = -control.width*0.5
|
|
behavior.enabled = true
|
|
bar.x = control.width
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|