C

Qt Cluster: Rendering and Recovery from Main UI Failure

// Copyright (C) 2023 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause

// This file is part of the Qt Safe Renderer module

import QtQuick
import QtMultimedia
import ClusterDemo

Item {
    property alias imageSource: overlay.source

    visible: true

    /* TODO replace with image */
    MediaPlayer {
        id: video
        autoPlay: false
        muted: true
        //source: "file:///data/user/qt/qtcluster/video/reversing_video.3gp"
        // Switch to still image after reversing video is finished, or an error occurs
        onError: {
            stillView.visible = true
            console.log("Error playing video: " + error + ": " + errorString)
        }
        onStatusChanged: {
            if (status === MediaPlayer.EndOfMedia)
                stillView.visible = true
        }
    }

    VideoOutput {
        id: videoOutput

        source: video //camera
        anchors.centerIn: parent
        height: 480 - 180
        width: 1280 / 2.1
        fillMode: Image.Stretch

        Image {
            id: stillView
            visible: false
            anchors.centerIn: parent
            source: "image://etc/RearCameraStill.jpg"
            height: videoOutput.height
            width: videoOutput.width
        }

        Image {
            id: overlay
            visible: ValueSource.gear === -1
            anchors.horizontalCenter: parent.horizontalCenter
            anchors.bottom: parent.bottom
        }
    }

    onVisibleChanged: {
        if (visible) {
            stillView.visible = false
            video.play()

        } else {
            video.stop()
        }
    }
}