diff options
-rw-r--r-- | gtk2_ardour/panner2d.cc | 4 | ||||
-rw-r--r-- | gtk2_ardour/route_time_axis.cc | 2 | ||||
-rw-r--r-- | libs/ardour/ardour/pannable.h | 2 | ||||
-rw-r--r-- | libs/ardour/ardour/panner.h | 10 | ||||
-rw-r--r-- | libs/ardour/pannable.cc | 10 | ||||
-rw-r--r-- | libs/ardour/panner.cc | 6 | ||||
-rw-r--r-- | libs/ardour/route.cc | 8 | ||||
-rw-r--r-- | libs/panners/1in2out/panner_1in2out.cc | 11 | ||||
-rw-r--r-- | libs/panners/1in2out/panner_1in2out.h | 2 | ||||
-rw-r--r-- | libs/panners/2in2out/panner_2in2out.cc | 11 | ||||
-rw-r--r-- | libs/panners/2in2out/panner_2in2out.h | 2 | ||||
-rw-r--r-- | libs/panners/stereobalance/panner_balance.cc | 10 | ||||
-rw-r--r-- | libs/panners/stereobalance/panner_balance.h | 2 | ||||
-rw-r--r-- | libs/panners/vbap/vbap.cc | 24 | ||||
-rw-r--r-- | libs/panners/vbap/vbap.h | 2 |
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); |