1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
|
// Copyright (C) 2022 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQuick
import QtQuick.Effects
Item {
id: rootItem
// We expect all effects to be placed under ItemSwitcher
property Item switcher: rootItem.parent
anchors.fill: parent
Item {
id: mask
anchors.fill: parent
layer.enabled: true
visible: false
clip: true
Image {
anchors.fill: parent
source: "images/star.png"
scale: switcher.inAnimation * 5
rotation: switcher.outAnimation * 360
}
}
// Item going out
MultiEffect {
source: switcher.fromItem
anchors.fill: parent
maskEnabled: true
maskSource: mask
maskInverted: true
maskThresholdMin: 0.5
maskSpreadAtMin: 0.5
}
// Item coming in
MultiEffect {
source: switcher.toItem
anchors.fill: parent
maskEnabled: true
maskSource: mask
maskThresholdMin: 0.5
maskSpreadAtMin: 0.5
colorizationColor: "#ffd020"
colorization: Math.max(0, 1.0 - switcher.inAnimation * 2)
brightness: Math.max(0.0, 0.8 - switcher.inAnimation * 2)
}
}
|