]> git.sesse.net Git - nageru/commitdiff
Split VUMeter into a left and right side, so one can (optionally) have stereo meters.
authorSteinar H. Gunderson <sgunderson@bigfoot.com>
Sun, 28 Aug 2016 15:20:39 +0000 (17:20 +0200)
committerSteinar H. Gunderson <sgunderson@bigfoot.com>
Wed, 19 Oct 2016 22:55:44 +0000 (00:55 +0200)
vumeter.cpp
vumeter.h

index 08ac1da684c3c479b5c58a4759fdb25e8602d51a..50f0f143f7e575d03f8e0810130cad28da010424 100644 (file)
@@ -19,27 +19,34 @@ void VUMeter::paintEvent(QPaintEvent *event)
 {
        QPainter painter(this);
 
-       float level_lufs;
+       float level_lufs[2];
        {
                unique_lock<mutex> lock(level_mutex);
-               level_lufs = this->level_lufs;
+               level_lufs[0] = this->level_lufs[0];
+               level_lufs[1] = this->level_lufs[1];
        }
 
-       float level_lu = level_lufs - ref_level_lufs;
-       int on_pos = lrint(lufs_to_pos(level_lu, height()));
+       int mid = width() / 2;
 
-       if (flip) {
-               QRect on_rect(0, 0, width(), height() - on_pos);
-               QRect off_rect(0, height() - on_pos, width(), height());
+       for (unsigned channel = 0; channel < 2; ++channel) {
+               int left = (channel == 0) ? 0 : mid;
+               int right = (channel == 0) ? mid : width();
+               float level_lu = level_lufs[channel] - ref_level_lufs;
+               int on_pos = lrint(lufs_to_pos(level_lu, height()));
 
-               painter.drawPixmap(on_rect, on_pixmap, on_rect);
-               painter.drawPixmap(off_rect, off_pixmap, off_rect);
-       } else {
-               QRect off_rect(0, 0, width(), on_pos);
-               QRect on_rect(0, on_pos, width(), height() - on_pos);
+               if (flip) {
+                       QRect on_rect(left, 0, right, height() - on_pos);
+                       QRect off_rect(left, height() - on_pos, right, height());
 
-               painter.drawPixmap(off_rect, off_pixmap, off_rect);
-               painter.drawPixmap(on_rect, on_pixmap, on_rect);
+                       painter.drawPixmap(on_rect, on_pixmap, on_rect);
+                       painter.drawPixmap(off_rect, off_pixmap, off_rect);
+               } else {
+                       QRect off_rect(left, 0, right, on_pos);
+                       QRect on_rect(left, on_pos, right, height() - on_pos);
+
+                       painter.drawPixmap(off_rect, off_pixmap, off_rect);
+                       painter.drawPixmap(on_rect, on_pixmap, on_rect);
+               }
        }
 }
 
index 9322997d7435571131646145d623af5e31d6de81..1fecf7e9cfcd34a0af9e05bad31bccf2df59a30b 100644 (file)
--- a/vumeter.h
+++ b/vumeter.h
@@ -17,8 +17,13 @@ public:
        VUMeter(QWidget *parent);
 
        void set_level(float level_lufs) {
+               set_level(level_lufs, level_lufs);
+       }
+
+       void set_level(float level_lufs_left, float level_lufs_right) {
                std::unique_lock<std::mutex> lock(level_mutex);
-               this->level_lufs = level_lufs;
+               this->level_lufs[0] = level_lufs_left;
+               this->level_lufs[1] = level_lufs_right;
                QMetaObject::invokeMethod(this, "update", Qt::AutoConnection);
        }
 
@@ -56,7 +61,7 @@ private:
        void recalculate_pixmaps();
 
        std::mutex level_mutex;
-       float level_lufs = -HUGE_VAL;
+       float level_lufs[2] { -HUGE_VALF, -HUGE_VALF };
        float min_level = -18.0f, max_level = 9.0f, ref_level_lufs = -23.0f;
        bool flip = false;