summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gtk2_ardour/panner2d.cc4
-rw-r--r--gtk2_ardour/route_time_axis.cc2
-rw-r--r--libs/ardour/ardour/pannable.h2
-rw-r--r--libs/ardour/ardour/panner.h10
-rw-r--r--libs/ardour/pannable.cc10
-rw-r--r--libs/ardour/panner.cc6
-rw-r--r--libs/ardour/route.cc8
-rw-r--r--libs/panners/1in2out/panner_1in2out.cc11
-rw-r--r--libs/panners/1in2out/panner_1in2out.h2
-rw-r--r--libs/panners/2in2out/panner_2in2out.cc11
-rw-r--r--libs/panners/2in2out/panner_2in2out.h2
-rw-r--r--libs/panners/stereobalance/panner_balance.cc10
-rw-r--r--libs/panners/stereobalance/panner_balance.h2
-rw-r--r--libs/panners/vbap/vbap.cc24
-rw-r--r--libs/panners/vbap/vbap.h2
15 files changed, 43 insertions, 63 deletions
diff --git a/gtk2_ardour/panner2d.cc b/gtk2_ardour/panner2d.cc
index 0100faa684..6de3f8bdb2 100644
--- a/gtk2_ardour/panner2d.cc
+++ b/gtk2_ardour/panner2d.cc
@@ -256,7 +256,7 @@ Panner2d::handle_state_change ()
panner_shell->panner()->SignalPositionChanged.connect (panner_connections, invalidator(*this), boost::bind (&Panner2d::handle_position_change, this), gui_context());
- set<Evoral::Parameter> params = panner_shell->panner()->what_can_be_automated();
+ set<Evoral::Parameter> params = panner_shell->pannable()->what_can_be_automated();
set<Evoral::Parameter>::iterator p = params.find(PanElevationAutomation);
bool elev = have_elevation;
have_elevation = (p == params.end()) ? false : true;
@@ -997,7 +997,7 @@ Panner2dWindow::set_bypassed ()
bypass_button.set_active(model);
}
- set<Evoral::Parameter> params = widget.get_panner_shell()->panner()->what_can_be_automated();
+ set<Evoral::Parameter> params = widget.get_panner_shell()->pannable()->what_can_be_automated();
set<Evoral::Parameter>::iterator p = params.find(PanWidthAutomation);
if (p == params.end()) {
spinner_box.set_sensitive(false);
diff --git a/gtk2_ardour/route_time_axis.cc b/gtk2_ardour/route_time_axis.cc
index 4f838faaf2..cd2a101cde 100644
--- a/gtk2_ardour/route_time_axis.cc
+++ b/gtk2_ardour/route_time_axis.cc
@@ -1814,7 +1814,7 @@ RouteTimeAxisView::ensure_pan_views (bool show)
return;
}
- set<Evoral::Parameter> params = _route->panner()->what_can_be_automated();
+ set<Evoral::Parameter> params = _route->pannable()->what_can_be_automated();
set<Evoral::Parameter>::iterator p;
for (p = params.begin(); p != params.end(); ++p) {
diff --git a/libs/ardour/ardour/pannable.h b/libs/ardour/ardour/pannable.h
index c7a0969091..4bb029eb7f 100644
--- a/libs/ardour/ardour/pannable.h
+++ b/libs/ardour/ardour/pannable.h
@@ -53,6 +53,8 @@ public:
Session& session() { return _session; }
+ const std::set<Evoral::Parameter>& what_can_be_automated() const;
+
void set_automation_state (AutoState);
AutoState automation_state() const { return _auto_state; }
PBD::Signal1<void, AutoState> automation_state_changed;
diff --git a/libs/ardour/ardour/panner.h b/libs/ardour/ardour/panner.h
index c1f925df92..f328b7818b 100644
--- a/libs/ardour/ardour/panner.h
+++ b/libs/ardour/ardour/panner.h
@@ -110,8 +110,6 @@ public:
void set_automation_state (AutoState);
AutoState automation_state() const;
- virtual std::set<Evoral::Parameter> what_can_be_automated() const;
-
bool touching() const;
/**
@@ -145,8 +143,16 @@ public:
protected:
friend PanControllable;
+ friend Pannable; // allow what_can_be_automated
+
boost::shared_ptr<Pannable> _pannable;
+ std::set<Evoral::Parameter> _can_automate_list;
+
+ const std::set<Evoral::Parameter>& what_can_be_automated() const {
+ return _can_automate_list;
+ }
+
virtual std::string value_as_string (boost::shared_ptr<const AutomationControl>) const = 0;
virtual void distribute_one (AudioBuffer&, BufferSet& obufs, gain_t gain_coeff, pframes_t nframes, uint32_t which) = 0;
diff --git a/libs/ardour/pannable.cc b/libs/ardour/pannable.cc
index f0ee102ec2..d6d3c20007 100644
--- a/libs/ardour/pannable.cc
+++ b/libs/ardour/pannable.cc
@@ -108,6 +108,16 @@ Pannable::set_panner (boost::shared_ptr<Panner> p)
_panner = p;
}
+const std::set<Evoral::Parameter>&
+Pannable::what_can_be_automated() const
+{
+ boost::shared_ptr<Panner> const panner = _panner.lock();
+ if (panner) {
+ return panner->what_can_be_automated ();
+ }
+ return Automatable::what_can_be_automated ();
+}
+
void
Pannable::value_changed ()
{
diff --git a/libs/ardour/panner.cc b/libs/ardour/panner.cc
index c0e93fcc91..5ffb2ade88 100644
--- a/libs/ardour/panner.cc
+++ b/libs/ardour/panner.cc
@@ -86,12 +86,6 @@ Panner::touching () const
return _pannable->touching ();
}
-set<Evoral::Parameter>
-Panner::what_can_be_automated() const
-{
- return _pannable->what_can_be_automated ();
-}
-
int
Panner::set_state (XMLNode const &, int)
{
diff --git a/libs/ardour/route.cc b/libs/ardour/route.cc
index 15791f4901..622ec7cd1a 100644
--- a/libs/ardour/route.cc
+++ b/libs/ardour/route.cc
@@ -5367,7 +5367,7 @@ Route::pan_elevation_control() const
return boost::shared_ptr<AutomationControl>();
}
- set<Evoral::Parameter> c = panner()->what_can_be_automated ();
+ set<Evoral::Parameter> c = pannable()->what_can_be_automated ();
if (c.find (PanElevationAutomation) != c.end()) {
return _pannable->pan_elevation_control;
@@ -5388,7 +5388,7 @@ Route::pan_width_control() const
return boost::shared_ptr<AutomationControl>();
}
- set<Evoral::Parameter> c = panner()->what_can_be_automated ();
+ set<Evoral::Parameter> c = pannable()->what_can_be_automated ();
if (c.find (PanWidthAutomation) != c.end()) {
return _pannable->pan_width_control;
@@ -5403,7 +5403,7 @@ Route::pan_frontback_control() const
return boost::shared_ptr<AutomationControl>();
}
- set<Evoral::Parameter> c = panner()->what_can_be_automated ();
+ set<Evoral::Parameter> c = pannable()->what_can_be_automated ();
if (c.find (PanFrontBackAutomation) != c.end()) {
return _pannable->pan_frontback_control;
@@ -5418,7 +5418,7 @@ Route::pan_lfe_control() const
return boost::shared_ptr<AutomationControl>();
}
- set<Evoral::Parameter> c = panner()->what_can_be_automated ();
+ set<Evoral::Parameter> c = pannable()->what_can_be_automated ();
if (c.find (PanLFEAutomation) != c.end()) {
return _pannable->pan_lfe_control;
diff --git a/libs/panners/1in2out/panner_1in2out.cc b/libs/panners/1in2out/panner_1in2out.cc
index 3e4ebd8d82..dade3286ba 100644
--- a/libs/panners/1in2out/panner_1in2out.cc
+++ b/libs/panners/1in2out/panner_1in2out.cc
@@ -80,6 +80,8 @@ Panner1in2out::Panner1in2out (boost::shared_ptr<Pannable> p)
_pannable->pan_azimuth_control->set_value (0.5, Controllable::NoGroup);
}
+ _can_automate_list.insert (Evoral::Parameter (PanAzimuthAutomation));
+
update ();
left = desired_left;
@@ -342,15 +344,6 @@ Panner1in2out::get_state ()
return root;
}
-
-std::set<Evoral::Parameter>
-Panner1in2out::what_can_be_automated() const
-{
- set<Evoral::Parameter> s;
- s.insert (Evoral::Parameter (PanAzimuthAutomation));
- return s;
-}
-
string
Panner1in2out::value_as_string (boost::shared_ptr<const AutomationControl> ac) const
{
diff --git a/libs/panners/1in2out/panner_1in2out.h b/libs/panners/1in2out/panner_1in2out.h
index 93112e1527..55ec3ffae3 100644
--- a/libs/panners/1in2out/panner_1in2out.h
+++ b/libs/panners/1in2out/panner_1in2out.h
@@ -52,8 +52,6 @@ class Panner1in2out : public Panner
ChanCount in() const { return ChanCount (DataType::AUDIO, 1); }
ChanCount out() const { return ChanCount (DataType::AUDIO, 2); }
- std::set<Evoral::Parameter> what_can_be_automated() const;
-
static Panner* factory (boost::shared_ptr<Pannable>, boost::shared_ptr<Speakers>);
std::string value_as_string (boost::shared_ptr<const AutomationControl>) const;
diff --git a/libs/panners/2in2out/panner_2in2out.cc b/libs/panners/2in2out/panner_2in2out.cc
index da47228fbb..e6127194c4 100644
--- a/libs/panners/2in2out/panner_2in2out.cc
+++ b/libs/panners/2in2out/panner_2in2out.cc
@@ -85,6 +85,8 @@ Panner2in2out::Panner2in2out (boost::shared_ptr<Pannable> p)
set_width(w > 0 ? wrange : -wrange);
}
+ _can_automate_list.insert (Evoral::Parameter (PanAzimuthAutomation));
+ _can_automate_list.insert (Evoral::Parameter (PanWidthAutomation));
update ();
@@ -486,15 +488,6 @@ Panner2in2out::get_state ()
return root;
}
-std::set<Evoral::Parameter>
-Panner2in2out::what_can_be_automated() const
-{
- set<Evoral::Parameter> s;
- s.insert (Evoral::Parameter (PanAzimuthAutomation));
- s.insert (Evoral::Parameter (PanWidthAutomation));
- return s;
-}
-
string
Panner2in2out::value_as_string (boost::shared_ptr<const AutomationControl> ac) const
{
diff --git a/libs/panners/2in2out/panner_2in2out.h b/libs/panners/2in2out/panner_2in2out.h
index f41944a911..4816be7734 100644
--- a/libs/panners/2in2out/panner_2in2out.h
+++ b/libs/panners/2in2out/panner_2in2out.h
@@ -58,8 +58,6 @@ class Panner2in2out : public Panner
double position () const;
double width () const;
- std::set<Evoral::Parameter> what_can_be_automated() const;
-
static Panner* factory (boost::shared_ptr<Pannable>, boost::shared_ptr<Speakers>);
std::string value_as_string (boost::shared_ptr<const AutomationControl>) const;
diff --git a/libs/panners/stereobalance/panner_balance.cc b/libs/panners/stereobalance/panner_balance.cc
index 73a3022a12..701f081951 100644
--- a/libs/panners/stereobalance/panner_balance.cc
+++ b/libs/panners/stereobalance/panner_balance.cc
@@ -77,6 +77,8 @@ Pannerbalance::Pannerbalance (boost::shared_ptr<Pannable> p)
_pannable->pan_azimuth_control->set_value (0.5, Controllable::NoGroup);
}
+ _can_automate_list.insert (Evoral::Parameter (PanAzimuthAutomation));
+
update ();
/* LEFT SIGNAL */
@@ -275,14 +277,6 @@ Pannerbalance::get_state ()
return root;
}
-std::set<Evoral::Parameter>
-Pannerbalance::what_can_be_automated() const
-{
- set<Evoral::Parameter> s;
- s.insert (Evoral::Parameter (PanAzimuthAutomation));
- return s;
-}
-
string
Pannerbalance::value_as_string (boost::shared_ptr<const AutomationControl> ac) const
{
diff --git a/libs/panners/stereobalance/panner_balance.h b/libs/panners/stereobalance/panner_balance.h
index db41502cbc..9ce5519759 100644
--- a/libs/panners/stereobalance/panner_balance.h
+++ b/libs/panners/stereobalance/panner_balance.h
@@ -50,8 +50,6 @@ class Pannerbalance : public Panner
std::pair<double, double> position_range () const;
double position () const;
- std::set<Evoral::Parameter> what_can_be_automated() const;
-
static Panner* factory (boost::shared_ptr<Pannable>, boost::shared_ptr<Speakers>);
std::string value_as_string (boost::shared_ptr<const AutomationControl>) const;
diff --git a/libs/panners/vbap/vbap.cc b/libs/panners/vbap/vbap.cc
index da48b46fa0..0bf9e34255 100644
--- a/libs/panners/vbap/vbap.cc
+++ b/libs/panners/vbap/vbap.cc
@@ -123,6 +123,16 @@ VBAPanner::configure_io (ChanCount in, ChanCount /* ignored - we use Speakers */
void
VBAPanner::update ()
{
+
+ _can_automate_list.clear ();
+ _can_automate_list.insert (Evoral::Parameter (PanAzimuthAutomation));
+ if (_signals.size() > 1) {
+ _can_automate_list.insert (Evoral::Parameter (PanWidthAutomation));
+ }
+ if (_speakers->dimension() == 3) {
+ _can_automate_list.insert (Evoral::Parameter (PanElevationAutomation));
+ }
+
/* recompute signal directions based on panner azimuth and, if relevant, width (diffusion) and elevation parameters */
double elevation = _pannable->pan_elevation_control->get_value() * 90.0;
@@ -392,20 +402,6 @@ VBAPanner::out() const
return ChanCount (DataType::AUDIO, _speakers->n_speakers());
}
-std::set<Evoral::Parameter>
-VBAPanner::what_can_be_automated() const
-{
- set<Evoral::Parameter> s;
- s.insert (Evoral::Parameter (PanAzimuthAutomation));
- if (_signals.size() > 1) {
- s.insert (Evoral::Parameter (PanWidthAutomation));
- }
- if (_speakers->dimension() == 3) {
- s.insert (Evoral::Parameter (PanElevationAutomation));
- }
- return s;
-}
-
string
VBAPanner::value_as_string (boost::shared_ptr<const AutomationControl> ac) const
{
diff --git a/libs/panners/vbap/vbap.h b/libs/panners/vbap/vbap.h
index fb96de8715..2a3c0ea8e3 100644
--- a/libs/panners/vbap/vbap.h
+++ b/libs/panners/vbap/vbap.h
@@ -49,8 +49,6 @@ public:
void set_width (double);
void set_elevation (double);
- std::set<Evoral::Parameter> what_can_be_automated() const;
-
static Panner* factory (boost::shared_ptr<Pannable>, boost::shared_ptr<Speakers>);
void distribute (BufferSet& ibufs, BufferSet& obufs, gain_t gain_coeff, pframes_t nframes);