summaryrefslogtreecommitdiff
path: root/gtk2_ardour/panner_ui.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2011-02-22 18:44:22 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2011-02-22 18:44:22 +0000
commit75abb09f32c3c4f39e1356bd2caac44182febb02 (patch)
tree77214bd64517cc734e63dde5a5792ce24df1acd6 /gtk2_ardour/panner_ui.cc
parent14277ff831c90dbdd1131a44eac86da919bb0544 (diff)
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
Diffstat (limited to 'gtk2_ardour/panner_ui.cc')
-rw-r--r--gtk2_ardour/panner_ui.cc20
1 files changed, 14 insertions, 6 deletions
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<Panner> p)
+PannerUI::set_panner (boost::shared_ptr<PannerShell> ps, boost::shared_ptr<Panner> 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<Panner> 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<Panner> 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<Panner> 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;