mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-18 20:56:28 +01:00
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:
parent
ca10cc82a4
commit
807bc4c3d6
7 changed files with 60 additions and 60 deletions
|
|
@ -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;
|
||||||
|
|
|
||||||
|
|
@ -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 ();
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
|
||||||
|
|
@ -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();
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue