1
0
mirror of https://gitlab.com/kelteseth/ScreenPlay.git synced 2024-11-13 22:42:51 +01:00
ScreenPlay/ScreenPlayWorkshop/qml/Background.qml
2022-05-01 20:20:57 +02:00

224 lines
4.8 KiB
QML

import QtQuick
import Qt5Compat.GraphicalEffects
Rectangle {
id: root
property string backgroundImage: ""
property int imageOffsetTop: 0
property int stackViewDepth: 0
onStackViewDepthChanged: {
if (stackViewDepth > 1) {
root.state = "backgroundBlur"
return true
}
root.state = "backgroundImage"
return false
}
color: "#161C1D"
onImageOffsetTopChanged: {
if ((imageOffsetTop * -1) >= 200) {
root.state = "backgroundColor"
} else {
if (root.state !== "backgroundImage")
root.state = "backgroundImage"
}
}
onBackgroundImageChanged: {
if (backgroundImage === "")
root.state = ""
else
root.state = "backgroundImage"
}
Image {
id: maskSource
visible: false
source: "qrc:/qml/ScreenPlayWorkshop/assets/images/mask_workshop.png"
}
Image {
id: bgImage
height: bgImage.sourceSize.height
//fillMode: Image.PreserveAspectCrop
opacity: 0
source: root.backgroundImage
anchors {
topMargin: root.imageOffsetTop
top: parent.top
right: parent.right
left: parent.left
}
LinearGradient {
id: gradient
anchors.fill: parent
z: 4
gradient: Gradient {
GradientStop {
position: 0
color: "#00ffffff"
}
GradientStop {
position: 0.6
color: "#00ffffff"
}
GradientStop {
position: 1
color: "#161C1D"
}
}
}
}
FastBlur {
id: blur
anchors.fill: bgImage
source: bgImage
radius: 16
cached: true
opacity: 0
}
Rectangle {
id: bgColor
color: "#161C1D"
opacity: 0
anchors.fill: parent
}
states: [
State {
name: ""
PropertyChanges {
target: bgImage
opacity: 0
}
PropertyChanges {
target: bgColor
opacity: 0
}
PropertyChanges {
target: blur
opacity: 0
}
},
State {
name: "backgroundImage"
PropertyChanges {
target: bgImage
opacity: 1
}
PropertyChanges {
target: bgColor
opacity: 0
}
PropertyChanges {
target: blur
opacity: 0
radius: 16
}
},
State {
name: "backgroundColor"
PropertyChanges {
target: bgImage
opacity: 1
}
PropertyChanges {
target: bgColor
opacity: 0.8
}
PropertyChanges {
target: blur
opacity: 1
radius: 16
}
},
State {
name: "backgroundBlur"
PropertyChanges {
target: bgImage
opacity: 1
}
PropertyChanges {
target: bgColor
opacity: 0.85
}
PropertyChanges {
target: blur
opacity: 1
radius: 64
}
}
]
transitions: [
Transition {
from: ""
to: "backgroundImage"
reversible: true
PropertyAnimation {
targets: [bgImage, bgColor, blur]
duration: 500
easing.type: Easing.InOutQuart
property: "opacity"
}
},
Transition {
from: "backgroundImage"
to: "backgroundColor"
reversible: true
PropertyAnimation {
targets: [bgImage, bgColor, blur]
duration: 200
easing.type: Easing.InOutQuart
property: "opacity"
}
},
Transition {
from: "backgroundImage"
to: "backgroundBlur"
reversible: true
PropertyAnimation {
targets: [bgImage, bgColor, blur]
duration: 300
easing.type: Easing.InOutQuart
property: "opacity"
}
PropertyAnimation {
target: blur
duration: 300
easing.type: Easing.InOutQuart
property: "radius"
}
}
]
}