int32 row
frac32.positive v0
frac32.positive v1
frac32.positive v2
frac32.positive v3
frac32.positive v4
frac32.positive v5
frac32.positive v6
frac32.positive v7
bool32.risingfalling mute
bool32.rising redraw
None
bool trig;
char text[77];
uint8_t data[77] = {240, 71, 127, 21};
int8_t fb;
int16_t nb;
uint8_t celloffset[8] = {0, 9, 17, 26, 34, 43, 51, 60};
int32_t in[8];
int32_t prev[8];
int32_t v;
int i;
int ii;
bool doit;
#define BARS_ONE_L 0x03
#define BARS_ONE_R 0x04
#define BARS_TWO 0x05
#define BARS_NONE 0x06
data[5] = 0;
data[6] = 69;
data[7] = 0;
data[76] = 247;
if (!inlet_mute) {
in[0] = inlet_v0;
in[1] = inlet_v1;
in[2] = inlet_v2;
in[3] = inlet_v3;
in[4] = inlet_v4;
in[5] = inlet_v5;
in[6] = inlet_v6;
in[7] = inlet_v7;
if (!doit) {
for (i = 0; i < 8; i++)
if (in[i] != prev[i]) {
prev[i] = in[i];
doit = 1;
}
}
if (inlet_redraw && !trig) {
trig = 1;
doit = 1;
}
if (!inlet_redraw)
trig = 0;
if (doit && !MidiGetOutputBufferPending(MIDI_DEVICE_USB_HOST)) {
data[4] = inlet_row + 24;
for (i = 0; i < 8; i++) {
for (ii = 0; ii < 8; ii++)
text[ii + celloffset[i]] = BARS_NONE;
v = in[i];
if (v <= 0)
v = 0;
nb = (((v >> 20) + 1) << 4) >> 7;
fb = nb >> 1;
for (ii = 0; ii < fb; ii++)
text[ii + celloffset[i]] = BARS_TWO;
if (nb % 2)
text[fb + celloffset[i]] = BARS_ONE_L;
}
for (i = 0; i < 68; i++)
data[i + 8] = text[i] ? text[i] : 32;
MidiSendSysEx(MIDI_DEVICE_USB_HOST, 2, data, 77);
doit = 0;
}
}