updated modulation part (still needs limits and channel change)
This commit is contained in:
@ -3,17 +3,16 @@ Features:
|
|||||||
- Master BPM
|
- Master BPM
|
||||||
- Separate divider or multiplier per chennel (from /32 to x24)
|
- Separate divider or multiplier per chennel (from /32 to x24)
|
||||||
- Per-channel random pulse skip (currently only 50/50 chance)
|
- Per-channel random pulse skip (currently only 50/50 chance)
|
||||||
- 2 inputs for external modulation (currently only 1, hardcoded to channel 6)
|
- 2 inputs for external modulation
|
||||||
|
|
||||||
TODO:
|
TODO:
|
||||||
- per-channel modulation settings
|
- per-channel modulation settings
|
||||||
- different chance options for random
|
- different chance options for random
|
||||||
- External clock
|
|
||||||
- Save state to EEPROM when stopped
|
- Save state to EEPROM when stopped
|
||||||
|
- design PCB
|
||||||
|
- external clock
|
||||||
- swing
|
- swing
|
||||||
- Switch to U8G2 for screen
|
|
||||||
- settings (input mode, pulse length)
|
- settings (input mode, pulse length)
|
||||||
- Design PCB
|
|
||||||
|
|
||||||
Timer library available here
|
Timer library available here
|
||||||
https://github.com/PaulStoffregen/FlexiTimer2
|
https://github.com/PaulStoffregen/FlexiTimer2
|
||||||
|
|||||||
@ -24,9 +24,10 @@
|
|||||||
const int outsPins[6] = {5, 6, 7, 8, 9, 10};
|
const int outsPins[6] = {5, 6, 7, 8, 9, 10};
|
||||||
|
|
||||||
const int outsModes[18] = {-24, -16, -12, -8, -6, -4, -3, -2, 1, 2, 3, 4, 5, 6, 7, 8, 16, 32}; //positive - divide, negative - multiply, 0 - off
|
const int outsModes[18] = {-24, -16, -12, -8, -6, -4, -3, -2, 1, 2, 3, 4, 5, 6, 7, 8, 16, 32}; //positive - divide, negative - multiply, 0 - off
|
||||||
int outsModeIndex[6] = {8, 9, 10, 7, 6, 6}; //10 - /1, 9 - off
|
int outsModeIndex[6] = {8, 9, 10, 7, 2, 6}; //8 - 1
|
||||||
bool outsRandom[6] = {0,0,0,0,0,1};
|
bool outsRandom[6] = {0,0,0,0,0,1};
|
||||||
bool outsMod[6] = {0,0,0,0,0,1}; //0 - A1, 1 - A2
|
bool outsMod[6] = {0,0,0,0,1,1}; //0 - A1, 1 - A2
|
||||||
|
int outsModRange[6] = {0,0,0,0,4,-4};
|
||||||
int outsPeriods[6];
|
int outsPeriods[6];
|
||||||
int outsClocksCounts[6];
|
int outsClocksCounts[6];
|
||||||
int outsModesPlay[6]; //actual channel modes array updated from outsModeIndex each beat
|
int outsModesPlay[6]; //actual channel modes array updated from outsModeIndex each beat
|
||||||
@ -45,11 +46,10 @@ int needToResetChannel;
|
|||||||
bool beatCounted = false;
|
bool beatCounted = false;
|
||||||
bool pulseCounted = false;
|
bool pulseCounted = false;
|
||||||
|
|
||||||
|
|
||||||
int displayTab = 0;
|
int displayTab = 0;
|
||||||
int displayTabOld;
|
int displayTabOld;
|
||||||
bool needToChangeTab = 0;
|
int insideTab = 0;
|
||||||
bool buttonPushed = false;
|
bool playBtnPushed = false;
|
||||||
|
|
||||||
int a1Input = 0;
|
int a1Input = 0;
|
||||||
int a2Input = 0;
|
int a2Input = 0;
|
||||||
@ -80,7 +80,7 @@ void setup() {
|
|||||||
display.begin(SSD1306_SWITCHCAPVCC, SCREEN_ADDRESS);
|
display.begin(SSD1306_SWITCHCAPVCC, SCREEN_ADDRESS);
|
||||||
|
|
||||||
updateScreen();
|
updateScreen();
|
||||||
updatePeriod();
|
updateTiming();
|
||||||
|
|
||||||
FlexiTimer2::set(1, 1.0/1000, internalClock); // 1.0/1000 = 1ms period
|
FlexiTimer2::set(1, 1.0/1000, internalClock); // 1.0/1000 = 1ms period
|
||||||
FlexiTimer2::start();
|
FlexiTimer2::start();
|
||||||
@ -98,11 +98,14 @@ void internalClock() {
|
|||||||
|
|
||||||
//modulation
|
//modulation
|
||||||
for (int i = 0; i<6; i++) {
|
for (int i = 0; i<6; i++) {
|
||||||
|
int mod;
|
||||||
if (!outsMod[i]) {
|
if (!outsMod[i]) {
|
||||||
outsModesPlay[i] = outsModes[outsModeIndex[i] - a1Input];
|
mod = a1Input;
|
||||||
} else {
|
} else {
|
||||||
outsModesPlay[i] = outsModes[outsModeIndex[i] - a2Input];
|
mod = a2Input;
|
||||||
}
|
}
|
||||||
|
mod = map (mod, 0, 1023, 0, outsModRange[i]);
|
||||||
|
outsModesPlay[i] = outsModes[outsModeIndex[i] - mod]; //subtrackting because the innitiall array is backwards
|
||||||
}
|
}
|
||||||
|
|
||||||
//divider
|
//divider
|
||||||
@ -171,7 +174,7 @@ void internalClock() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void updatePeriod() {
|
void updateTiming() {
|
||||||
pulsePeriod = 60000 / (bpm * PPQN);
|
pulsePeriod = 60000 / (bpm * PPQN);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -200,15 +203,26 @@ void checkInputs() {
|
|||||||
Serial.println(encReleasedTime - encPressedTime);
|
Serial.println(encReleasedTime - encPressedTime);
|
||||||
|
|
||||||
if (encReleasedTime - encPressedTime < 500) { // press shorter than .5s switches tabs
|
if (encReleasedTime - encPressedTime < 500) { // press shorter than .5s switches tabs
|
||||||
|
if (insideTab == 0) {
|
||||||
displayTabOld = displayTab;
|
displayTabOld = displayTab;
|
||||||
displayTab++;
|
displayTab++;
|
||||||
if (displayTab>6) {
|
if (displayTab>6) {
|
||||||
displayTab = 0;
|
displayTab = 0;
|
||||||
}
|
}
|
||||||
needToChangeTab = 0;
|
} else if (insideTab < 2) {
|
||||||
|
insideTab ++;
|
||||||
|
} else {
|
||||||
|
insideTab = 1;
|
||||||
|
}
|
||||||
updateScreen();
|
updateScreen();
|
||||||
} else if (encReleasedTime - encPressedTime < 2000 && displayTab != 0) { // longer press (<2s) and switches random mode, longer than 2s presses are ignored
|
} else if (encReleasedTime - encPressedTime < 2000 && displayTab != 0) { // longer press (<2s) and switches random mode, longer than 2s presses are ignored
|
||||||
outsRandom[displayTab-1] = !outsRandom[displayTab-1];
|
if (insideTab == 0) {
|
||||||
|
insideTab = 1;
|
||||||
|
} else {
|
||||||
|
insideTab = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
//outsRandom[displayTab-1] = !outsRandom[displayTab-1];
|
||||||
updateScreen();
|
updateScreen();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -225,8 +239,8 @@ void checkInputs() {
|
|||||||
} else if (bpm < MINBPM) {
|
} else if (bpm < MINBPM) {
|
||||||
bpm = MINBPM;
|
bpm = MINBPM;
|
||||||
}
|
}
|
||||||
updatePeriod();
|
updateTiming();
|
||||||
} else {
|
} else if (displayTab != 0 && insideTab == 0) {
|
||||||
outsModeIndex[displayTab-1] = outsModeIndex[displayTab-1] - change;
|
outsModeIndex[displayTab-1] = outsModeIndex[displayTab-1] - change;
|
||||||
if (outsModeIndex[displayTab-1] < 0) {
|
if (outsModeIndex[displayTab-1] < 0) {
|
||||||
outsModeIndex[displayTab-1] = 0;
|
outsModeIndex[displayTab-1] = 0;
|
||||||
@ -234,28 +248,27 @@ void checkInputs() {
|
|||||||
outsModeIndex[displayTab-1] = (sizeof(outsModes)/sizeof(int)) - 1;
|
outsModeIndex[displayTab-1] = (sizeof(outsModes)/sizeof(int)) - 1;
|
||||||
}
|
}
|
||||||
needToResetChannel = displayTab-1;
|
needToResetChannel = displayTab-1;
|
||||||
|
} else if (displayTab != 0 && insideTab == 1) { //random
|
||||||
|
outsRandom[displayTab-1] = !outsRandom[displayTab-1];
|
||||||
|
} else if (displayTab != 0 && insideTab == 2) { //modulation
|
||||||
|
outsModRange[displayTab-1] = outsModRange[displayTab-1] + change;
|
||||||
}
|
}
|
||||||
updateScreen();
|
updateScreen();
|
||||||
encPositionOld = encPosition;
|
encPositionOld = encPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
//play button
|
//play button
|
||||||
if (!digitalRead(START_STOP_BTN_PIN) && !buttonPushed) {
|
if (!digitalRead(START_STOP_BTN_PIN) && !playBtnPushed) {
|
||||||
isPlaying = !isPlaying;
|
isPlaying = !isPlaying;
|
||||||
resetClocks();
|
resetClocks();
|
||||||
buttonPushed = true;
|
playBtnPushed = true;
|
||||||
} else if (digitalRead(START_STOP_BTN_PIN) && buttonPushed) {
|
} else if (digitalRead(START_STOP_BTN_PIN) && playBtnPushed) {
|
||||||
buttonPushed = false;
|
playBtnPushed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
//modulations
|
//modulations
|
||||||
a1Input = analogRead(ANALOGUE_INPUT_1_PIN);
|
a1Input = analogRead(ANALOGUE_INPUT_1_PIN);
|
||||||
|
|
||||||
a1Input = map (a1Input, 0, 1023, 0, 4);
|
|
||||||
a2Input = analogRead(ANALOGUE_INPUT_2_PIN);
|
a2Input = analogRead(ANALOGUE_INPUT_2_PIN);
|
||||||
Serial.println(a2Input);
|
|
||||||
a2Input = map (a2Input, 0, 1023, 0, 4);
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -320,19 +333,41 @@ void updateScreen() {
|
|||||||
|
|
||||||
//Extra params
|
//Extra params
|
||||||
display.setTextSize(1);
|
display.setTextSize(1);
|
||||||
display.print(F("RND:"));
|
|
||||||
if (displayTab != 0) {
|
if (displayTab != 0) {
|
||||||
|
if (insideTab == 1) {
|
||||||
|
display.setTextColor(SSD1306_BLACK, SSD1306_WHITE);
|
||||||
|
} else {
|
||||||
|
display.setTextColor(SSD1306_WHITE);
|
||||||
|
}
|
||||||
|
display.print(F(" RND:"));
|
||||||
if (outsRandom[displayTab-1]) {
|
if (outsRandom[displayTab-1]) {
|
||||||
display.print(F("On "));
|
display.print(F("On "));
|
||||||
} else {
|
} else {
|
||||||
display.print(F("Off "));
|
display.print(F("Off "));
|
||||||
}
|
}
|
||||||
display.setCursor(64,50);
|
display.setCursor(60,50);
|
||||||
display.print(F("MOD:"));
|
if (insideTab == 2) {
|
||||||
if (outsMod[displayTab-1]) {
|
display.setTextColor(SSD1306_BLACK, SSD1306_WHITE);
|
||||||
display.print(F("A2 "));
|
|
||||||
} else {
|
} else {
|
||||||
|
display.setTextColor(SSD1306_WHITE);
|
||||||
|
}
|
||||||
|
display.print(F(" MOD:"));
|
||||||
|
if (outsMod[displayTab-1] && outsModRange[displayTab-1] != 0) {
|
||||||
|
display.print(F("A2 "));
|
||||||
|
if (outsModRange[displayTab-1] > 0) {
|
||||||
|
display.print(F("+"));
|
||||||
|
}
|
||||||
|
display.print(outsModRange[displayTab-1]);
|
||||||
|
display.print(F(" "));
|
||||||
|
} else if (!outsMod[displayTab-1] && outsModRange[displayTab-1] != 0) {
|
||||||
display.print(F("A1 "));
|
display.print(F("A1 "));
|
||||||
|
if (outsModRange[displayTab-1] > 0) {
|
||||||
|
display.print(F("+"));
|
||||||
|
}
|
||||||
|
display.print(outsModRange[displayTab-1]);
|
||||||
|
display.print(F(" "));
|
||||||
|
} else {
|
||||||
|
display.print(F("Off "));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user