mirror of
https://github.com/ShikyC/Taiko-Drum-Controller-Arduino.git
synced 2024-11-12 00:50:46 +01:00
refactor code
This commit is contained in:
parent
b2600886aa
commit
5d95133c45
@ -21,6 +21,11 @@
|
|||||||
|
|
||||||
#include <Keyboard.h>
|
#include <Keyboard.h>
|
||||||
#include "cache.h"
|
#include "cache.h"
|
||||||
|
#include "limits.h"
|
||||||
|
|
||||||
|
#if MODE_JIRO
|
||||||
|
#define HEAVY_THRES LONG_MAX
|
||||||
|
#endif
|
||||||
|
|
||||||
int channelSample [CHANNELS];
|
int channelSample [CHANNELS];
|
||||||
int lastChannelSample [CHANNELS];
|
int lastChannelSample [CHANNELS];
|
||||||
@ -31,9 +36,9 @@ Cache <long int, POWER_CACHE_LENGTH> powerCache [CHANNELS];
|
|||||||
|
|
||||||
bool triggered [CHANNELS];
|
bool triggered [CHANNELS];
|
||||||
|
|
||||||
#if MODE_DEBUG
|
int pins[] = { A0, A1, A2, A3 }; // L don, R don, L kat, R kat
|
||||||
long int lastTime;
|
char lightKeys[] = { 'g', 'h', 'f', 'j' };
|
||||||
#endif
|
char heavyKeys[] = { 't', 'y', 'r', 'u' };
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
Serial.begin (9600);
|
Serial.begin (9600);
|
||||||
@ -44,25 +49,27 @@ void setup() {
|
|||||||
lastChannelSample [i] = 0;
|
lastChannelSample [i] = 0;
|
||||||
triggered [i] = false;
|
triggered [i] = false;
|
||||||
}
|
}
|
||||||
#if MODE_DEBUG
|
|
||||||
lastTime = 0;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
|
|
||||||
channelSample[0] = analogRead (A0); // L don
|
|
||||||
channelSample[1] = analogRead (A1); // R don
|
|
||||||
channelSample[2] = analogRead (A2); // L kat
|
|
||||||
channelSample[3] = analogRead (A3); // R kat
|
|
||||||
|
|
||||||
#if MODE_DEBUG
|
#if MODE_DEBUG
|
||||||
Serial.print (micros () - lastTime);
|
long int sampleLastTime = 0;
|
||||||
lastTime = micros ();
|
long int calcLastTime = 0;
|
||||||
Serial.print ("\t");
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for (short int i = 0; i < CHANNELS; i++) {
|
for (short int i = 0; i < CHANNELS; i++) {
|
||||||
|
|
||||||
|
#if MODE_DEBUG
|
||||||
|
long int lastTime = micros();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
channelSample[i] = analogRead (pins[i]);
|
||||||
|
|
||||||
|
#if MODE_DEBUG
|
||||||
|
sampleLastTime += micros () - lastTime;
|
||||||
|
lastTime = micros();
|
||||||
|
#endif
|
||||||
|
|
||||||
sampleCache [i].put (channelSample [i] - lastChannelSample [i]);
|
sampleCache [i].put (channelSample [i] - lastChannelSample [i]);
|
||||||
|
|
||||||
@ -79,47 +86,29 @@ void loop() {
|
|||||||
powerCache [i].put (power [i]);
|
powerCache [i].put (power [i]);
|
||||||
lastChannelSample [i] = channelSample [i];
|
lastChannelSample [i] = channelSample [i];
|
||||||
|
|
||||||
|
if (powerCache [i].get (1) == 0) {
|
||||||
|
triggered [i] = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool isDescending = true;
|
||||||
for (short int j = 0; j < POWER_CACHE_LENGTH - 1; j++){
|
for (short int j = 0; j < POWER_CACHE_LENGTH - 1; j++){
|
||||||
|
if (!triggered [i] && (powerCache [i].get (j - 1) > powerCache [i].get (j))) {
|
||||||
if (powerCache [i].get (j) == 0) {
|
isDescending = false;
|
||||||
triggered [i] = false;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (!triggered [i]) {
|
if (isDescending) {
|
||||||
if (powerCache [i].get (j + 1) >= powerCache [i].get (j) || j != POWER_CACHE_LENGTH - 2) {
|
if (power [i] >= HEAVY_THRES) {
|
||||||
break;
|
triggered [i] = true;
|
||||||
} else {
|
Keyboard.print (heavyKeys [i]);
|
||||||
#if MODE_JIRO
|
} else if (power [i] >= LIGHT_THRES) {
|
||||||
if (power [i] >= LIGHT_THRES) {
|
triggered [i] = true;
|
||||||
triggered [i] = true;
|
Keyboard.print (lightKeys [i]);
|
||||||
switch (i) {
|
}
|
||||||
case 0: Keyboard.print ('g'); break;
|
|
||||||
case 1: Keyboard.print ('h'); break;
|
#if MODE_DEBUG
|
||||||
case 2: Keyboard.print ('f'); break;
|
calcLastTime += micros () - lastTime;
|
||||||
case 3: Keyboard.print ('j'); break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
if (power [i] >= HEAVY_THRES) {
|
|
||||||
triggered [i] = true;
|
|
||||||
switch (i) {
|
|
||||||
case 0: Keyboard.print ('t'); break;
|
|
||||||
case 1: Keyboard.print ('y'); break;
|
|
||||||
case 2: Keyboard.print ('r'); break;
|
|
||||||
case 3: Keyboard.print ('u'); break;
|
|
||||||
}
|
|
||||||
} else if (power [i] >= LIGHT_THRES) {
|
|
||||||
triggered [i] = true;
|
|
||||||
switch (i) {
|
|
||||||
case 0: Keyboard.print ('g'); break;
|
|
||||||
case 1: Keyboard.print ('h'); break;
|
|
||||||
case 2: Keyboard.print ('f'); break;
|
|
||||||
case 3: Keyboard.print ('j'); break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#if MODE_DEBUG
|
#if MODE_DEBUG
|
||||||
@ -131,8 +120,9 @@ void loop() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if MODE_DEBUG
|
#if MODE_DEBUG
|
||||||
Serial.print (micros () - lastTime);
|
Serial.print(sampleLastTime);
|
||||||
lastTime = micros ();
|
Serial.print('\t');
|
||||||
|
Serial.print(calcLastTime);
|
||||||
Serial.println ("");
|
Serial.println ("");
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user