reset meter when meter-point changes
authorRobin Gareus <robin@gareus.org>
Thu, 18 Jul 2013 07:01:47 +0000 (09:01 +0200)
committerPaul Davis <paul@linuxaudiosystems.com>
Thu, 8 Aug 2013 19:23:10 +0000 (15:23 -0400)
libs/ardour/meter.cc
libs/ardour/route.cc

index 90f0977e4d0ac67f88ad73ff0cff6c55f6049de8..961a489a631b7669af26d2cad28d505edb0ca48c 100644 (file)
@@ -129,6 +129,16 @@ PeakMeter::reset_max ()
                _max_peak_power[i] = -INFINITY;
                _max_peak_signal[i] = 0;
        }
+
+       const size_t n_midi  = min (_peak_signal.size(), (size_t) current_meters.n_midi());
+
+       for (size_t n = 0; n < _peak_signal.size(); ++n) {
+               if (n < n_midi) {
+                       _visible_peak_power[n] = 0;
+               } else {
+                       _visible_peak_power[n] = -INFINITY;
+               }
+       }
 }
 
 bool
@@ -159,7 +169,6 @@ PeakMeter::reflect_inputs (const ChanCount& in)
 
        const size_t limit = min (_peak_signal.size(), (size_t) current_meters.n_total ());
        const size_t n_midi  = min (_peak_signal.size(), (size_t) current_meters.n_midi());
-       const size_t n_audio = current_meters.n_audio();
 
        for (size_t n = 0; n < limit; ++n) {
                if (n < n_midi) {
@@ -169,10 +178,7 @@ PeakMeter::reflect_inputs (const ChanCount& in)
                }
        }
 
-       for (size_t n = 0; n < n_audio; ++n) {
-               _kmeter[n]->reset();
-       }
-
+       reset();
        reset_max();
 
        ConfigurationChanged (in, in); /* EMIT SIGNAL */
@@ -212,6 +218,9 @@ PeakMeter::reset_max_channels (const ChanCount& chn)
                _kmeter.push_back(new Kmeterdsp());
        }
        assert(_kmeter.size() == n_audio);
+
+       reset();
+       reset_max();
 }
 
 /** To be driven by the Meter signal from IO.
index dad19224880fca129d3098aa0be00e0eb31664b4..5c794fb379377185ed64e4c72d2db7b183bab855 100644 (file)
@@ -3152,6 +3152,9 @@ Route::set_meter_point (MeterPoint p, bool force)
                */
        }
 
+       _meter->reset();
+       _meter->reset_max();
+
        meter_change (); /* EMIT SIGNAL */
 
        bool const meter_visibly_changed = (_meter->display_to_user() != meter_was_visible_to_user);