diff options
Diffstat (limited to 'libs/surfaces/osc/osc_select_observer.cc')
-rw-r--r-- | libs/surfaces/osc/osc_select_observer.cc | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/libs/surfaces/osc/osc_select_observer.cc b/libs/surfaces/osc/osc_select_observer.cc index d08c454b26..fd95522738 100644 --- a/libs/surfaces/osc/osc_select_observer.cc +++ b/libs/surfaces/osc/osc_select_observer.cc @@ -31,6 +31,7 @@ #include "ardour/solo_isolate_control.h" #include "ardour/solo_safe_control.h" #include "ardour/route.h" +#include "ardour/route_group.h" #include "ardour/send.h" #include "ardour/plugin.h" #include "ardour/plugin_insert.h" @@ -133,6 +134,10 @@ OSCSelectObserver::refresh_strip (boost::shared_ptr<ARDOUR::Stripable> new_strip _strip->PropertyChanged.connect (strip_connections, MISSING_INVALIDATOR, boost::bind (&OSCSelectObserver::name_changed, this, boost::lambda::_1), OSC::instance()); name_changed (ARDOUR::Properties::name); + boost::shared_ptr<Route> rt = boost::dynamic_pointer_cast<Route> (_strip); + rt->route_group_changed.connect (strip_connections, MISSING_INVALIDATOR, boost::bind (&OSCSelectObserver::group_name, this), OSC::instance()); + group_name (); + _strip->presentation_info().PropertyChanged.connect (strip_connections, MISSING_INVALIDATOR, boost::bind (&OSCSelectObserver::pi_changed, this, _1), OSC::instance()); _osc.float_message ("/select/hide", _strip->is_hidden (), addr); @@ -271,6 +276,7 @@ OSCSelectObserver::clear_observer () // all strip buttons should be off and faders 0 and etc. _osc.float_message ("/select/expand", 0, addr); _osc.text_message ("/select/name", " ", addr); + _osc.text_message ("/select/group/name", " ", addr); _osc.text_message ("/select/comment", " ", addr); _osc.float_message ("/select/mute", 0, addr); _osc.float_message ("/select/solo", 0, addr); @@ -643,6 +649,19 @@ OSCSelectObserver::name_changed (const PBD::PropertyChange& what_changed) } void +OSCSelectObserver::group_name () +{ + boost::shared_ptr<Route> rt = boost::dynamic_pointer_cast<Route> (_strip); + + RouteGroup *rg = rt->route_group(); + if (rg) { + _osc.text_message ("/select/group/name", rg->name(), addr); + } else { + _osc.text_message ("/select/group/name", " ", addr); + } +} + +void OSCSelectObserver::pi_changed (PBD::PropertyChange const& what_changed) { _osc.float_message ("/select/hide", _strip->is_hidden (), addr); |