Plays samples from SPI flash. USB mass storage conflicts with USB MIDI so it's commented out for now

This commit is contained in:
Oleksiy 2021-08-17 22:29:10 +03:00
parent dc973522c9
commit d1671f7992
1 changed files with 119 additions and 80 deletions

View File

@ -1,49 +1,21 @@
#include "Audio.h"
#include "Adafruit_NeoTrellisM4.h"
#include <Audio.h>
#include <play_fs_wav.h>
#include <Adafruit_NeoTrellisM4.h>
#include <Wire.h>
#include <Adafruit_Sensor.h>
#include <Adafruit_ADXL343.h>
#include "AudioSampleG1_1.h"
#include "AudioSampleG1_2.h"
#include "AudioSampleG1_3.h"
#include "AudioSampleG1_4.h"
#include "AudioSampleG1_5.h"
#include "AudioSampleG1_6.h"
#include "AudioSampleG1_7.h"
//#include "AudioSampleG2_1.h"
//#include "AudioSampleG2_2.h"
//#include "AudioSampleG2_3.h"
//#include "AudioSampleG2_4.h"
//#include "AudioSampleG2_5.h"
//#include "AudioSampleG2_6.h"
//#include "AudioSampleG2_7.h"
#include "AudioSampleG3_1.h"
#include "AudioSampleG3_2.h"
#include "AudioSampleG3_3.h"
#include "AudioSampleG3_4.h"
#include "AudioSampleG3_5.h"
#include "AudioSampleG3_6.h"
#include "AudioSampleG3_7.h"
//#include "AudioSampleG4_1.h"
//#include "AudioSampleG4_2.h"
//#include "AudioSampleG4_3.h"
//#include "AudioSampleG4_4.h"
//#include "AudioSampleG4_5.h"
//#include "AudioSampleG4_6.h"
//#include "AudioSampleG4_7.h"
#include <Adafruit_SPIFlash.h>
// #include <Adafruit_TinyUSB.h> conflicts with Adafruit_NeoTrellisM4.h due to MIDI USB
#define BPM 160
// GUItool: begin automatically generated code
AudioPlayMemory playMem1; //xy=275,499
AudioPlayMemory playMem2; //xy=284,532.5
AudioPlayMemory playMem3; //xy=294,566.5
AudioPlayMemory playMem4; //xy=302,599.5
AudioPlayFSWav playMem1; //xy=275,499
AudioPlayFSWav playMem2; //xy=284,532.5
AudioPlayFSWav playMem3; //xy=294,566.5
AudioPlayFSWav playMem4; //xy=302,599.5
AudioMixer4 mixer1; //xy=491,517
AudioSynthWaveformDc dc1; //xy=507,581
AudioFilterStateVariable filter1; //xy=649,502
@ -57,7 +29,13 @@ AudioConnection patchCord6(dc1, 0, dacs1, 1);
AudioConnection patchCord7(filter1, 0, dacs1, 0);
// GUItool: end automatically generated code
int timeToClick;
//Flash memory stuff
Adafruit_FlashTransport_QSPI flashTransport(PIN_QSPI_SCK, PIN_QSPI_CS, PIN_QSPI_IO0, PIN_QSPI_IO1, PIN_QSPI_IO2, PIN_QSPI_IO3);
Adafruit_SPIFlash flash(&flashTransport);
FatFileSystem fatfs;
/*FatFile root; //related to USB Mass Storage
FatFile file;
Adafruit_USBD_MSC usb_msc;*/
Adafruit_NeoTrellisM4 trellis = Adafruit_NeoTrellisM4();
Adafruit_ADXL343 accel = Adafruit_ADXL343(50, &Wire1); //50 does not mean anything here, just a random id
@ -69,6 +47,8 @@ int colors[] = {
0x100800
};
int timeToClick;
int G1[] = {0,1,8,9,16,17,24,25};
int G2[] = {2,3,10,11,18,19,26,27};
int G3[] = {4,5,12,13,20,21,28,29};
@ -90,6 +70,37 @@ int EighthNote = 60000 / (BPM * 2);
int clickOn;
//bool USBFlash = false;
File sample1;
File sample2;
File sample3;
File sample4;
void setup() {
Serial.begin(115200);
trellis.begin();
trellis.setBrightness(127);
accel.begin();
AudioMemory(32);
redrawAndPlay();
filter1.resonance(2.2); //from 0.7 to 5
flash.begin();
/*if (USBFlash) { //related to USB Mass Storage
usb_msc.setID("Adafruit", "External Flash", "1.0");
usb_msc.setReadWriteCallback(msc_read_cb, msc_write_cb, msc_flush_cb);
usb_msc.setCapacity(flash.size()/512, 512);
usb_msc.setUnitReady(true);
usb_msc.begin();
}*/
fatfs.begin(&flash);
};
void clockTick(){
if(millis() >= timeToClick) {
timeToClick = millis() + EighthNote; //214 should be ~1/8 at 140 bpm
@ -107,6 +118,8 @@ void clickOff() {
}
void updatePlay() {
//if there's less than 30ms until the end of the sample, retriger it to prevent gap
if (playMem1.lengthMillis() - playMem1.positionMillis() < 30) {
G1Trigger = 1;
@ -115,25 +128,32 @@ void updatePlay() {
G1Trigger = 0;
switch (G1Select) {
case 6:
playMem1.play(AudioSampleG1_1);
sample1 = fatfs.open("G1_1.wav");
playMem1.play(sample1);
break;
case 4:
playMem1.play(AudioSampleG1_2);
sample1 = fatfs.open("G1_2.wav");
playMem1.play(sample1);
break;
case 2:
playMem1.play(AudioSampleG1_3);
sample1 = fatfs.open("G1_3.wav");
playMem1.play(sample1);
break;
case 0:
playMem1.play(AudioSampleG1_4);
sample1 = fatfs.open("G1_4.wav");
playMem1.play(sample1);
break;
case 1:
playMem1.play(AudioSampleG1_5);
sample1 = fatfs.open("G1_5.wav");
playMem1.play(sample1);
break;
case 3:
playMem1.play(AudioSampleG1_6);
sample1 = fatfs.open("G1_6.wav");
playMem1.play(sample1);
break;
case 5:
playMem1.play(AudioSampleG1_7);
sample1 = fatfs.open("G1_7.wav");
playMem1.play(sample1);
break;
}
}
@ -144,25 +164,32 @@ void updatePlay() {
G2Trigger = 0;
switch (G2Select) {
case 6:
//playMem2.play(AudioSampleG2_1);
sample2 = fatfs.open("G2_1.wav");
playMem2.play(sample2);
break;
case 4:
//playMem2.play(AudioSampleG2_2);
sample2 = fatfs.open("G2_2.wav");
playMem2.play(sample2);
break;
case 2:
//playMem2.play(AudioSampleG2_3);
sample2 = fatfs.open("G2_3.wav");
playMem2.play(sample2);
break;
case 0:
//playMem2.play(AudioSampleG2_4);
sample2 = fatfs.open("G2_4.wav");
playMem2.play(sample2);
break;
case 1:
//playMem2.play(AudioSampleG2_5);
sample2 = fatfs.open("G2_5.wav");
playMem2.play(sample2);
break;
case 3:
//playMem2.play(AudioSampleG2_6);
sample2 = fatfs.open("G2_6.wav");
playMem2.play(sample2);
break;
case 5:
//playMem2.play(AudioSampleG2_7);
sample2 = fatfs.open("G2_7.wav");
playMem2.play(sample2);
break;
}
}
@ -173,25 +200,32 @@ void updatePlay() {
G3Trigger = 0;
switch (G3Select) {
case 6:
playMem3.play(AudioSampleG3_1);
sample3= fatfs.open("G3_1.wav");
playMem3.play(sample3);
break;
case 4:
playMem3.play(AudioSampleG3_2);
sample3= fatfs.open("G3_2.wav");
playMem3.play(sample3);
break;
case 2:
playMem3.play(AudioSampleG3_3);
sample3= fatfs.open("G3_3.wav");
playMem3.play(sample3);
break;
case 0:
playMem3.play(AudioSampleG3_4);
sample3= fatfs.open("G3_4.wav");
playMem3.play(sample3);
break;
case 1:
playMem3.play(AudioSampleG3_5);
sample3= fatfs.open("G3_5.wav");
playMem3.play(sample3);
break;
case 3:
playMem3.play(AudioSampleG3_6);
sample3= fatfs.open("G3_6.wav");
playMem3.play(sample3);
break;
case 5:
playMem3.play(AudioSampleG3_7);
sample3= fatfs.open("G3_7.wav");
playMem3.play(sample3);
break;
}
}
@ -202,25 +236,32 @@ void updatePlay() {
G4Trigger = 0;
switch (G4Select) {
case 6:
//playMem4.play(AudioSampleG4_1);
sample4= fatfs.open("G4_1.wav");
playMem4.play(sample4);
break;
case 4:
//playMem4.play(AudioSampleG4_2);
sample4= fatfs.open("G4_2.wav");
playMem4.play(sample4);
break;
case 2:
//playMem4.play(AudioSampleG4_3);
sample4= fatfs.open("G4_3.wav");
playMem4.play(sample4);
break;
case 0:
//playMem4.play(AudioSampleG4_4);
sample4= fatfs.open("G4_4.wav");
playMem4.play(sample4);
break;
case 1:
//playMem4.play(AudioSampleG4_5);
sample4= fatfs.open("G4_5.wav");
playMem4.play(sample4);
break;
case 3:
//playMem4.play(AudioSampleG4_6);
sample4= fatfs.open("G4_6.wav");
playMem4.play(sample4);
break;
case 5:
//playMem4.play(AudioSampleG4_7);
sample4= fatfs.open("G4_7.wav");
playMem4.play(sample4);
break;
}
}
@ -268,20 +309,18 @@ void redrawAndPlay() {
}
}
void setup() {
Serial.begin(115200);
trellis.begin();
trellis.setBrightness(127);
accel.begin();
AudioMemory(32);
redrawAndPlay();
filter1.resonance(2.2); //from 0.7 to 5
};
/*Flash related functions
int32_t msc_read_cb (uint32_t lba, void* buffer, uint32_t bufsize) {
return flash.readBlocks(lba, (uint8_t*) buffer, bufsize/512) ? bufsize : -1;
}
int32_t msc_write_cb (uint32_t lba, uint8_t* buffer, uint32_t bufsize) {
digitalWrite(LED_BUILTIN, HIGH);
return flash.writeBlocks(lba, buffer, bufsize/512) ? bufsize : -1;
}
void msc_flush_cb (void) {
flash.syncBlocks();
fatfs.cacheClear();
}*/
void loop() {
trellis.tick();