diff options
author | Len Ovens <len@ovenwerks.net> | 2018-01-13 07:58:37 -0800 |
---|---|---|
committer | Len Ovens <len@ovenwerks.net> | 2018-01-13 07:58:37 -0800 |
commit | e51c5ab76a4c53d723ec5dcc31a05400e528d70e (patch) | |
tree | c620f338ad986c2da203a80cb0c329011d88aa76 /libs/surfaces/osc/osc.cc | |
parent | 40498f841d2c7961793a2964f2b86255a96360dd (diff) |
OSC: add /select/hide
Diffstat (limited to 'libs/surfaces/osc/osc.cc')
-rw-r--r-- | libs/surfaces/osc/osc.cc | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/libs/surfaces/osc/osc.cc b/libs/surfaces/osc/osc.cc index f3f7421e85..41d1210281 100644 --- a/libs/surfaces/osc/osc.cc +++ b/libs/surfaces/osc/osc.cc @@ -576,6 +576,7 @@ OSC::register_callbacks() REGISTER_CALLBACK (serv, "/select/fader", "f", sel_fader); REGISTER_CALLBACK (serv, "/select/db_delta", "f", sel_dB_delta); REGISTER_CALLBACK (serv, "/select/trimdB", "f", sel_trim); + REGISTER_CALLBACK (serv, "/select/hide", "i", sel_hide); REGISTER_CALLBACK (serv, "/select/pan_stereo_position", "f", sel_pan_position); REGISTER_CALLBACK (serv, "/select/pan_stereo_width", "f", sel_pan_width); REGISTER_CALLBACK (serv, "/select/send_gain", "if", sel_sendgain); @@ -4124,6 +4125,24 @@ OSC::sel_trim (float val, lo_message msg) } int +OSC::sel_hide (uint32_t state, lo_message msg) +{ + OSCSurface *sur = get_surface(get_address (msg)); + boost::shared_ptr<Stripable> s; + if (sur->expand_enable) { + s = get_strip (sur->expand, get_address (msg)); + } else { + s = _select; + } + if (s) { + if (state != s->is_hidden ()) { + s->presentation_info().set_hidden ((bool) state); + } + } + return 0; +} + +int OSC::sel_pan_position (float val, lo_message msg) { OSCSurface *sur = get_surface(get_address (msg)); |