From 75abb09f32c3c4f39e1356bd2caac44182febb02 Mon Sep 17 00:00:00 2001 From: Paul Davis Date: Tue, 22 Feb 2011 18:44:22 +0000 Subject: remove semantic-free Panner::Changed signal; make mackie code pay attention to actual pan controls; make GUI watch PannerShell::Changed for news that the currently chosen panner has changed or changed configuration git-svn-id: svn://localhost/ardour2/branches/3.0@8924 d708f5d6-7413-0410-9779-e7cbd77b26cf --- gtk2_ardour/panner_ui.cc | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) (limited to 'gtk2_ardour/panner_ui.cc') diff --git a/gtk2_ardour/panner_ui.cc b/gtk2_ardour/panner_ui.cc index cd35bc2d88..2a69d73251 100644 --- a/gtk2_ardour/panner_ui.cc +++ b/gtk2_ardour/panner_ui.cc @@ -37,6 +37,7 @@ #include "ardour/session.h" #include "ardour/panner.h" #include "ardour/pannable.h" +#include "ardour/panner_shell.h" #include "ardour/route.h" #include "i18n.h" @@ -91,8 +92,11 @@ PannerUI::PannerUI (Session* s) } void -PannerUI::set_panner (boost::shared_ptr p) +PannerUI::set_panner (boost::shared_ptr ps, boost::shared_ptr p) { + /* note that the panshell might not change here (i.e. ps == _panshell) + */ + connections.drop_connections (); delete pan_astyle_menu; @@ -101,6 +105,7 @@ PannerUI::set_panner (boost::shared_ptr p) delete pan_astate_menu; pan_astate_menu = 0; + _panshell = ps; _panner = p; delete twod_panner; @@ -113,7 +118,7 @@ PannerUI::set_panner (boost::shared_ptr p) return; } - _panner->Changed.connect (connections, invalidator (*this), boost::bind (&PannerUI::panner_changed, this, this), gui_context()); + _panshell->Changed.connect (connections, invalidator (*this), boost::bind (&PannerUI::panshell_changed, this), gui_context()); _panner->StateChanged.connect (connections, invalidator (*this), boost::bind (&PannerUI::update_pan_state, this), gui_context()); /* new panner object, force complete reset of panner GUI @@ -122,10 +127,9 @@ PannerUI::set_panner (boost::shared_ptr p) _current_nouts = 0; _current_nins = 0; - panner_changed (0); + setup_pan (); update_pan_sensitive (); pan_automation_state_changed (); - } void @@ -206,8 +210,9 @@ PannerUI::~PannerUI () void -PannerUI::panner_changed (void* src) +PannerUI::panshell_changed () { + set_panner (_panshell, _panshell->panner()); setup_pan (); } @@ -231,13 +236,16 @@ PannerUI::setup_pan () return; } + _current_nins = nins; + _current_nouts = nouts; + container_clear (pan_vbox); delete twod_panner; twod_panner = 0; delete _stereo_panner; _stereo_panner = 0; - + if (nouts == 0 || nouts == 1) { delete _stereo_panner; -- cgit v1.2.3