diff options
| author | 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> | 2025-06-02 16:31:26 +0800 |
|---|---|---|
| committer | 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> | 2025-06-02 16:31:26 +0800 |
| commit | 24a3da813862623b3eec05ef5050ba715e08c684 (patch) | |
| tree | 1674c1be77e48befe6e877b421f799deca6c4475 /modules/bar/popouts/Background.qml | |
| parent | osd: fix text not updating during transition (diff) | |
| download | caelestia-shell-24a3da813862623b3eec05ef5050ba715e08c684.tar.gz caelestia-shell-24a3da813862623b3eec05ef5050ba715e08c684.tar.bz2 caelestia-shell-24a3da813862623b3eec05ef5050ba715e08c684.zip | |
feat: bar popouts
Create active window popout
Diffstat (limited to 'modules/bar/popouts/Background.qml')
| -rw-r--r-- | modules/bar/popouts/Background.qml | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/modules/bar/popouts/Background.qml b/modules/bar/popouts/Background.qml new file mode 100644 index 0000000..dd76af8 --- /dev/null +++ b/modules/bar/popouts/Background.qml @@ -0,0 +1,63 @@ +import "root:/services" +import "root:/config" +import QtQuick +import QtQuick.Shapes + +ShapePath { + id: root + + required property Wrapper wrapper + readonly property real rounding: BorderConfig.rounding + readonly property bool flatten: wrapper.width < rounding * 2 + readonly property real roundingX: flatten ? wrapper.width / 2 : rounding + + strokeWidth: -1 + fillColor: BorderConfig.colour + + PathArc { + relativeX: root.roundingX + relativeY: root.rounding + radiusX: Math.min(root.rounding, root.wrapper.width) + radiusY: root.rounding + direction: PathArc.Counterclockwise + } + PathLine { + relativeX: root.wrapper.width - root.roundingX * 2 + relativeY: 0 + } + PathArc { + relativeX: root.roundingX + relativeY: root.rounding + radiusX: Math.min(root.rounding, root.wrapper.width) + radiusY: root.rounding + } + PathLine { + relativeX: 0 + relativeY: root.wrapper.height - root.rounding * 4 + } + PathArc { + relativeX: -root.roundingX + relativeY: root.rounding + radiusX: Math.min(root.rounding, root.wrapper.width) + radiusY: root.rounding + } + PathLine { + relativeX: -(root.wrapper.width - root.roundingX * 2) + relativeY: 0 + } + PathArc { + relativeX: -root.roundingX + relativeY: root.rounding + radiusX: Math.min(root.rounding, root.wrapper.width) + radiusY: root.rounding + direction: PathArc.Counterclockwise + } + + Behavior on fillColor { + ColorAnimation { + duration: Appearance.anim.durations.normal + easing.type: Easing.BezierSpline + easing.bezierCurve: Appearance.anim.curves.standard + } + } +} |