Files
SweetTokyoNight/kde/look-and-feel/contents/splash/Splash.qml
2019-10-11 13:24:35 -05:00

108 lines
2.6 KiB
QML

import QtQuick 2.5
Image {
id: root
source: "images/background.png"
property int stage
onStageChanged: {
if (stage == 1) {
introAnimation.running = true
}
}
Item {
id: content
anchors.fill: parent
opacity: 0
TextMetrics {
id: units
text: "M"
property int gridUnit: boundingRect.height
property int largeSpacing: units.gridUnit
property int smallSpacing: Math.max(2, gridUnit/4)
}
Image {
id: logo
property real size: units.gridUnit * 12
anchors.centerIn: parent
source: "images/sweetlogo.png"
sourceSize.width: size
sourceSize.height: size
ParallelAnimation {
running: true
ScaleAnimator {
target: logo
from: 0
to: 1
duration: 700
}
SequentialAnimation {
running: true
loops: Animation.Infinite
OpacityAnimator {
target: logo
from: 0.85
to: 1
duration: 1200
}
OpacityAnimator {
target: logo
from: 1
to: 0.85
duration: 1200
}
}
}
}
Image {
id: busyIndicator
y: parent.height - (parent.height - logo.y) / 3 - height/2
anchors.horizontalCenter: parent.horizontalCenter
source: "images/busy.svg"
sourceSize.height: units.gridUnit * 3
sourceSize.width: units.gridUnit * 3
ParallelAnimation{
running: true
ScaleAnimator{
target: busyIndicator
from: 0
to: 1
duration: 800
}
RotationAnimator{
target: busyIndicator
id: rotationAnimator
from: 0
to: 360
duration: 800
loops: Animation.Infinite
}
}
}
}
OpacityAnimator {
id: introAnimation
running: false
target: content
from: 0
to: 1
duration: 1000
easing.type: Easing.InOutQuad
}
}