diff options
author | Robin Gareus <robin@gareus.org> | 2013-07-25 10:53:11 +0200 |
---|---|---|
committer | Robin Gareus <robin@gareus.org> | 2013-07-25 10:53:11 +0200 |
commit | 132549c48a65271dfd81a3f550305e3990caed9f (patch) | |
tree | e6d7033adbb26981b44f37c6e41243df5122c436 /libs/ardour/meter.cc | |
parent | 3c33ff26335f9fdd6ea327cf5829345c3d4bbdc5 (diff) |
reset meters only when *really* necessary
..and continue to calculate fall-off in
audio-cycle (rather than UI thread)
TODO: check if this works properly when switching
between audio/midi meter modes on a midi-track.
One of the motivations to always reset meters when the
meter-point changes was to resolve peak-hold & fall-off
issues when a midi-meter replaces an audio-meter and vice
versa.
Diffstat (limited to 'libs/ardour/meter.cc')
-rw-r--r-- | libs/ardour/meter.cc | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/libs/ardour/meter.cc b/libs/ardour/meter.cc index 3c2d28ef1b..0c23ea168d 100644 --- a/libs/ardour/meter.cc +++ b/libs/ardour/meter.cc @@ -186,20 +186,20 @@ PeakMeter::configure_io (ChanCount in, ChanCount out) void PeakMeter::reflect_inputs (const ChanCount& in) { - current_meters = 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()); - - for (size_t n = 0; n < limit; ++n) { - if (n < n_midi) { - _visible_peak_power[n] = 0; - } else { - _visible_peak_power[n] = -INFINITY; + for (uint32_t i = in.n_total(); i < current_meters.n_total(); ++i) { + if (i < _peak_signal.size()) { + _peak_signal[i] = 0.0f; } } + for (uint32_t i = in.n_audio(); i < current_meters.n_audio(); ++i) { + if (i >= _kmeter.size()) continue; + _kmeter[i]->reset(); + _iec1meter[i]->reset(); + _iec2meter[i]->reset(); + _vumeter[i]->reset(); + } - reset(); + current_meters = in; reset_max(); ConfigurationChanged (in, in); /* EMIT SIGNAL */ |