From c1872c2d77065a9bcfe2f7953436c561f17290a3 Mon Sep 17 00:00:00 2001 From: 2 * r + 2 * t <61896496+soramanew@users.noreply.github.com> Date: Sat, 28 Jun 2025 22:29:46 +1000 Subject: dashboard: optimise cava Use refs to prevent loading at all times --- modules/dashboard/Media.qml | 4 ++++ services/Cava.qml | 6 +++++- widgets/Ref.qml | 9 +++++++++ 3 files changed, 18 insertions(+), 1 deletion(-) create mode 100644 widgets/Ref.qml diff --git a/modules/dashboard/Media.qml b/modules/dashboard/Media.qml index 24f504a..fd36b53 100644 --- a/modules/dashboard/Media.qml +++ b/modules/dashboard/Media.qml @@ -108,6 +108,10 @@ Item { easing.bezierCurve: Appearance.anim.curves.standard } } + + Ref { + service: Cava + } } StyledClippingRect { diff --git a/services/Cava.qml b/services/Cava.qml index 3fa5083..5053984 100644 --- a/services/Cava.qml +++ b/services/Cava.qml @@ -8,12 +8,16 @@ Singleton { id: root property list values + property int refCount Process { running: true command: ["sh", "-c", `printf '[general]\nframerate=60\nbars=${Config.dashboard.visualiserBars}\n[output]\nchannels=mono\nmethod=raw\nraw_target=/dev/stdout\ndata_format=ascii\nascii_max_range=100' | cava -p /dev/stdin`] stdout: SplitParser { - onRead: data => root.values = data.slice(0, -1).split(";").map(v => parseInt(v, 10)) + onRead: data => { + if (root.refCount) + root.values = data.slice(0, -1).split(";").map(v => parseInt(v, 10)); + } } } } diff --git a/widgets/Ref.qml b/widgets/Ref.qml new file mode 100644 index 0000000..679f52f --- /dev/null +++ b/widgets/Ref.qml @@ -0,0 +1,9 @@ +import Quickshell +import QtQuick + +QtObject { + required property Singleton service + + Component.onCompleted: service.refCount++ + Component.onDestruction: service.refCount-- +} -- cgit v1.2.3-freya