#include <MIDI_Inputs/LEDs/MCU/VULEDs.hpp>
A MIDI input element that represents a Mackie Control Universal VU meter and displays its value using LEDs.
This version can be banked.
BankSize | The number of banks. |
NumLEDs | The number of LEDs for the VU meter display. Recommended value is 12, because this is the range that's sent over MIDI. |
Definition at line 134 of file VULEDs.hpp.
Data access | |
uint8_t | getValue (uint8_t bank) const |
Get the most recent VU position that was received for the given bank. | |
uint8_t | getValue () override |
Get the most recent VU position that was received for the active bank. | |
bool | getOverload (uint8_t bank) const |
Get the status of the overload indicator for the given bank. | |
bool | getOverload () override |
Get the status of the overload indicator for the active bank. | |
float | getFloatValue (uint8_t bank) const |
Get the most recent VU position for the given bank as a value between 0 and 1. | |
float | getFloatValue () override |
Get the most recent VU position for the active bank as a value between 0 and 1. | |
Enabling and disabling updatables | |
void | enable () |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically. | |
void | disable () |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically. | |
bool | isEnabled () const |
Check if this updatable is enabled. | |
void | moveDown () |
Move down this element in the list. | |
static void | enable (UpdatableCRTP *element) |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically. | |
static void | enable (UpdatableCRTP &element) |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically. | |
static void | enable (U(&array)[N]) |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically. | |
static void | disable (UpdatableCRTP *element) |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically. | |
static void | disable (UpdatableCRTP &element) |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically. | |
static void | disable (U(&array)[N]) |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically. | |
Detecting changes | |
bool | getDirty () const |
Check if the value was updated since the last time the dirty flag was cleared. | |
void | clearDirty () |
Clear the dirty flag. | |
Public Types | |
using | Parent = VU<BankSize> |
using | Matcher = typename Parent::Matcher |
using | MessageType = typename MIDIInputElement<Type>::MessageType |
Public Member Functions | |
VULEDs (BankConfig< BankSize > config, const PinList< NumLEDs > &leds, uint8_t track, MIDIChannelCable channelCN, unsigned int decayTime=VUDecay::Default) | |
VULEDs (BankConfig< BankSize > config, const PinList< NumLEDs > &leds, uint8_t track, unsigned int decayTime=VUDecay::Default) | |
void | begin () override |
Initialize the input element. | |
void | reset () override |
Reset all values to zero. | |
void | update () override |
Decay the VU meter. | |
bool | updateWith (MessageType midimsg) override |
Receive a new MIDI message and update the internal state. | |
uint8_t | getMax () const |
Get the maximum value that this VU meter can return. | |
void | displayVU (uint16_t value) |
void | display (uint16_t value) const |
Display the given number of LEDs on the LED bar. | |
void | display (float value) const |
Display the given fraction of the LED bar. | |
DotBarMode | getMode () const |
Get the dot/bar mode. | |
void | setMode (DotBarMode mode) |
Set the mode to either dot or bar mode. | |
void | dotMode () |
Set the mode to dot mode. | |
void | barMode () |
Set the mode to bar mode. | |
void | toggleMode () |
Toggle the dot/bar mode. | |
void | begin () const |
Initialize (set LED pins as outputs). | |
void | displayRange (uint16_t startOn, uint16_t startOff) const |
Turn on a range of the LEDs. | |
void | set (uint16_t index) const |
Turn on the given LED. | |
void | clear (uint16_t index) const |
Turn off the given LED. | |
void | clear () const |
Turn off all LEDs. | |
void | displayDot (uint16_t led) const |
Turn on a single LED, and turn off all others. | |
Static Public Member Functions | |
static bool | updateAllWith (MessageType midimsg) |
Update all. | |
static void | updateAll () |
Update all. | |
static void | beginAll () |
Begin all. | |
static void | resetAll () |
Reset all. | |
Protected Member Functions | |
void | handleUpdate (typename Matcher::Result match) override |
void | updateDisplay () |
void | onBankSettingChange () override |
A function to be executed each time the bank setting changes. | |
bool | handleUpdateImpl (typename Matcher::Result match) |
void | handleUpdate (typename Matcher::Result match) override |
bool | decay () |
uint8_t | getActiveBank () const |
Protected Attributes | |
Matcher | matcher |
Node * | next = nullptr |
BankSettingChangeCallback * | next |
Node * | previous = nullptr |
BankSettingChangeCallback * | previous |
uint8_t | max |
bool | alwaysDirty |
bool | dirty = true |
Static Protected Attributes | |
static DoublyLinkedList< MIDIInputElement< Type > > | updatables |
Private Attributes | |
AH::Array< VUState, BankSize > | states = {{}} |
AH::Timer< millis > | decayTimer |
DotBarMode | mode |
const PinList< N > | ledPins |
Static Private Attributes | |
static constexpr uint8_t | FLOOR_CORRECTION = 5 |
Definition at line 136 of file VULEDs.hpp.
using Matcher = typename Parent::Matcher |
Definition at line 137 of file VULEDs.hpp.
|
inherited |
Definition at line 93 of file MIDIInputElement.hpp.
|
inline |
config | The bank configuration to use. |
leds | The pins with the LEDs connected. |
track | The track of the VU meter. [1, 8] |
channelCN | The MIDI channel [Channel_1, Channel_16] and Cable Number [Cable_1, Cable_16]. |
decayTime | The time in milliseconds it takes for the value to decay one step. The MCU protocol uses 300 ms per division, and two steps per division, so the default is 150 ms per step. Some software doesn't work if the VU meter decays automatically, in that case, you can set the decay time to zero to disable the decay. |
Definition at line 157 of file VULEDs.hpp.
|
inline |
config | The bank configuration to use. |
leds | The pins with the LEDs connected. |
track | The track of the VU meter. [1, 8] |
decayTime | The time in milliseconds it takes for the value to decay one step. The MCU protocol uses 300 ms per division, and two steps per division, so the default is 150 ms per step. Some software doesn't work if the VU meter decays automatically, in that case, you can set the decay time to zero to disable the decay. |
Definition at line 178 of file VULEDs.hpp.
|
inlineoverrideprotectedvirtual |
Implements MatchingMIDIInputElement< Type, Matcher >.
Definition at line 183 of file VULEDs.hpp.
|
inlineprotected |
Definition at line 190 of file VULEDs.hpp.
|
inlineoverridevirtual |
Initialize the input element.
Reimplemented from MIDIInputElement< Type >.
Definition at line 193 of file VULEDs.hpp.
|
inlineoverridevirtual |
Reset all values to zero.
Reimplemented from VU< BankSize >.
Definition at line 199 of file VULEDs.hpp.
|
inlineoverridevirtual |
|
inlineoverrideprotectedvirtual |
A function to be executed each time the bank setting changes.
Think of an LED that indicates whether a track is muted or not. If this LED is bankable, let's say with 4 tracks per bank, 2 banks, and a base address of 3, then this LED object keeps the state of tracks 3 and 7. When the bank setting is 0, the LED displays the state of track 3, when the bank setting is 1, the LED displays the state of track 7. To know when to update the LED, this callback is used.
Reimplemented from VU< BankSize >.
Definition at line 212 of file VULEDs.hpp.
|
inlineprotectedinherited |
|
inlineoverrideprotectedinherited |
|
inlineprotectedinherited |
|
inlineinherited |
|
inlineoverridevirtualinherited |
|
inlineinherited |
|
inlineoverridevirtualinherited |
|
inlineinherited |
|
inlineoverridevirtualinherited |
|
inlineprotectedinherited |
Definition at line 126 of file MIDIInputElement.hpp.
|
inlineoverridevirtualinherited |
Receive a new MIDI message and update the internal state.
Implements MIDIInputElement< Type >.
Definition at line 95 of file MIDIInputElement.hpp.
|
inlinestaticinherited |
Update all.
Definition at line 46 of file MIDIInputElement.hpp.
|
inlinestaticinherited |
Update all.
Definition at line 57 of file MIDIInputElement.hpp.
|
inlinestaticinherited |
Begin all.
Definition at line 62 of file MIDIInputElement.hpp.
|
inlinestaticinherited |
Reset all.
Definition at line 67 of file MIDIInputElement.hpp.
|
inlineinherited |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 96 of file Updatable.hpp.
|
inlinestaticinherited |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 125 of file Updatable.hpp.
|
inlinestaticinherited |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 127 of file Updatable.hpp.
|
inlinestaticinherited |
Enable this updatable: insert it into the linked list of instances, so it gets updated automatically.
Definition at line 130 of file Updatable.hpp.
|
inlineinherited |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 106 of file Updatable.hpp.
|
inlinestaticinherited |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 136 of file Updatable.hpp.
|
inlinestaticinherited |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 138 of file Updatable.hpp.
|
inlinestaticinherited |
Disable this updatable: remove it from the linked list of instances, so it no longer gets updated automatically.
Definition at line 141 of file Updatable.hpp.
|
inlineinherited |
Check if this updatable is enabled.
Definition at line 120 of file Updatable.hpp.
|
inlineinherited |
Move down this element in the list.
Definition at line 147 of file Updatable.hpp.
|
inlineinherited |
Check if the value was updated since the last time the dirty flag was cleared.
Definition at line 94 of file InterfaceMIDIInputElements.hpp.
|
inlineinherited |
Clear the dirty flag.
Definition at line 96 of file InterfaceMIDIInputElements.hpp.
|
inlineinherited |
Get the maximum value that this VU meter can return.
Definition at line 107 of file InterfaceMIDIInputElements.hpp.
|
inlineinherited |
value | [0, 12] |
Definition at line 20 of file VULEDs.hpp.
|
inlineinherited |
Display the given number of LEDs on the LED bar.
value | The number of the LED to activate. |
Definition at line 37 of file DotBarDisplayLEDs.hpp.
|
inlineinherited |
Display the given fraction of the LED bar.
value | The fraction of the LED bar to display. |
Definition at line 52 of file DotBarDisplayLEDs.hpp.
|
inlineinherited |
Get the dot/bar mode.
Definition at line 55 of file DotBarDisplayLEDs.hpp.
|
inlineinherited |
Set the mode to either dot or bar mode.
mode | The mode. |
Definition at line 63 of file DotBarDisplayLEDs.hpp.
|
inlineinherited |
Set the mode to dot mode.
Definition at line 66 of file DotBarDisplayLEDs.hpp.
|
inlineinherited |
Set the mode to bar mode.
Definition at line 69 of file DotBarDisplayLEDs.hpp.
|
inlineinherited |
Toggle the dot/bar mode.
Definition at line 72 of file DotBarDisplayLEDs.hpp.
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
privateinherited |
|
protectedinherited |
Definition at line 105 of file MIDIInputElement.hpp.
|
staticprotectedinherited |
Definition at line 152 of file Updatable.hpp.
|
protectedinherited |
Definition at line 320 of file LinkedList.hpp.
|
protectedinherited |
Definition at line 320 of file LinkedList.hpp.
|
protectedinherited |
Definition at line 321 of file LinkedList.hpp.
|
protectedinherited |
Definition at line 321 of file LinkedList.hpp.
|
protectedinherited |
Definition at line 110 of file InterfaceMIDIInputElements.hpp.
|
protectedinherited |
Definition at line 111 of file InterfaceMIDIInputElements.hpp.
|
protectedinherited |
Definition at line 112 of file InterfaceMIDIInputElements.hpp.
|
staticconstexprprivateinherited |
Definition at line 27 of file VULEDs.hpp.
|
privateinherited |
Definition at line 75 of file DotBarDisplayLEDs.hpp.
|
privateinherited |