chennel settings now stored in objects
This commit is contained in:
@ -8,7 +8,7 @@
|
|||||||
#define SCREEN_ADDRESS 0x3C
|
#define SCREEN_ADDRESS 0x3C
|
||||||
|
|
||||||
#define PPQN 24
|
#define PPQN 24
|
||||||
#define PULSE_LENGTH 5
|
#define PULSE_LENGTH 5 //ms
|
||||||
#define MAXBPM 250 //250 at 24ppqn with 5ms pulse will be 50/50 square wave
|
#define MAXBPM 250 //250 at 24ppqn with 5ms pulse will be 50/50 square wave
|
||||||
#define MINBPM 20
|
#define MINBPM 20
|
||||||
|
|
||||||
@ -23,21 +23,33 @@
|
|||||||
|
|
||||||
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 clockModes[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, 2, 6}; //8 - 1
|
|
||||||
bool outsRandom[6] = {0,0,0,0,0,1};
|
|
||||||
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 outsClocksCounts[6];
|
|
||||||
int outsModesPlay[6]; //actual channel modes array updated from outsModeIndex each beat
|
|
||||||
|
|
||||||
bool clockMode;
|
|
||||||
bool clockModeOld;
|
|
||||||
int inputMode; //clock, reset, start/stop
|
|
||||||
int clockCount = 0;
|
|
||||||
|
|
||||||
int bpm = 130;
|
int bpm = 130;
|
||||||
|
|
||||||
|
struct channel {
|
||||||
|
unsigned int mode;
|
||||||
|
bool random;
|
||||||
|
bool modulationChannel; //0 - A1, 1 - A2
|
||||||
|
int modulationRange;
|
||||||
|
};
|
||||||
|
|
||||||
|
channel channels[6] = { //array of channel settings
|
||||||
|
{ 8, 0, 0, 0 },
|
||||||
|
{ 9, 0, 0, 0 },
|
||||||
|
{10, 0, 0, 0 },
|
||||||
|
{ 7, 1, 0, 0 },
|
||||||
|
{ 2, 0, 1, 4 },
|
||||||
|
{ 6, 1, 1,-4 },
|
||||||
|
};
|
||||||
|
|
||||||
|
int outsClocksCounts[6];
|
||||||
|
int playingModes[6]; //actual channel modes array updated from channels each beat
|
||||||
|
|
||||||
|
bool clockMode; //internal/external. needs to be renamed
|
||||||
|
bool clockModeOld;
|
||||||
|
int clockCount = 0;
|
||||||
|
|
||||||
int pulseClockCount = 0;
|
int pulseClockCount = 0;
|
||||||
int pulseCount = 0;
|
int pulseCount = 0;
|
||||||
int pulsePeriod;
|
int pulsePeriod;
|
||||||
@ -54,8 +66,6 @@ bool playBtnPushed = false;
|
|||||||
int a1Input = 0;
|
int a1Input = 0;
|
||||||
int a2Input = 0;
|
int a2Input = 0;
|
||||||
|
|
||||||
bool changesSaved;
|
|
||||||
|
|
||||||
int encPositionOld = 0;
|
int encPositionOld = 0;
|
||||||
unsigned long encPressedTime;
|
unsigned long encPressedTime;
|
||||||
unsigned long encReleasedTime;
|
unsigned long encReleasedTime;
|
||||||
@ -66,6 +76,8 @@ RotaryEncoder encoder(ENC_D1_PIN, ENC_D2_PIN, RotaryEncoder::LatchMode::TWO03);
|
|||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
|
channels[2].mode = 5;
|
||||||
|
Serial.println(channels[2].mode);
|
||||||
|
|
||||||
pinMode(INPUT_CONNECTED_PIN, INPUT_PULLUP);
|
pinMode(INPUT_CONNECTED_PIN, INPUT_PULLUP);
|
||||||
pinMode(ENC_BTN_PIN, INPUT_PULLUP);
|
pinMode(ENC_BTN_PIN, INPUT_PULLUP);
|
||||||
@ -99,29 +111,26 @@ void internalClock() {
|
|||||||
//modulation
|
//modulation
|
||||||
for (int i = 0; i<6; i++) {
|
for (int i = 0; i<6; i++) {
|
||||||
int mod;
|
int mod;
|
||||||
if (!outsMod[i]) {
|
if (!channels[i].modulationChannel) {
|
||||||
mod = a1Input;
|
mod = a1Input;
|
||||||
} else {
|
} else {
|
||||||
mod = a2Input;
|
mod = a2Input;
|
||||||
}
|
}
|
||||||
mod = map (mod, 0, 1023, 0, outsModRange[i]);
|
mod = map (mod, 0, 1023, 0, channels[i].modulationRange);
|
||||||
outsModesPlay[i] = outsModes[outsModeIndex[i] - mod]; //subtrackting because the innitiall array is backwards
|
playingModes[i] = clockModes[channels[i].mode - mod]; //subtrackting because the innitiall array is backwards
|
||||||
}
|
}
|
||||||
|
|
||||||
//divider
|
//divider
|
||||||
if (pulseCount == 0 && !beatCounted) {
|
if (pulseCount == 0 && !beatCounted) {
|
||||||
for (int i = 0; i<6; i++) {
|
for (int i = 0; i<6; i++) {
|
||||||
outsModesPlay[i] = outsModes[outsModeIndex[i]]; //updated here to prevent sync problems for multipliers
|
playingModes[i] = clockModes[channels[i].mode]; //updated here to prevent sync problems for multipliers
|
||||||
/*if (a1Input != 0 && i == 5) { //TESTING THE MODULATION ON 6th CHANNEL
|
if (playingModes[i] > 0) {
|
||||||
outsModesPlay[i] = outsModes[outsModeIndex[i] - a1Input];
|
|
||||||
}*/
|
|
||||||
if (outsModesPlay[i] > 0) {
|
|
||||||
if (outsClocksCounts[i] == 0) { //Pulse on 0
|
if (outsClocksCounts[i] == 0) { //Pulse on 0
|
||||||
if (outsRandom[i] == 0 || (outsRandom[i] == 1 && random(2))) { //random
|
if (channels[i].random == 0 || (channels[i].random == 1 && random(2))) { //random
|
||||||
digitalWrite(outsPins[i], HIGH);
|
digitalWrite(outsPins[i], HIGH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (outsClocksCounts[i] < (outsModesPlay[i] - 1)) {
|
if (outsClocksCounts[i] < (playingModes[i] - 1)) {
|
||||||
outsClocksCounts[i]++;
|
outsClocksCounts[i]++;
|
||||||
} else {
|
} else {
|
||||||
outsClocksCounts[i] = 0;
|
outsClocksCounts[i] = 0;
|
||||||
@ -133,13 +142,13 @@ void internalClock() {
|
|||||||
|
|
||||||
//multiplier
|
//multiplier
|
||||||
for (int i = 0; i<6; i++) {
|
for (int i = 0; i<6; i++) {
|
||||||
if (outsModesPlay[i] < 0) {
|
if (playingModes[i] < 0) {
|
||||||
if (outsClocksCounts[i] == 0) { //Pulse on 0
|
if (outsClocksCounts[i] == 0) { //Pulse on 0
|
||||||
if (outsRandom[i] == 0 || (outsRandom[i] == 1 && random(2))) { //random
|
if (channels[i].random == 0 || (channels[i].random == 1 && random(2))) { //random
|
||||||
digitalWrite(outsPins[i], HIGH);
|
digitalWrite(outsPins[i], HIGH);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (outsClocksCounts[i] < (PPQN / abs(outsModesPlay[i])) - 1) {
|
if (outsClocksCounts[i] < (PPQN / abs(playingModes[i])) - 1) {
|
||||||
outsClocksCounts[i]++;
|
outsClocksCounts[i]++;
|
||||||
} else {
|
} else {
|
||||||
outsClocksCounts[i] = 0;
|
outsClocksCounts[i] = 0;
|
||||||
@ -200,7 +209,7 @@ void checkInputs() {
|
|||||||
} else if (digitalRead(ENC_BTN_PIN) && encPressRegistered) {
|
} else if (digitalRead(ENC_BTN_PIN) && encPressRegistered) {
|
||||||
encPressRegistered = false;
|
encPressRegistered = false;
|
||||||
encReleasedTime = millis();
|
encReleasedTime = millis();
|
||||||
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) {
|
if (insideTab == 0) {
|
||||||
@ -221,8 +230,6 @@ void checkInputs() {
|
|||||||
} else {
|
} else {
|
||||||
insideTab = 0;
|
insideTab = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
//outsRandom[displayTab-1] = !outsRandom[displayTab-1];
|
|
||||||
updateScreen();
|
updateScreen();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -241,20 +248,20 @@ void checkInputs() {
|
|||||||
}
|
}
|
||||||
updateTiming();
|
updateTiming();
|
||||||
} else if (displayTab != 0 && insideTab == 0) {
|
} else if (displayTab != 0 && insideTab == 0) {
|
||||||
outsModeIndex[displayTab-1] = outsModeIndex[displayTab-1] - change;
|
channels[displayTab-1].mode = channels[displayTab-1].mode - change;
|
||||||
if (outsModeIndex[displayTab-1] < 0) {
|
if (channels[displayTab-1].mode < 0) {
|
||||||
outsModeIndex[displayTab-1] = 0;
|
channels[displayTab-1].mode = 0;
|
||||||
} else if (outsModeIndex[displayTab-1] > (sizeof(outsModes)/sizeof(int)) - 1) {
|
} else if (channels[displayTab-1].mode > (sizeof(clockModes)/sizeof(int)) - 1) {
|
||||||
outsModeIndex[displayTab-1] = (sizeof(outsModes)/sizeof(int)) - 1;
|
channels[displayTab-1].mode = (sizeof(clockModes)/sizeof(int)) - 1;
|
||||||
}
|
}
|
||||||
needToResetChannel = displayTab-1;
|
needToResetChannel = displayTab-1;
|
||||||
} else if (displayTab != 0 && insideTab == 1) { //random
|
} else if (displayTab != 0 && insideTab == 1) { //random
|
||||||
outsRandom[displayTab-1] = !outsRandom[displayTab-1];
|
channels[displayTab-1].random = !channels[displayTab-1].random;
|
||||||
} else if (displayTab != 0 && insideTab == 2) { //modulation
|
} else if (displayTab != 0 && insideTab == 2) { //modulation
|
||||||
outsModRange[displayTab-1] = outsModRange[displayTab-1] + change;
|
channels[displayTab-1].modulationRange = channels[displayTab-1].modulationRange + change;
|
||||||
if (outsModRange[displayTab-1] > 6 || outsModRange[displayTab-1] < -6) {
|
if (channels[displayTab-1].modulationRange > 6 || channels[displayTab-1].modulationRange < -6) {
|
||||||
outsMod[displayTab-1] = !outsMod[displayTab-1];
|
channels[displayTab-1].modulationChannel = !channels[displayTab-1].modulationChannel;
|
||||||
outsModRange[displayTab-1] = 0;
|
channels[displayTab-1].modulationRange = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
updateScreen();
|
updateScreen();
|
||||||
@ -321,14 +328,14 @@ void updateScreen() {
|
|||||||
display.print(bpm);
|
display.print(bpm);
|
||||||
display.println(F("bpm"));
|
display.println(F("bpm"));
|
||||||
} else {
|
} else {
|
||||||
if (outsModes[outsModeIndex[displayTab-1]] == 0) {
|
if (clockModes[channels[displayTab-1].mode] == 0) {
|
||||||
display.print(F(" OFF"));
|
display.print(F(" OFF"));
|
||||||
} else if (outsModes[outsModeIndex[displayTab-1]]>0) {
|
} else if (clockModes[channels[displayTab-1].mode]>0) {
|
||||||
display.print(F(" /"));
|
display.print(F(" /"));
|
||||||
display.print(abs(outsModes[outsModeIndex[displayTab-1]]));
|
display.print(abs(clockModes[channels[displayTab-1].mode]));
|
||||||
} else {
|
} else {
|
||||||
display.print(F(" x"));
|
display.print(F(" x"));
|
||||||
display.print(abs(outsModes[outsModeIndex[displayTab-1]]));
|
display.print(abs(clockModes[channels[displayTab-1].mode]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
display.println();
|
display.println();
|
||||||
@ -344,7 +351,7 @@ void updateScreen() {
|
|||||||
display.setTextColor(SSD1306_WHITE);
|
display.setTextColor(SSD1306_WHITE);
|
||||||
}
|
}
|
||||||
display.print(F(" RND:"));
|
display.print(F(" RND:"));
|
||||||
if (outsRandom[displayTab-1]) {
|
if (channels[displayTab-1].random) {
|
||||||
display.print(F("On "));
|
display.print(F("On "));
|
||||||
} else {
|
} else {
|
||||||
display.print(F("Off "));
|
display.print(F("Off "));
|
||||||
@ -356,19 +363,19 @@ void updateScreen() {
|
|||||||
display.setTextColor(SSD1306_WHITE);
|
display.setTextColor(SSD1306_WHITE);
|
||||||
}
|
}
|
||||||
display.print(F(" MOD:"));
|
display.print(F(" MOD:"));
|
||||||
if (outsMod[displayTab-1] && outsModRange[displayTab-1] != 0) {
|
if (channels[displayTab-1].modulationChannel && channels[displayTab-1].modulationRange != 0) {
|
||||||
display.print(F("A2 "));
|
display.print(F("A2 "));
|
||||||
if (outsModRange[displayTab-1] > 0) {
|
if (channels[displayTab-1].modulationRange > 0) {
|
||||||
display.print(F("+"));
|
display.print(F("+"));
|
||||||
}
|
}
|
||||||
display.print(outsModRange[displayTab-1]);
|
display.print(channels[displayTab-1].modulationRange);
|
||||||
display.print(F(" "));
|
display.print(F(" "));
|
||||||
} else if (!outsMod[displayTab-1] && outsModRange[displayTab-1] != 0) {
|
} else if (!channels[displayTab-1].modulationChannel && channels[displayTab-1].modulationRange != 0) {
|
||||||
display.print(F("A1 "));
|
display.print(F("A1 "));
|
||||||
if (outsModRange[displayTab-1] > 0) {
|
if (channels[displayTab-1].modulationRange > 0) {
|
||||||
display.print(F("+"));
|
display.print(F("+"));
|
||||||
}
|
}
|
||||||
display.print(outsModRange[displayTab-1]);
|
display.print(channels[displayTab-1].modulationRange);
|
||||||
display.print(F(" "));
|
display.print(F(" "));
|
||||||
} else {
|
} else {
|
||||||
display.print(F("Off "));
|
display.print(F("Off "));
|
||||||
|
|||||||
Reference in New Issue
Block a user