summaryrefslogtreecommitdiff
path: root/plugin/src/Caelestia/beattracker.cpp
diff options
context:
space:
mode:
author2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-09-09 16:31:02 +1000
committer2 * r + 2 * t <61896496+soramanew@users.noreply.github.com>2025-09-09 16:31:02 +1000
commit6ae1a8e811f72bda251f8718fb148fcb6853bcc4 (patch)
tree4b4018628c9cc32a7f43a4a0d17b091eb852db2c /plugin/src/Caelestia/beattracker.cpp
parentnix: fix build error with libcava (#585) (diff)
downloadcaelestia-shell-6ae1a8e811f72bda251f8718fb148fcb6853bcc4.tar.gz
caelestia-shell-6ae1a8e811f72bda251f8718fb148fcb6853bcc4.tar.bz2
caelestia-shell-6ae1a8e811f72bda251f8718fb148fcb6853bcc4.zip
plugin/ac: not singleton
Also add nodeId prop BeatTracker not singleton Move BeatTracker and Cava to Audio service
Diffstat (limited to 'plugin/src/Caelestia/beattracker.cpp')
-rw-r--r--plugin/src/Caelestia/beattracker.cpp50
1 files changed, 41 insertions, 9 deletions
diff --git a/plugin/src/Caelestia/beattracker.cpp b/plugin/src/Caelestia/beattracker.cpp
index a23d052..501739f 100644
--- a/plugin/src/Caelestia/beattracker.cpp
+++ b/plugin/src/Caelestia/beattracker.cpp
@@ -6,20 +6,52 @@
namespace caelestia {
-BeatProcessor::BeatProcessor(QObject* parent)
- : AudioProcessor(parent)
- , m_tempo(new_aubio_tempo("default", 1024, m_chunkSize, m_sampleRate))
- , m_in(new_fvec(m_chunkSize))
- , m_out(new_fvec(2)) {};
+BeatProcessor::BeatProcessor(AudioCollector* collector, QObject* parent)
+ : AudioProcessor(collector, parent)
+ , m_tempo(nullptr)
+ , m_in(nullptr)
+ , m_out(new_fvec(2)) {
+ if (collector) {
+ m_tempo = new_aubio_tempo("default", 1024, collector->chunkSize(), collector->sampleRate());
+ m_in = new_fvec(collector->chunkSize());
+ }
+};
BeatProcessor::~BeatProcessor() {
- del_aubio_tempo(m_tempo);
- del_fvec(m_in);
+ if (m_tempo) {
+ del_aubio_tempo(m_tempo);
+ }
+ if (m_in) {
+ del_fvec(m_in);
+ }
del_fvec(m_out);
}
+void BeatProcessor::setCollector(AudioCollector* collector) {
+ AudioProcessor::setCollector(collector);
+
+ if (m_tempo) {
+ del_aubio_tempo(m_tempo);
+ }
+ if (m_in) {
+ del_fvec(m_in);
+ }
+
+ if (collector) {
+ m_tempo = new_aubio_tempo("default", 1024, collector->chunkSize(), collector->sampleRate());
+ m_in = new_fvec(collector->chunkSize());
+ } else {
+ m_tempo = nullptr;
+ m_in = nullptr;
+ }
+}
+
void BeatProcessor::process() {
- AudioCollector::instance()->readChunk(m_in->data, m_chunkSize);
+ if (!m_collector || !m_tempo || !m_in) {
+ return;
+ }
+
+ m_collector->readChunk(m_in->data);
aubio_tempo_do(m_tempo, m_in, m_out);
if (m_out->data[0] != 0.0f) {
@@ -30,7 +62,7 @@ void BeatProcessor::process() {
BeatTracker::BeatTracker(QObject* parent)
: AudioProvider(parent)
, m_bpm(120) {
- m_processor = new BeatProcessor();
+ m_processor = new BeatProcessor(m_collector);
init();
connect(static_cast<BeatProcessor*>(m_processor), &BeatProcessor::beat, this, &BeatTracker::updateBpm);