1
0
mirror of https://gitlab.com/kelteseth/ScreenPlay.git synced 2024-09-19 08:52:33 +02:00
ScreenPlay/ScreenPlayWallpaper/qml/MultimediaView.qml
2023-02-02 15:25:26 +01:00

80 lines
2.2 KiB
QML

import QtQuick
import QtMultimedia
import ScreenPlayWallpaper
Item {
id: root
anchors.fill: parent
property bool loops: Wallpaper.loops
property bool isPlaying: Wallpaper.isPlaying
property string fillMode: Wallpaper.fillMode
onFillModeChanged: {
// Convert Web based video modes to the limited Qt fillModes
if (fillMode === "cover" || fillMode === "stretch" || fillMode === "contain") {
return vo.fillMode = VideoOutput.Stretch;
}
if (fillMode === "fill") {
return vo.fillMode = VideoOutput.PreserveAspectFit;
}
if (fillMode === "scale_down") {
return vo.fillMode = VideoOutput.PreserveAspectCrop;
}
}
onIsPlayingChanged: isPlaying ? mediaPlayer.play() : mediaPlayer.pause()
property bool isWindows: Qt.platform.os === "windows"
property bool ready: false
property string source: Wallpaper.projectSourceFileAbsolute
onSourceChanged: {
// Qt 6.3 workaround
mediaPlayer.stop();
mediaPlayer.source = Qt.resolvedUrl(root.source);
mediaPlayer.play();
}
MediaPlayer {
id: mediaPlayer
onPlaybackStateChanged: {
if (mediaPlayer.playbackState == MediaPlayer.PlayingState) {
root.ready = true;
}
}
loops: root.loops ? MediaPlayer.Infinite : 1
videoOutput: vo
audioOutput: ao
}
VideoOutput {
id: vo
anchors.fill: parent
}
AudioOutput {
id: ao
volume: Wallpaper.volume
muted: Wallpaper.muted
}
Connections {
function onFillModeChanged(fillMode) {
if (fillMode === "stretch") {
vo.fillMode = VideoOutput.Stretch;
return;
}
if (fillMode === "fill") {
vo.fillMode = VideoOutput.PreserveAspectFit;
return;
}
if (fillMode === "contain" || fillMode === "cover" || fillMode === "scale-down") {
vo.fillMode = VideoOutput.PreserveAspectCrop;
}
}
function onCurrentTimeChanged(currentTime) {
mediaPlayer.position = currentTime * mediaPlayer.duration;
}
target: Wallpaper
}
}