Added support for showing band and voice on a LCD display.

Added initial support for two encoder+switches.
pull/4/head
Holger Wirtz 6 years ago
parent e93d8f6eac
commit 8c4095ca08
  1. 52
      MicroDexed.ino
  2. 13
      config.h
  3. 16
      dexed_sysex.cpp
  4. 8
      dexed_sysex.h

@ -36,20 +36,28 @@
#ifdef USE_ONBOARD_USB_HOST #ifdef USE_ONBOARD_USB_HOST
#include <USBHost_t36.h> #include <USBHost_t36.h>
#endif #endif
#ifndef MASTER_KEY_MIDI // selecting sounds by encoder, button and display
#ifdef I2C_DISPLAY // selecting sounds by encoder, button and display
#include <Bounce.h> #include <Bounce.h>
#include <Encoder.h> #include <Encoder.h>
#endif
#ifdef I2C_DISPLAY
#include <LiquidCrystalPlus_I2C.h> #include <LiquidCrystalPlus_I2C.h>
#endif #endif
#ifndef MASTER_KEY_MIDI #ifdef I2C_DISPLAY
Encoder enc_l(ENC_L_PIN_A, ENC_L_PIN_B);
Bounce but_l = Bounce(BUT_L_PIN, 10); // 10 ms debounce
Encoder enc_r(ENC_R_PIN_A, ENC_R_PIN_B);
Bounce but_r = Bounce(BUT_R_PIN, 10); // 10 ms debounce
#endif
#ifdef I2C_DISPLAY
// [I2C] SCL: Pin 19, SDA: Pin 18 (https://www.pjrc.com/teensy/td_libs_Wire.html) // [I2C] SCL: Pin 19, SDA: Pin 18 (https://www.pjrc.com/teensy/td_libs_Wire.html)
#define LCD_I2C_ADDRESS 0x27 #define LCD_I2C_ADDRESS 0x27
#define LCD_CHARS 16 #define LCD_CHARS 16
#define LCD_LINES 2 #define LCD_LINES 2
LiquidCrystalPlus_I2C lcd(LCD_I2C_ADDRESS, LCD_CHARS, LCD_LINES); LiquidCrystalPlus_I2C lcd(LCD_I2C_ADDRESS, LCD_CHARS, LCD_LINES);
Encoder enc1(ENC1_PIN_A, ENC1_PIN_B);
Bounce but1 = Bounce(BUT1_PIN, 10); // 10 ms debounce
#endif #endif
// GUItool: begin automatically generated code // GUItool: begin automatically generated code
@ -87,7 +95,8 @@ uint8_t voice = 0;
float vol = VOLUME; float vol = VOLUME;
float vol_right = 1.0; float vol_right = 1.0;
float vol_left = 1.0; float vol_left = 1.0;
char bank_name[10];
char voice_name[10];
#ifdef MASTER_KEY_MIDI #ifdef MASTER_KEY_MIDI
bool master_key_enabled = false; bool master_key_enabled = false;
#endif #endif
@ -116,7 +125,7 @@ void setup()
Serial.begin(SERIAL_SPEED); Serial.begin(SERIAL_SPEED);
delay(220); delay(220);
#ifndef MASTER_KEY_MIDI #ifndef I2C_DISPLAY
lcd.init(); lcd.init();
lcd.blink_off(); lcd.blink_off();
lcd.cursor_off(); lcd.cursor_off();
@ -126,7 +135,8 @@ void setup()
lcd.display(); lcd.display();
lcd.show(0, 0, 20, "MicroDexed"); lcd.show(0, 0, 20, "MicroDexed");
enc1.write(INITIAL_ENC1_VALUE); enc_l.write(INITIAL_ENC_L_VALUE);
enc_r.write(INITIAL_ENC_R_VALUE);
#endif #endif
Serial.println(F("MicroDexed based on https://github.com/asb2m10/dexed")); Serial.println(F("MicroDexed based on https://github.com/asb2m10/dexed"));
@ -165,11 +175,20 @@ void setup()
if (!SD.begin(SDCARD_CS_PIN)) if (!SD.begin(SDCARD_CS_PIN))
{ {
Serial.println(F("SD card not accessable")); Serial.println(F("SD card not accessable"));
strcpy(bank_name, "Default");
strcpy(voice_name, "FM-Piano");
} }
else else
{ {
Serial.println(F("SD card found.")); Serial.println(F("SD card found."));
sd_card_available = true; sd_card_available = true;
// load default SYSEX data
load_sysex(bank, voice);
#ifdef I2C_DISPLAY
enc_l.write(bank);
enc_r.write(voice);
#endif
} }
#if defined (DEBUG) && defined (SHOW_CPU_LOAD_MSEC) #if defined (DEBUG) && defined (SHOW_CPU_LOAD_MSEC)
@ -178,8 +197,7 @@ void setup()
AudioMemoryUsageMaxReset(); AudioMemoryUsageMaxReset();
#endif #endif
// load default SYSEX data
load_sysex(bank, voice);
#ifdef DEBUG #ifdef DEBUG
Serial.print(F("Bank/Voice from EEPROM [")); Serial.print(F("Bank/Voice from EEPROM ["));
@ -209,6 +227,11 @@ void setup()
cpu_mem_millis = 0; cpu_mem_millis = 0;
#endif #endif
#ifndef I2C_DISPLAY
lcd.show(1, 0, 3, data1);
lcd.show(1, 4, 3, data2);
#endif
#ifdef TEST_NOTE #ifdef TEST_NOTE
//dexed->data[DEXED_VOICE_OFFSET+DEXED_LFO_PITCH_MOD_DEP] = 99; // full pitch mod depth //dexed->data[DEXED_VOICE_OFFSET+DEXED_LFO_PITCH_MOD_DEP] = 99; // full pitch mod depth
//dexed->data[DEXED_VOICE_OFFSET+DEXED_LFO_PITCH_MOD_SENS] = 99; // full pitch mod sense //dexed->data[DEXED_VOICE_OFFSET+DEXED_LFO_PITCH_MOD_SENS] = 99; // full pitch mod sense
@ -252,11 +275,10 @@ void loop()
elapsedMicros t1; elapsedMicros t1;
dexed->getSamples(AUDIO_BLOCK_SAMPLES, audio_buffer); dexed->getSamples(AUDIO_BLOCK_SAMPLES, audio_buffer);
uint32_t t2 = t1; if (t1 > audio_block_time_ms) // everything greater 2.9ms is a buffer underrun!
if (t2 > audio_block_time_ms) // everything greater 2.9ms is a buffer underrun!
xrun++; xrun++;
if (t2 > render_time_max) if (t1 > render_time_max)
render_time_max = t2; render_time_max = t1;
if (peak1.available()) if (peak1.available())
{ {
if (peak1.read() > 0.99) if (peak1.read() > 0.99)
@ -329,10 +351,6 @@ void print_midi_event(uint8_t type, uint8_t data1, uint8_t data2)
Serial.print(data1, DEC); Serial.print(data1, DEC);
Serial.print(F(", data2: ")); Serial.print(F(", data2: "));
Serial.println(data2, DEC); Serial.println(data2, DEC);
#ifndef MASTER_KEY_MIDI
lcd.show(1, 0, 3, data1);
lcd.show(1, 4, 3, data2);
#endif
} }
#endif #endif
#endif #endif

@ -32,6 +32,7 @@
#define MIDI_DEVICE Serial1 #define MIDI_DEVICE Serial1
#define USE_ONBOARD_USB_HOST 1 #define USE_ONBOARD_USB_HOST 1
#define TEENSY_AUDIO_BOARD 1 #define TEENSY_AUDIO_BOARD 1
#define I2C_DISPLAY 1
#define VOLUME 0.6 #define VOLUME 0.6
#define DEFAULT_MIDI_CHANNEL MIDI_CHANNEL_OMNI #define DEFAULT_MIDI_CHANNEL MIDI_CHANNEL_OMNI
#define DEFAULT_SYSEXBANK 0 #define DEFAULT_SYSEXBANK 0
@ -78,10 +79,14 @@
#define SDCARD_SCK_PIN 13 // not actually used #define SDCARD_SCK_PIN 13 // not actually used
// Encoder with button // Encoder with button
#define ENC1_PIN_A 14 #define ENC_L_PIN_A 2
#define ENC1_PIN_B 15 #define ENC_L_PIN_B 3
#define BUT1_PIN 16 #define BUT_L_PIN 4
#define INITIAL_ENC1_VALUE 0 #define INITIAL_ENC_L_VALUE 0
#define ENC_R_PIN_A 5
#define ENC_R_PIN_B 24
#define BUT_R_PIN 25
#define INITIAL_ENC_R_VALUE 0
// EEPROM address // EEPROM address
#define EEPROM_OFFSET 0 #define EEPROM_OFFSET 0

@ -81,6 +81,8 @@ bool load_sysex(uint8_t b, uint8_t v)
Serial.print(F(" [")); Serial.print(F(" ["));
Serial.print(n); Serial.print(n);
Serial.println(F("]")); Serial.println(F("]"));
strcpy(bank_name, bankdir);
strcpy(voice_name, entry.name());
#endif #endif
return (dexed->loadSysexVoice(data)); return (dexed->loadSysexVoice(data));
} }
@ -94,6 +96,16 @@ bool load_sysex(uint8_t b, uint8_t v)
} }
} }
} }
#ifdef I2C_DISPLAY
char tmp[3];
itoa(bank, tmp, 10);
lcd.show(0, 0, 2, tmp);
lcd.show(0, 3, 10, bank_name);
itoa(voice, tmp, 10);
lcd.show(1, 0, 2, tmp);
lcd.show(1, 3, 10, voice_name);
#endif
#ifdef DEBUG #ifdef DEBUG
if (found == false) if (found == false)
Serial.println(F("E: File not found.")); Serial.println(F("E: File not found."));
@ -195,7 +207,7 @@ bool get_sysex_voice(char* dir, File sysex, uint8_t voice_number, uint8_t* data)
} }
#endif #endif
render_time_max=0; render_time_max = 0;
return (true); return (true);
} }

@ -23,11 +23,19 @@
*/ */
#include "config.h"
#ifdef I2C_DISPLAY
#include <LiquidCrystalPlus_I2C.h>
#endif
extern bool sd_card_available; extern bool sd_card_available;
extern Dexed* dexed; extern Dexed* dexed;
extern uint16_t render_time_max; extern uint16_t render_time_max;
extern uint8_t bank; extern uint8_t bank;
extern uint8_t voice; extern uint8_t voice;
extern char bank_name[10];
extern char voice_name[10];
extern LiquidCrystalPlus_I2C lcd;
bool load_sysex(uint8_t b, uint8_t v); bool load_sysex(uint8_t b, uint8_t v);
bool get_sysex_voice(char* dir, File sysex, uint8_t voice_number, uint8_t* data); bool get_sysex_voice(char* dir, File sysex, uint8_t voice_number, uint8_t* data);

Loading…
Cancel
Save