harbour-fernschreiber/qml/components/ImageThumbnail.qml

98 lines
3 KiB
QML
Raw Normal View History

/*
Copyright (C) 2020 Sebastian J. Wolf
This file is part of Fernschreiber.
Fernschreiber is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Fernschreiber is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Fernschreiber. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.5
import QtGraphicalEffects 1.0
import Sailfish.Silica 1.0
Item {
2020-08-14 12:11:34 +03:00
id: imageThumbnail
property variant imageData;
Image {
Component.onCompleted: {
if (imageData.local.is_downloading_completed) {
singleImage.source = imageData.local.path;
} else {
tdLibWrapper.downloadFile(imageData.id);
}
}
Connections {
target: tdLibWrapper
onFileUpdated: {
if (id === imageData.id) {
console.log("File updated, completed? " + fileInformation.local.is_downloading_completed);
2020-08-14 12:11:34 +03:00
imageThumbnail.imageData = fileInformation;
if (imageThumbnail.imageData.local.is_downloading_completed) {
singleImage.source = imageThumbnail.imageData.local.path;
}
}
}
}
id: singleImage
width: parent.width - Theme.paddingSmall
height: parent.height - Theme.paddingSmall
anchors.centerIn: parent
fillMode: Image.PreserveAspectCrop
autoTransform: true
asynchronous: true
2020-08-14 12:11:34 +03:00
visible: false
}
Rectangle {
id: imageThumbnailMask
width: parent.width - Theme.paddingSmall
height: parent.height - Theme.paddingSmall
color: Theme.primaryColor
radius: parent.width / 7
anchors.centerIn: singleImage
visible: false
}
OpacityMask {
id: maskedThumbnail
source: singleImage
maskSource: imageThumbnailMask
anchors.fill: singleImage
visible: singleImage.status === Image.Ready ? true : false
opacity: singleImage.status === Image.Ready ? 1 : 0
Behavior on opacity { NumberAnimation {} }
}
Image {
id: imageLoadingBackgroundImage
source: "../../images/background" + ( Theme.colorScheme ? "-black" : "-white" ) + ".png"
anchors {
centerIn: parent
}
width: parent.width - 2 * Theme.paddingLarge
height: parent.height - 2 * Theme.paddingLarge
visible: singleImage.status !== Image.Ready
fillMode: Image.PreserveAspectFit
opacity: 0.15
}
}