mirror of
https://github.com/zoriya/noctalia-shell.git
synced 2025-12-06 06:36:15 +00:00
70 lines
1.9 KiB
QML
70 lines
1.9 KiB
QML
import QtQuick
|
|
import QtQuick.Effects
|
|
import Quickshell
|
|
import Quickshell.Widgets
|
|
import qs.Commons
|
|
|
|
Item {
|
|
id: root
|
|
|
|
property real radius: 0
|
|
property string imagePath: ""
|
|
property string fallbackIcon: ""
|
|
property real fallbackIconSize: Style.fontSizeXXL
|
|
property real borderWidth: 0
|
|
property color borderColor: Color.transparent
|
|
property int imageFillMode: Image.PreserveAspectCrop
|
|
|
|
readonly property bool showFallback: (fallbackIcon !== undefined && fallbackIcon !== "") && (imagePath === undefined || imagePath === "")
|
|
|
|
signal statusChanged(int status)
|
|
|
|
Rectangle {
|
|
anchors.fill: parent
|
|
radius: root.radius
|
|
color: Color.transparent
|
|
border.width: root.borderWidth
|
|
border.color: root.borderColor
|
|
|
|
Image {
|
|
id: imageSource
|
|
anchors.fill: parent
|
|
anchors.margins: root.borderWidth
|
|
visible: false
|
|
source: root.imagePath
|
|
mipmap: true
|
|
smooth: true
|
|
asynchronous: true
|
|
antialiasing: true
|
|
fillMode: root.imageFillMode
|
|
onStatusChanged: root.statusChanged(status)
|
|
}
|
|
|
|
ShaderEffect {
|
|
anchors.fill: parent
|
|
anchors.margins: root.borderWidth
|
|
visible: !root.showFallback
|
|
property variant source: imageSource
|
|
property real itemWidth: width
|
|
property real itemHeight: height
|
|
property real sourceWidth: imageSource.sourceSize.width
|
|
property real sourceHeight: imageSource.sourceSize.height
|
|
property real cornerRadius: Math.max(0, root.radius - root.borderWidth)
|
|
property real imageOpacity: 1.0
|
|
property int fillMode: root.imageFillMode
|
|
|
|
fragmentShader: Qt.resolvedUrl(Quickshell.shellDir + "/Shaders/qsb/rounded_image.frag.qsb")
|
|
supportsAtlasTextures: false
|
|
blending: true
|
|
}
|
|
|
|
NIcon {
|
|
anchors.fill: parent
|
|
anchors.margins: root.borderWidth
|
|
visible: root.showFallback
|
|
icon: root.fallbackIcon
|
|
pointSize: root.fallbackIconSize
|
|
}
|
|
}
|
|
}
|