1
0
mirror of https://gitlab.com/kelteseth/ScreenPlay.git synced 2024-10-06 09:17:07 +02:00

Refactor widget Window

it still has a bit of flicker on startup...
This commit is contained in:
Elias Steurer 2022-11-05 14:38:59 +01:00
parent c66b9d4191
commit 712e8113f0
3 changed files with 58 additions and 34 deletions

View File

@ -5,15 +5,20 @@ import ScreenPlayWidget
import ScreenPlay.Enums.InstalledType
Item {
id: mainWindow
anchors.fill: parent
id: root
// We must set a default size not not
// trigger render errors.
width: 200
height: 100
state: "out"
opacity: 0
Connections {
target: Widget
function onQmlExit() {
if (Qt.platform.os === "windows")
Widget.setWindowBlur(0)
loader.source = ""
animFadeOut.start()
}
@ -31,41 +36,29 @@ Item {
Widget.clearComponentCache()
loader.source = Qt.resolvedUrl(Widget.projectSourceFileAbsolute)
}
target: Widget
}
OpacityAnimator {
id: animFadeOut
from: 1
to: 0
target: parent
target: root
duration: 800
easing.type: Easing.InOutQuad
onFinished: Widget.destroyThis()
}
Rectangle {
id: bgColor
anchors.fill: parent
color: "white"
opacity: 0.15
}
Image {
id: bg
source: "qrc:/ScreenPlayWidget/assets/image/noisy-texture-3.png"
id: bgNoise
source: "qrc:/qml/ScreenPlayWidget/assets/image/noisy-texture-3.png"
anchors.fill: parent
opacity: 0.05
fillMode: Image.Tile
opacity: 0
}
Loader {
id: loader
opacity: 0
anchors.fill: parent
asynchronous: true
Component.onCompleted: {
@ -79,17 +72,14 @@ Item {
}
}
onStatusChanged: {
if (loader.status == Loader.Ready) {
if (loader.item.widgetBackground !== undefined)
bgColor.color = loader.item.widgetBackground
if (loader.item.widgetBackgroundOpacity !== undefined)
bgColor.opacity = loader.item.widgetBackgroundOpacity
if (loader.item.widgetWidth !== undefined
&& loader.item.widgetHeight !== undefined)
Widget.setWidgetSize(loader.item.widgetWidth,
loader.item.widgetHeight)
if (loader.status == Loader.Ready && loader.source !== "") {
// Resize to loaded widget size
// Note: We must use implicit* here to not
// break the set values.
root.width = loader.item.implicitWidth
root.height = loader.item.implicitHeight
Widget.show()
root.state = "in"
}
}
}
@ -152,7 +142,7 @@ Item {
Image {
id: imgClose
source: "qrc:/ScreenPlayWidget/assets/icons/baseline-close-24px.svg"
source: "qrc:/qml/ScreenPlayWidget/assets/icons/baseline-close-24px.svg"
anchors.centerIn: parent
opacity: 0.15
@ -185,4 +175,33 @@ Item {
right: parent.right
}
}
states: [
State {
name: "in"
PropertyChanges {
target: root
opacity: 1
}
PropertyChanges {
target: bgNoise
opacity: 0.05
}
PropertyChanges {
target: loader
opacity: 1
}
}
]
transitions: [
Transition {
from: "out"
to: "in"
PropertyAnimation {
targets: [root, bgNoise, loader]
duration: 250
property: "opacity"
}
}
]
}

View File

@ -73,7 +73,6 @@ WidgetWindow::WidgetWindow(
m_window.setResizeMode(QQuickView::ResizeMode::SizeViewToRootObject);
m_window.setSource(QUrl("qrc:/qml/ScreenPlayWidget/qml/Widget.qml"));
m_window.setPosition(m_position);
m_window.show();
// Debug mode means we directly start the ScreenPlayWallpaper for easy debugging.
// This means we do not have a running ScreenPlay instance to connect to.
@ -185,6 +184,11 @@ void WidgetWindow::clearComponentCache()
m_window.engine()->clearComponentCache();
}
void WidgetWindow::show()
{
m_window.show();
}
/*!
\brief This public slot is for QML usage. We limit the change event updates
to every 50ms, because the filesystem can be very trigger happy

View File

@ -110,6 +110,7 @@ public slots:
void setClickPos(const QPoint& clickPos);
void setWidgetSize(const int with, const int height);
void clearComponentCache();
void show();
void setAppID(QString appID)
{