summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2013-03-07 19:35:10 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2013-03-07 19:35:10 +0000
commit626dbf8abb38b241e879d30d4ae0cabb0d20ad10 (patch)
tree90392d93cd6fc8505d84b476df7b0648396ae7ae
parent204ec4ebd9ecc4446971e20155d5492efa0c5c01 (diff)
fix problem with display of panner when adding instrument to a MIDI track
git-svn-id: svn://localhost/ardour2/branches/3.0@14177 d708f5d6-7413-0410-9779-e7cbd77b26cf
-rw-r--r--gtk2_ardour/mixer_strip.cc39
1 files changed, 33 insertions, 6 deletions
diff --git a/gtk2_ardour/mixer_strip.cc b/gtk2_ardour/mixer_strip.cc
index 5159b66482..90d2a2912a 100644
--- a/gtk2_ardour/mixer_strip.cc
+++ b/gtk2_ardour/mixer_strip.cc
@@ -485,12 +485,6 @@ MixerStrip::set_route (boost::shared_ptr<Route> rt)
at->FreezeChange.connect (route_connections, invalidator (*this), boost::bind (&MixerStrip::map_frozen, this), gui_context());
}
- if (has_audio_outputs ()) {
- panners.show_all ();
- } else {
- panners.hide_all ();
- }
-
if (is_track ()) {
rec_solo_table.attach (*rec_enable_button, 0, 1, 0, 2);
@@ -539,6 +533,12 @@ MixerStrip::set_route (boost::shared_ptr<Route> rt)
connect_to_pan ();
panners.setup_pan ();
+ if (has_audio_outputs ()) {
+ panners.show_all ();
+ } else {
+ panners.hide_all ();
+ }
+
update_diskstream_display ();
update_input_display ();
update_output_display ();
@@ -1230,6 +1230,13 @@ MixerStrip::update_input_display ()
{
update_io_button (_route, _width, true);
panners.setup_pan ();
+
+ if (has_audio_outputs ()) {
+ panners.show_all ();
+ } else {
+ panners.hide_all ();
+ }
+
}
void
@@ -1238,6 +1245,12 @@ MixerStrip::update_output_display ()
update_io_button (_route, _width, false);
gpm.setup_meters ();
panners.setup_pan ();
+
+ if (has_audio_outputs ()) {
+ panners.show_all ();
+ } else {
+ panners.hide_all ();
+ }
}
void
@@ -1832,6 +1845,14 @@ MixerStrip::show_send (boost::shared_ptr<Send> send)
panner_ui().set_panner (_current_delivery->panner_shell(), _current_delivery->panner());
panner_ui().setup_pan ();
+ /* make sure the send has audio output */
+
+ if (_current_delivery->output() && _current_delivery->output()->n_ports().n_audio() > 0) {
+ panners.show_all ();
+ } else {
+ panners.hide_all ();
+ }
+
input_button.set_sensitive (false);
group_button.set_sensitive (false);
set_invert_sensitive (false);
@@ -1865,6 +1886,12 @@ MixerStrip::revert_to_default_display ()
panner_ui().set_panner (_route->main_outs()->panner_shell(), _route->main_outs()->panner());
panner_ui().setup_pan ();
+ if (has_audio_outputs ()) {
+ panners.show_all ();
+ } else {
+ panners.hide_all ();
+ }
+
reset_strip_style ();
}