Description
This is a MIDI controller with analog audio scratch option; This controller software to control.
Features
- 22 retro arcade game butttons with color options
- 80 assignable buttons accessible via 4 banks
- 16 assignable potentiometers accessible via 4 banks
- 4 assignable slide potentiometer accessible via 4 banks
- Dedicated Bank Select buttons
- Ultra-compact design lets you create anywhere
- USB-powered; no power adapter required while functioning as a MIDI Controller
Hybrid Features
- Nanofader board
- Durable straight rod crossfader
- Analog audio input, output, aux input options
- 9V Battery power connection for portable purpose
Specifications
Dimension: 32cm x 25cm x 5cm
Optional 9V 1A Arduino power supply
Code
/**
*
*
* Many bankable potentiometers and buttons. Bank selector displays bank setting
* using LEDs.
* If any of the buttons is pressed, the LED on pin 22 is turned on.
*
* @boards Mega
*/
#include
#include // std::any_of
USBMIDI_Interface midi; // MIDI Interface to use
Bank<4> bank(20);
// Create a new bank selector that changes the bank setting of the bank we just
// created.
// It has push buttons connected to pins 21 and 20 that increment or decrement
// the bank setting, and 4 LEDs to pins 46, 48, 50, 52 that display the current
// bank setting.
IncrementDecrementSelectorLEDs<4> bankSelector = {
bank,
{35, 37}, // button pins
{39, 41, 43, 45}, // LED pins
};
using namespace MIDI_CC;
Bankable::CCPotentiometer potentiometers[] = {
{bank, A4, {0x4A, CHANNEL_2}},
{bank, A5, {0x4B, CHANNEL_2}},
{bank, A6, {0x4C, CHANNEL_2}},
};
Bankable::NoteButton muteButtons[] = {
{bank, 13, 0x14},
{bank, 12, 0x15},
{bank, 11, 0x16},
{bank, 10, 0x17},
{bank, 9, 0x18},
{bank, 8, 0x19},
{bank, 14, 0x1A},
{bank, 15, 0x1B},
{bank, 16, 0x1C},
{bank, 17, 0x1D},
{bank, 18, 0x1E},
{bank, 19, 0x1F},
{bank, 20, 0x20},
{bank, 21, 0x21},
{bank, 23, 0x22},
{bank, 25, 0x23},
{bank, 27, 0x24},
{bank, 29, 0x25},
{bank, 31, 0x26},
{bank, 33, 0x27},
};
constexpr pin_t ledPin = 47;
// :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: //
void setup() {
Control_Surface.begin();
pinMode(ledPin, OUTPUT);
}
// :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: //
void loop() {
Control_Surface.loop();
// Function that checks if a given button is pressed
auto checkButtonPressed = [](const Bankable::NoteButton &button) {
return button.getButtonState() == Button::Pressed;
};
// If any of the push buttons is pressed
bool pressed = std::any_of(std::begin(muteButtons), std::end(muteButtons),
checkButtonPressed);
// Turn on the LED
digitalWrite(ledPin, pressed);
}