From f0a3f1ea52ab1a2c142e904a3fce110092ac1106 Mon Sep 17 00:00:00 2001 From: Robin Gareus Date: Thu, 18 Jul 2013 09:01:47 +0200 Subject: [PATCH] reset meter when meter-point changes --- libs/ardour/meter.cc | 19 ++++++++++++++----- libs/ardour/route.cc | 3 +++ 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/libs/ardour/meter.cc b/libs/ardour/meter.cc index 90f0977e4d..961a489a63 100644 --- a/libs/ardour/meter.cc +++ b/libs/ardour/meter.cc @@ -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. diff --git a/libs/ardour/route.cc b/libs/ardour/route.cc index dad1922488..5c794fb379 100644 --- a/libs/ardour/route.cc +++ b/libs/ardour/route.cc @@ -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);