summaryrefslogtreecommitdiff
path: root/libs
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2017-10-19 16:57:12 +0200
committerRobin Gareus <robin@gareus.org>2017-10-19 16:57:26 +0200
commitf87e996013f7468d66f0ef6eb136fcf46ea333d1 (patch)
tree07530912b779425c38d2be1f83b96ec58dfd83a0 /libs
parent0f82302e633719476e7254869adca7801747135b (diff)
FP8: unhardcode IDs and strip-count
Diffstat (limited to 'libs')
-rw-r--r--libs/surfaces/faderport8/faderport8.cc48
-rw-r--r--libs/surfaces/faderport8/fp8_base.h2
-rw-r--r--libs/surfaces/faderport8/fp8_controls.cc18
-rw-r--r--libs/surfaces/faderport8/fp8_controls.h2
-rw-r--r--libs/surfaces/faderport8/fp8_strip.cc58
-rw-r--r--libs/surfaces/faderport8/fp8_strip.h15
6 files changed, 92 insertions, 51 deletions
diff --git a/libs/surfaces/faderport8/faderport8.cc b/libs/surfaces/faderport8/faderport8.cc
index c3e4a20a9a..2e52926183 100644
--- a/libs/surfaces/faderport8/faderport8.cc
+++ b/libs/surfaces/faderport8/faderport8.cc
@@ -354,7 +354,7 @@ FaderPort8::disconnected ()
{
stop_midi_handling ();
if (_device_active) {
- for (uint8_t id = 0; id < 8; ++id) {
+ for (uint8_t id = 0; id < N_STRIPS; ++id) {
_ctrls.strip(id).unset_controllables ();
}
_ctrls.all_lights_off ();
@@ -937,7 +937,7 @@ FaderPort8::assign_stripables (bool select_only)
int n_strips = strips.size();
int channel_off = get_channel_off (_ctrls.mix_mode ());
- channel_off = std::min (channel_off, n_strips - 8);
+ channel_off = std::min (channel_off, n_strips - N_STRIPS);
channel_off = std::max (0, channel_off);
set_channel_off (_ctrls.mix_mode (), channel_off);
@@ -972,11 +972,11 @@ FaderPort8::assign_stripables (bool select_only)
boost::function<void ()> cb (boost::bind (&FaderPort8::select_strip, this, boost::weak_ptr<Stripable> (*s)));
_ctrls.strip(id).set_select_cb (cb);
- if (++id == 8) {
+ if (++id == N_STRIPS) {
break;
}
}
- for (; id < 8; ++id) {
+ for (; id < N_STRIPS; ++id) {
_ctrls.strip(id).unset_controllables (select_only ? (FP8Strip::CTRL_SELECT | FP8Strip::CTRL_TEXT3) : FP8Strip::CTRL_ALL);
_ctrls.strip(id).set_periodic_display_mode (FP8Strip::Stripables);
}
@@ -1106,7 +1106,7 @@ FaderPort8::assign_processor_ctrls ()
int n_parameters = std::max (toggle_params.size(), slider_params.size());
- _parameter_off = std::min (_parameter_off, n_parameters - 8);
+ _parameter_off = std::min (_parameter_off, n_parameters - N_STRIPS);
_parameter_off = std::max (0, _parameter_off);
uint8_t id = 0;
@@ -1130,13 +1130,13 @@ FaderPort8::assign_processor_ctrls ()
_ctrls.strip(id).set_select_controllable (toggle_params[i]->ac);
_ctrls.strip(id).set_text_line (3, toggle_params[i]->name, true);
}
- if (++id == 8) {
+ if (++id == N_STRIPS) {
break;
}
}
// clear remaining
- for (; id < 8; ++id) {
+ for (; id < N_STRIPS; ++id) {
_ctrls.strip(id).unset_controllables ();
}
}
@@ -1156,7 +1156,7 @@ FaderPort8::assign_plugin_presets (boost::shared_ptr<PluginInsert> pi)
int n_parameters = presets.size ();
- _parameter_off = std::min (_parameter_off, n_parameters - 7);
+ _parameter_off = std::min (_parameter_off, n_parameters - (N_STRIPS - 1));
_parameter_off = std::max (0, _parameter_off);
Plugin::PresetRecord active = plugin->last_preset ();
@@ -1177,18 +1177,18 @@ FaderPort8::assign_plugin_presets (boost::shared_ptr<PluginInsert> pi)
_ctrls.strip(id).set_text_line (0, label.substr (0, 9));
_ctrls.strip(id).set_text_line (1, label.length () > 9 ? label.substr (9) : "");
_ctrls.strip(id).set_text_line (3, "PRESET", true);
- if (++id == 7) {
+ if (++id == (N_STRIPS - 1)) {
break;
}
}
// clear remaining
- for (; id < 7; ++id) {
+ for (; id < (N_STRIPS - 1); ++id) {
_ctrls.strip(id).unset_controllables ();
}
// pin clear-preset to the last slot
- assert (id == 7);
+ assert (id == (N_STRIPS - 1));
_ctrls.strip(id).unset_controllables (FP8Strip::CTRL_ALL & ~FP8Strip::CTRL_TEXT0 & ~FP8Strip::CTRL_TEXT3 & ~FP8Strip::CTRL_SELECT);
boost::function<void ()> cb (boost::bind (&FaderPort8::select_plugin_preset, this, SIZE_MAX));
_ctrls.strip(id).set_select_cb (cb);
@@ -1413,7 +1413,7 @@ FaderPort8::spill_plugins ()
}
int n_plugins = procs.size();
- int spillwidth = 8;
+ int spillwidth = N_STRIPS;
bool have_well_known_eq = false;
bool have_well_known_comp = false;
@@ -1471,7 +1471,7 @@ FaderPort8::spill_plugins ()
}
if (have_well_known_comp) {
- assert (id < 8);
+ assert (id < N_STRIPS);
boost::function<void ()> cb (boost::bind (&FaderPort8::select_plugin, this, -2));
_ctrls.strip(id).unset_controllables (FP8Strip::CTRL_ALL & ~FP8Strip::CTRL_TEXT & ~FP8Strip::CTRL_SELECT);
_ctrls.strip(id).set_select_cb (cb);
@@ -1485,7 +1485,7 @@ FaderPort8::spill_plugins ()
++id;
}
if (have_well_known_eq) {
- assert (id < 8);
+ assert (id < N_STRIPS);
boost::function<void ()> cb (boost::bind (&FaderPort8::select_plugin, this, -1));
_ctrls.strip(id).unset_controllables (FP8Strip::CTRL_ALL & ~FP8Strip::CTRL_TEXT & ~FP8Strip::CTRL_SELECT);
_ctrls.strip(id).set_select_cb (cb);
@@ -1498,7 +1498,7 @@ FaderPort8::spill_plugins ()
_ctrls.strip(id).set_text_line (3, "");
++id;
}
- assert (id == 8);
+ assert (id == N_STRIPS);
}
/* ****************************************************************************
@@ -1528,7 +1528,7 @@ FaderPort8::assign_sends ()
set_periodic_display_mode (FP8Strip::SendDisplay);
- _plugin_off = std::min (_plugin_off, n_sends - 8);
+ _plugin_off = std::min (_plugin_off, n_sends - N_STRIPS);
_plugin_off = std::max (0, _plugin_off);
uint8_t id = 0;
@@ -1548,16 +1548,16 @@ FaderPort8::assign_sends ()
_ctrls.strip(id).set_text_line (0, s->send_name (i));
_ctrls.strip(id).set_mute_controllable (s->send_enable_controllable (i));
- if (++id == 8) {
+ if (++id == N_STRIPS) {
break;
}
}
// clear remaining
- for (; id < 8; ++id) {
+ for (; id < N_STRIPS; ++id) {
_ctrls.strip(id).unset_controllables (FP8Strip::CTRL_ALL & ~FP8Strip::CTRL_TEXT3 & ~FP8Strip::CTRL_SELECT);
}
#ifdef MIXBUS // master-assign on last solo
- _ctrls.strip(7).set_solo_controllable (s->master_send_enable_controllable ());
+ _ctrls.strip(N_STRIPS - 1).set_solo_controllable (s->master_send_enable_controllable ());
#endif
/* set select buttons */
assigned_stripable_connections.drop_connections ();
@@ -1602,7 +1602,7 @@ FaderPort8::assign_strips ()
void
FaderPort8::set_periodic_display_mode (FP8Strip::DisplayMode m)
{
- for (uint8_t id = 0; id < 8; ++id) {
+ for (uint8_t id = 0; id < N_STRIPS; ++id) {
_ctrls.strip(id).set_periodic_display_mode (m);
}
}
@@ -1854,14 +1854,14 @@ FaderPort8::move_selected_into_view ()
int off = std::distance (strips.begin(), it);
int channel_off = get_channel_off (_ctrls.mix_mode ());
- if (channel_off <= off && off < channel_off + 8) {
+ if (channel_off <= off && off < channel_off + N_STRIPS) {
return;
}
if (channel_off > off) {
channel_off = off;
} else {
- channel_off = off - 7;
+ channel_off = off - (N_STRIPS - 1);
}
set_channel_off (_ctrls.mix_mode (), channel_off);
assign_strips ();
@@ -1913,7 +1913,7 @@ FaderPort8::select_prev_next (bool next)
void
FaderPort8::bank (bool down, bool page)
{
- int dt = page ? 8 : 1;
+ int dt = page ? N_STRIPS : 1;
if (down) {
dt *= -1;
}
@@ -1924,7 +1924,7 @@ FaderPort8::bank (bool down, bool page)
void
FaderPort8::bank_param (bool down, bool page)
{
- int dt = page ? 8 : 1;
+ int dt = page ? N_STRIPS : 1;
if (down) {
dt *= -1;
}
diff --git a/libs/surfaces/faderport8/fp8_base.h b/libs/surfaces/faderport8/fp8_base.h
index 40af712c1d..f83b916738 100644
--- a/libs/surfaces/faderport8/fp8_base.h
+++ b/libs/surfaces/faderport8/fp8_base.h
@@ -96,7 +96,7 @@ public:
std::vector<uint8_t> d;
sysexhdr (d);
d.push_back (0x12);
- d.push_back (id & 0x07);
+ d.push_back (id & 0x0f);
d.push_back (line & 0x03);
d.push_back (align & 0x07);
diff --git a/libs/surfaces/faderport8/fp8_controls.cc b/libs/surfaces/faderport8/fp8_controls.cc
index 7ce1dfe5d4..6edbd556a0 100644
--- a/libs/surfaces/faderport8/fp8_controls.cc
+++ b/libs/surfaces/faderport8/fp8_controls.cc
@@ -156,11 +156,11 @@ FP8Controls::FP8Controls (FP8Base& b)
BindMix (BtnMUser, MixUser);
/* create channelstrips */
- for (uint8_t id = 0; id < 8; ++id) {
+ for (uint8_t id = 0; id < N_STRIPS; ++id) {
chanstrip[id] = new FP8Strip (b, id);
- _midimap_strip[0x08 + id] = &(chanstrip[id]->solo_button());
- _midimap_strip[0x10 + id] = &(chanstrip[id]->mute_button());
- _midimap_strip[0x18 + id] = &(chanstrip[id]->selrec_button());
+ _midimap_strip[FP8Strip::midi_ctrl_id (FP8Strip::BtnSolo, id)] = &(chanstrip[id]->solo_button());
+ _midimap_strip[FP8Strip::midi_ctrl_id (FP8Strip::BtnMute, id)] = &(chanstrip[id]->mute_button());
+ _midimap_strip[FP8Strip::midi_ctrl_id (FP8Strip::BtnSelect, id)] = &(chanstrip[id]->selrec_button());
}
/* set User button names */
@@ -190,7 +190,7 @@ FP8Controls::~FP8Controls ()
for (MidiButtonMap::const_iterator i = _midimap.begin (); i != _midimap.end (); ++i) {
delete i->second;
}
- for (uint8_t id = 0; id < 8; ++id) {
+ for (uint8_t id = 0; id < N_STRIPS; ++id) {
delete chanstrip[id];
}
_midimap_strip.clear ();
@@ -260,7 +260,7 @@ FP8Controls::initialize ()
button (BtnMFX).set_color (0x0000ffff);
button (BtnMUser).set_color (0x0000ffff);
- for (uint8_t id = 0; id < 8; ++id) {
+ for (uint8_t id = 0; id < N_STRIPS; ++id) {
chanstrip[id]->initialize ();
}
@@ -298,7 +298,7 @@ FP8Controls::button (ButtonId id)
FP8Strip&
FP8Controls::strip (uint8_t id)
{
- assert (id < 8);
+ assert (id < N_STRIPS);
return *chanstrip[id];
}
@@ -326,14 +326,14 @@ FP8Controls::midi_event (uint8_t id, uint8_t val)
bool
FP8Controls::midi_touch (uint8_t id, uint8_t val)
{
- assert (id < 8);
+ assert (id < N_STRIPS);
return chanstrip[id]->midi_touch (val > 0x40);
}
bool
FP8Controls::midi_fader (uint8_t id, unsigned short val)
{
- assert (id < 8);
+ assert (id < N_STRIPS);
return chanstrip[id]->midi_fader ((val >> 4) / 1023.f);
}
diff --git a/libs/surfaces/faderport8/fp8_controls.h b/libs/surfaces/faderport8/fp8_controls.h
index 868063c16d..9b015bea54 100644
--- a/libs/surfaces/faderport8/fp8_controls.h
+++ b/libs/surfaces/faderport8/fp8_controls.h
@@ -154,7 +154,7 @@ protected:
CtrlButtonMap _ctrlmap;
MidiButtonMap _midimap_strip;
- FP8Strip* chanstrip[8];
+ FP8Strip* chanstrip[N_STRIPS];
FP8Types::FaderMode _fadermode;
FP8Types::NavigationMode _navmode;
diff --git a/libs/surfaces/faderport8/fp8_strip.cc b/libs/surfaces/faderport8/fp8_strip.cc
index 5de996a294..be1122a03f 100644
--- a/libs/surfaces/faderport8/fp8_strip.cc
+++ b/libs/surfaces/faderport8/fp8_strip.cc
@@ -33,18 +33,44 @@ using namespace ARDOUR;
using namespace ArdourSurface;
using namespace ArdourSurface::FP8Types;
+uint8_t /* static */
+FP8Strip::midi_ctrl_id (CtrlElement type, uint8_t id)
+{
+ assert (id < N_STRIPS);
+ switch (type) {
+ case BtnSolo:
+ return 0x08 + id;
+ case BtnMute:
+ return 0x10 + id;
+ case BtnSelect:
+ return 0x18 + id;
+ case Fader:
+ return 0xe0 + id;
+ case Meter:
+ return 0xd0 + id;
+ case Redux:
+ return 0xd8 + id;
+ case BarVal:
+ return 0x30 + id;
+ case BarMode:
+ return 0x38 + id;
+ }
+ assert (0);
+ return 0;
+}
+
FP8Strip::FP8Strip (FP8Base& b, uint8_t id)
: _base (b)
, _id (id)
- , _solo (b, 0x08 + id)
- , _mute (b, 0x10 + id)
- , _selrec (b, 0x18 + id, true)
+ , _solo (b, midi_ctrl_id (BtnSolo, id))
+ , _mute (b, midi_ctrl_id (BtnMute, id))
+ , _selrec (b, midi_ctrl_id (BtnSelect, id), true)
, _touching (false)
, _strip_mode (0)
, _bar_mode (0)
, _displaymode (Stripables)
{
- assert (id < 8);
+ assert (id < N_STRIPS);
_last_fader = 65535;
_last_meter = _last_redux = _last_barpos = 0xff;
@@ -121,10 +147,10 @@ FP8Strip::initialize ()
set_bar_mode (4); // off
- _base.tx_midi2 (0xd0 + _id, 0); // reset meter
- _base.tx_midi2 (0xd8 + _id, 0); // reset redux
+ _base.tx_midi2 (midi_ctrl_id (Meter, _id), 0); // reset meter
+ _base.tx_midi2 (midi_ctrl_id (Redux, _id), 0); // reset redux
- _base.tx_midi3 (0xe0 + _id, 0, 0); // fader
+ _base.tx_midi3 (midi_ctrl_id (Fader, _id), 0, 0); // fader
/* clear cached values */
_last_fader = 65535;
@@ -398,7 +424,7 @@ FP8Strip::notify_fader_changed ()
return;
}
_last_fader = mv;
- _base.tx_midi3 (0xe0 + _id, (mv & 0x7f), (mv >> 7) & 0x7f);
+ _base.tx_midi3 (midi_ctrl_id (Fader, _id), (mv & 0x7f), (mv >> 7) & 0x7f);
}
void
@@ -501,13 +527,13 @@ FP8Strip::periodic_update_meter ()
// TODO: deflect meter
int val = std::min (127.f, std::max (0.f, 2.f * dB + 127.f));
if (val != _last_meter || val > 0) {
- _base.tx_midi2 (0xd0 + _id, val & 0x7f); // falls off automatically
+ _base.tx_midi2 (midi_ctrl_id (Meter, _id), val & 0x7f); // falls off automatically
_last_meter = val;
}
} else if (show_meters) {
if (0 != _last_meter) {
- _base.tx_midi2 (0xd0 + _id, 0);
+ _base.tx_midi2 (midi_ctrl_id (Meter, _id), 0);
_last_meter = 0;
}
}
@@ -518,12 +544,12 @@ FP8Strip::periodic_update_meter ()
// TODO: deflect redux
int val = std::min (127.f, std::max (0.f, rx));
if (val != _last_redux) {
- _base.tx_midi2 (0xd8 + _id, val & 0x7f);
+ _base.tx_midi2 (midi_ctrl_id (Redux, _id), val & 0x7f);
_last_redux = val;
}
} else if (show_meters) {
if (0 != _last_redux) {
- _base.tx_midi2 (0xd8 + _id, 0);
+ _base.tx_midi2 (midi_ctrl_id (Redux, _id), 0);
_last_redux = 0;
}
}
@@ -535,7 +561,7 @@ FP8Strip::periodic_update_meter ()
float barpos = _fader_ctrl->internal_to_interface (_fader_ctrl->get_value());
int val = std::min (127.f, std::max (0.f, barpos * 128.f));
if (val != _last_barpos) {
- _base.tx_midi3 (0xb0, 0x30 + _id, val & 0x7f);
+ _base.tx_midi3 (0xb0, midi_ctrl_id (BarVal, _id), val & 0x7f);
_last_barpos = val;
}
} else {
@@ -559,7 +585,7 @@ FP8Strip::periodic_update_meter ()
int val = std::min (127.f, std::max (0.f, panpos * 128.f));
set_bar_mode (have_panner ? 1 : 4); // Bipolar or Off
if (val != _last_barpos && have_panner) {
- _base.tx_midi3 (0xb0, 0x30 + _id, val & 0x7f);
+ _base.tx_midi3 (0xb0, midi_ctrl_id (BarVal, _id), val & 0x7f);
_last_barpos = val;
}
if (_base.twolinetext ()) {
@@ -620,12 +646,12 @@ FP8Strip::set_bar_mode (uint8_t bar_mode, bool force)
}
if (bar_mode == 4) {
- _base.tx_midi3 (0xb0, 0x30 + _id, 0);
+ _base.tx_midi3 (0xb0, midi_ctrl_id (BarVal, _id), 0);
_last_barpos = 0xff;
}
_bar_mode = bar_mode;
- _base.tx_midi3 (0xb0, 0x38 + _id, bar_mode);
+ _base.tx_midi3 (0xb0, midi_ctrl_id (BarMode, _id), bar_mode);
}
void
diff --git a/libs/surfaces/faderport8/fp8_strip.h b/libs/surfaces/faderport8/fp8_strip.h
index 200dae86cb..c301dad7ed 100644
--- a/libs/surfaces/faderport8/fp8_strip.h
+++ b/libs/surfaces/faderport8/fp8_strip.h
@@ -28,6 +28,8 @@
#include "fp8_base.h"
#include "fp8_button.h"
+#define N_STRIPS 8
+
namespace ARDOUR {
class Stripable;
class AutomationControl;
@@ -43,6 +45,19 @@ public:
FP8Strip (FP8Base& b, uint8_t id);
~FP8Strip ();
+ enum CtrlElement {
+ BtnSolo,
+ BtnMute,
+ BtnSelect,
+ Fader,
+ Meter,
+ Redux,
+ BarVal,
+ BarMode
+ };
+
+ static uint8_t midi_ctrl_id (CtrlElement type, uint8_t id);
+
FP8ButtonInterface& solo_button () { return _solo; }
FP8ButtonInterface& mute_button () { return _mute; }
FP8ButtonInterface& selrec_button () { return _selrec; }