Reconfigure GUI meters when route I/O configuration changes.

git-svn-id: svn://localhost/ardour2/branches/3.0@5037 d708f5d6-7413-0410-9779-e7cbd77b26cf
This commit is contained in:
David Robillard 2009-05-04 17:05:55 +00:00
parent ca10cc82a4
commit 807bc4c3d6
7 changed files with 60 additions and 60 deletions

View file

@ -165,7 +165,7 @@ GainMeterBase::set_io (boost::shared_ptr<IO> io)
_io = io; _io = io;
level_meter->set_io (_io); level_meter->set_meter (_io->peak_meter());
gain_slider->set_controllable (_io->gain_control()); gain_slider->set_controllable (_io->gain_control());
boost::shared_ptr<Route> r; boost::shared_ptr<Route> r;

View file

@ -58,7 +58,7 @@ namespace Gtk {
class GainMeterBase : virtual public sigc::trackable class GainMeterBase : virtual public sigc::trackable
{ {
public: public:
GainMeterBase ( ARDOUR::Session&, const Glib::RefPtr<Gdk::Pixbuf>& pix, GainMeterBase (ARDOUR::Session&, const Glib::RefPtr<Gdk::Pixbuf>& pix,
bool horizontal); bool horizontal);
virtual ~GainMeterBase (); virtual ~GainMeterBase ();
@ -94,7 +94,7 @@ class GainMeterBase : virtual public sigc::trackable
Gtkmm2ext::FocusEntry gain_display; Gtkmm2ext::FocusEntry gain_display;
Gtk::Button peak_display; Gtk::Button peak_display;
Gtk::DrawingArea meter_metric_area; Gtk::DrawingArea meter_metric_area;
LevelMeter *level_meter; LevelMeter *level_meter;
sigc::connection gain_watching; sigc::connection gain_watching;
@ -126,7 +126,7 @@ class GainMeterBase : virtual public sigc::trackable
void gain_activated (); void gain_activated ();
bool gain_focused (GdkEventFocus*); bool gain_focused (GdkEventFocus*);
float max_peak; float max_peak;
void gain_adjusted (); void gain_adjusted ();
void gain_changed (); void gain_changed ();

View file

@ -19,9 +19,6 @@
#include <limits.h> #include <limits.h>
#include "ardour/io.h"
#include "ardour/route.h"
#include "ardour/route_group.h"
#include "ardour/session.h" #include "ardour/session.h"
#include "ardour/session_route.h" #include "ardour/session_route.h"
#include "ardour/dB.h" #include "ardour/dB.h"
@ -43,7 +40,6 @@
#include "public_editor.h" #include "public_editor.h"
#include "ardour/session.h" #include "ardour/session.h"
#include "ardour/route.h"
#include "i18n.h" #include "i18n.h"
@ -60,7 +56,8 @@ using namespace std;
LevelMeter::LevelMeter (Session& s) LevelMeter::LevelMeter (Session& s)
: _session (s) : _session (s)
, _meter (0)
, meter_length (0)
{ {
set_spacing (1); set_spacing (1);
Config->ParameterChanged.connect (mem_fun (*this, &LevelMeter::parameter_changed)); Config->ParameterChanged.connect (mem_fun (*this, &LevelMeter::parameter_changed));
@ -83,9 +80,12 @@ LevelMeter::~LevelMeter ()
} }
void void
LevelMeter::set_io (boost::shared_ptr<IO> io) LevelMeter::set_meter (PeakMeter& meter)
{ {
_io = io; _configuration_connection.disconnect();
_meter = &meter;
_configuration_connection = _meter->ConfigurationChanged.connect(
mem_fun(*this, &LevelMeter::configuration_changed));
} }
float float
@ -97,9 +97,9 @@ LevelMeter::update_meters ()
for (n = 0, i = meters.begin(); i != meters.end(); ++i, ++n) { for (n = 0, i = meters.begin(); i != meters.end(); ++i, ++n) {
if ((*i).packed) { if ((*i).packed) {
peak = _io->peak_meter().peak_power (n); peak = _meter->peak_power (n);
(*i).meter->set (log_meter (peak)); (*i).meter->set (log_meter (peak));
mpeak = _io->peak_meter().max_peak_power(n); mpeak = _meter->max_peak_power(n);
if (mpeak > max_peak) { if (mpeak > max_peak) {
max_peak = mpeak; max_peak = mpeak;
} }
@ -132,10 +132,16 @@ LevelMeter::parameter_changed(const char* parameter_name)
#undef PARAM_IS #undef PARAM_IS
} }
void
LevelMeter::configuration_changed(ChanCount in, ChanCount out)
{
color_changed = true;
setup_meters (meter_length, regular_meter_width);
}
void void
LevelMeter::hide_all_meters () LevelMeter::hide_all_meters ()
{ {
for (vector<MeterInfo>::iterator i = meters.begin(); i != meters.end(); ++i) { for (vector<MeterInfo>::iterator i = meters.begin(); i != meters.end(); ++i) {
if ((*i).packed) { if ((*i).packed) {
remove (*((*i).meter)); remove (*((*i).meter));
@ -147,37 +153,19 @@ LevelMeter::hide_all_meters ()
void void
LevelMeter::setup_meters (int len, int initial_width) LevelMeter::setup_meters (int len, int initial_width)
{ {
if (!_io) { if (!_meter) {
return; /* do it later */ return; /* do it later */
} }
uint32_t nmeters = _io->n_outputs().n_total(); int32_t nmidi = _meter->input_streams().n_midi();
uint32_t nmeters = _meter->input_streams().n_total();
regular_meter_width = initial_width; regular_meter_width = initial_width;
meter_length = len;
guint16 width; guint16 width;
hide_all_meters (); hide_all_meters ();
Route* r;
if ((r = dynamic_cast<Route*> (_io.get())) != 0) {
switch (r->meter_point()) {
case MeterPreFader:
case MeterInput:
nmeters = r->n_inputs().n_total();
break;
case MeterPostFader:
nmeters = r->n_outputs().n_total();
break;
}
} else {
nmeters = _io->n_outputs().n_total();
}
if (nmeters == 0) { if (nmeters == 0) {
return; return;
} }
@ -192,15 +180,21 @@ LevelMeter::setup_meters (int len, int initial_width)
meters.push_back (MeterInfo()); meters.push_back (MeterInfo());
} }
int b = ARDOUR_UI::config()->canvasvar_MeterColorBase.get();
int m = ARDOUR_UI::config()->canvasvar_MeterColorMid.get();
int t = ARDOUR_UI::config()->canvasvar_MeterColorTop.get();
int c = ARDOUR_UI::config()->canvasvar_MeterColorClip.get();
//cerr << "LevelMeter::setup_meters() called color_changed = " << color_changed << " colors: " << endl;//DEBUG //cerr << "LevelMeter::setup_meters() called color_changed = " << color_changed << " colors: " << endl;//DEBUG
for (int32_t n = nmeters-1; nmeters && n >= 0 ; --n) { for (int32_t n = nmeters-1; nmeters && n >= 0 ; --n) {
uint32_t b, m, t, c;
if (n < nmidi) {
b = ARDOUR_UI::config()->canvasvar_MidiNoteMeterColorBase.get();
m = ARDOUR_UI::config()->canvasvar_MidiNoteMeterColorMid.get();
t = ARDOUR_UI::config()->canvasvar_MidiNoteMeterColorTop.get();
c = ARDOUR_UI::config()->canvasvar_MeterColorClip.get();
} else {
b = ARDOUR_UI::config()->canvasvar_MeterColorBase.get();
m = ARDOUR_UI::config()->canvasvar_MeterColorMid.get();
t = ARDOUR_UI::config()->canvasvar_MeterColorTop.get();
c = ARDOUR_UI::config()->canvasvar_MeterColorClip.get();
}
if (meters[n].width != width || meters[n].length != len || color_changed) { if (meters[n].width != width || meters[n].length != len || color_changed) {
delete meters[n].meter; delete meters[n].meter;
meters[n].meter = new FastMeter ((uint32_t) floor (Config->get_meter_hold()), width, FastMeter::Vertical, len, b, m, t, c); meters[n].meter = new FastMeter ((uint32_t) floor (Config->get_meter_hold()), width, FastMeter::Vertical, len, b, m, t, c);

View file

@ -39,14 +39,11 @@
#include "enums.h" #include "enums.h"
namespace ARDOUR { namespace ARDOUR {
class IO;
class Session; class Session;
class Route; class PeakMeter;
class RouteGroup;
} }
namespace Gtkmm2ext { namespace Gtkmm2ext {
class FastMeter; class FastMeter;
class BarController;
} }
namespace Gtk { namespace Gtk {
class Menu; class Menu;
@ -58,7 +55,7 @@ class LevelMeter : public Gtk::HBox
LevelMeter (ARDOUR::Session&); LevelMeter (ARDOUR::Session&);
~LevelMeter (); ~LevelMeter ();
virtual void set_io (boost::shared_ptr<ARDOUR::IO> io); virtual void set_meter (ARDOUR::PeakMeter& meter);
void update_gain_sensitive (); void update_gain_sensitive ();
@ -69,18 +66,16 @@ class LevelMeter : public Gtk::HBox
void setup_meters (int len=0, int width=3); void setup_meters (int len=0, int width=3);
private: private:
ARDOUR::Session& _session;
//friend class MixerStrip; ARDOUR::PeakMeter* _meter;
boost::shared_ptr<ARDOUR::IO> _io;
ARDOUR::Session& _session;
Width _width; Width _width;
struct MeterInfo { struct MeterInfo {
Gtkmm2ext::FastMeter *meter; Gtkmm2ext::FastMeter *meter;
gint16 width; gint16 width;
int length; int length;
bool packed; bool packed;
MeterInfo() { MeterInfo() {
meter = 0; meter = 0;
@ -90,15 +85,19 @@ class LevelMeter : public Gtk::HBox
} }
}; };
guint16 regular_meter_width; guint16 regular_meter_width;
static const guint16 thin_meter_width = 2; int meter_length;
std::vector<MeterInfo> meters; static const guint16 thin_meter_width = 2;
float max_peak; std::vector<MeterInfo> meters;
float max_peak;
sigc::connection _configuration_connection;
void hide_all_meters (); void hide_all_meters ();
gint meter_button_release (GdkEventButton*, uint32_t); gint meter_button_release (GdkEventButton*, uint32_t);
void parameter_changed (const char*); void parameter_changed (const char*);
void configuration_changed (ARDOUR::ChanCount in, ARDOUR::ChanCount out);
void on_theme_changed (); void on_theme_changed ();
bool style_changed; bool style_changed;

View file

@ -107,8 +107,9 @@ class Processor : public SessionObject, public AutomatableControls, public Laten
static sigc::signal<void,Processor*> ProcessorCreated; static sigc::signal<void,Processor*> ProcessorCreated;
sigc::signal<void> ActiveChanged; sigc::signal<void> ActiveChanged;
sigc::signal<void> PlacementChanged; sigc::signal<void> PlacementChanged;
sigc::signal<void,ChanCount,ChanCount> ConfigurationChanged;
protected: protected:
int _pending_active; int _pending_active;

View file

@ -98,6 +98,8 @@ PeakMeter::reset_max ()
bool bool
PeakMeter::configure_io (ChanCount in, ChanCount out) PeakMeter::configure_io (ChanCount in, ChanCount out)
{ {
cerr << "METER CONFIGURE IO " << in << " -> " << out << endl;
/* we're transparent no matter what. fight the power. */ /* we're transparent no matter what. fight the power. */
if (out != in) { if (out != in) {
return false; return false;
@ -105,6 +107,8 @@ PeakMeter::configure_io (ChanCount in, ChanCount out)
uint32_t limit = in.n_total(); uint32_t limit = in.n_total();
cerr << "METER LIMIT " << limit << endl;
while (_peak_power.size() > limit) { while (_peak_power.size() > limit) {
_peak_power.pop_back(); _peak_power.pop_back();
_visible_peak_power.pop_back(); _visible_peak_power.pop_back();

View file

@ -256,5 +256,7 @@ Processor::configure_io (ChanCount in, ChanCount out)
_configured_output = out; _configured_output = out;
_configured = true; _configured = true;
ConfigurationChanged.emit (in, out);
return true; return true;
} }