Compare commits

..

7 Commits

Author SHA1 Message Date
0218eabc34 add dependency information 2021-01-24 16:10:55 +09:00
f413eae2fd omit sending hat if direction is not changed 2021-01-01 21:53:43 +09:00
9454fdc54e implement hitbox compatible SOCD. 2020-09-18 22:17:12 +09:00
20a25ecf26 tmp 2020-09-17 00:23:53 +09:00
dbff5cf2ac tmp 2020-09-15 21:48:26 +09:00
6ab58857c7 tmp 2020-09-15 20:13:43 +09:00
7539e3658a disable rapid fire 2020-09-15 18:29:48 +09:00
8 changed files with 87 additions and 505 deletions

View File

@@ -1,7 +0,0 @@
{
"board": "SparkFun:avr:promicro",
"programmer": "AVR ISP",
"port": "COM11",
"sketch": "connect_switch.ino",
"configuration": "cpu=16MHzatmega32U4"
}

View File

@@ -1,18 +0,0 @@
{
"configurations": [
{
"name": "Win32",
"includePath": [
"C:\\Users\\sirrow\\AppData\\Local\\Arduino15\\packages\\SparkFun\\hardware\\avr\\1.1.13\\**",
"C:\\Users\\sirrow\\AppData\\Local\\Arduino15\\packages\\arduino\\tools\\**",
"C:\\Users\\sirrow\\AppData\\Local\\Arduino15\\packages\\arduino\\hardware\\avr\\1.8.2\\**"
],
"forcedInclude": [],
"intelliSenseMode": "msvc-x64",
"compilerPath": "C:/Program Files (x86)/Microsoft Visual Studio/2019/Community/VC/Tools/MSVC/14.24.28314/bin/Hostx64/x64/cl.exe",
"cStandard": "c11",
"cppStandard": "c++17"
}
],
"version": 4
}

View File

@@ -1,4 +1,7 @@
Arduino Pro Micro でコントローラー自作するときのスケッチ
=======================================================
[SwitchControlLibrary](https://github.com/celclow/SwitchControlLibrary) を利用している。
## 依存ライブラリ
- [SwitchControlLibrary](https://github.com/celclow/SwitchControlLibrary) をフォークし[一部改変したもの](https://git.sirrow.work/sirrow/SwitchControlLibrary)
- ArduinoSTL
- MsTimer2

View File

@@ -6,7 +6,6 @@
int loopCount = 0;
int state = 0;
int rapidFireTable[RapidFireTableSize];
bool rapidPressState = 0;
int index = 0;
int val = 1;
@@ -29,23 +28,25 @@ struct ButtonInfo {
};
struct arrow arrowTable[4];
struct arrow oldestArrow;
struct arrow newestArrow;
struct arrow oldestXArrow;
struct arrow newestXArrow;
struct arrow oldestYArrow;
struct arrow newestYArrow;
#define ButtonInfoTableSize 9
struct ButtonInfo buttonInfoTable[ButtonInfoTableSize];
Hat last = Hat::CENTER;
void perms() {
if(val == 0){
if (rapidFireTable[index] == 1){
SwitchControlLibrary().PressButtonA();
rapidPressState = true;
}
if (rapidFireTable[index] == 2){
SwitchControlLibrary().ReleaseButtonA();
rapidPressState = false;
}
}
index = (index + 1) % RapidFireTableSize;
@@ -66,8 +67,8 @@ void setup()
rapidFireTable[RapidFireTableSize/2] = 2;
SwitchControlLibrary();
MsTimer2::set(1, perms);
MsTimer2::start();
//MsTimer2::set(1, perms);
//MsTimer2::start();
setupButton(&(buttonInfoTable[0]), 3, Button::B);
setupButton(&(buttonInfoTable[1]), 4, Button::X);
@@ -98,11 +99,17 @@ void setup()
arrowTable[i].newer = NULL;
}
oldestArrow.older = NULL;
oldestArrow.newer = &newestArrow;
oldestArrow.arrowSymbol = Hat::CENTER;
newestArrow.older = &oldestArrow;
newestArrow.newer = NULL;
oldestXArrow.older = NULL;
oldestXArrow.newer = &newestXArrow;
oldestXArrow.arrowSymbol = Hat::CENTER;
newestXArrow.older = &oldestXArrow;
newestXArrow.newer = NULL;
oldestYArrow.older = NULL;
oldestYArrow.newer = &newestYArrow;
oldestYArrow.arrowSymbol = Hat::CENTER;
newestYArrow.older = &oldestYArrow;
newestYArrow.newer = NULL;
}
@@ -119,18 +126,22 @@ void handleButtonInput(ButtonInfo *but){
but->prev = but->current;
}
void moveHat(Hat dir){
if(last != dir){
SwitchControlLibrary().MoveHat(static_cast<uint8_t>(dir));
last = dir;
}
}
void loop()
{
val = digitalRead(2);
if(prevVal == 1 && val == 0){
SwitchControlLibrary().PressButtonA();
rapidPressState = true;
index = 1;
}
else if(prevVal == 0 && val == 1){
if(rapidPressState){
SwitchControlLibrary().ReleaseButtonA();
}
SwitchControlLibrary().ReleaseButtonA();
}
prevVal = val;
@@ -142,24 +153,63 @@ void loop()
for (int i=0; i<4; i++){
arrowTable[i].current = digitalRead(arrowTable[i].pinNumber);
if(arrowTable[i].prev==1 && arrowTable[i].current==0){
// add arrow to the tail of linked list
arrowTable[i].older = newestArrow.older;
arrowTable[i].newer = &newestArrow;
newestArrow.older->newer = &(arrowTable[i]);
newestArrow.older = &(arrowTable[i]);
}
else if (arrowTable[i].prev==0 && arrowTable[i].current==1){
arrowTable[i].newer->older = arrowTable[i].older;
arrowTable[i].older->newer = arrowTable[i].newer;
arrowTable[i].newer = NULL;
arrowTable[i].older = NULL;
}
if(arrowTable[1].current == 0){
if(arrowTable[3].current == 0){
if(arrowTable[0].current == 0){
moveHat(Hat::TOP);
}
else{
if(arrowTable[2].current == 0){
moveHat(Hat::BOTTOM);
}
else{
moveHat(Hat::CENTER);
}
}
}
else{
if(arrowTable[0].current == 0){
moveHat(Hat::TOP_LEFT);
}
else{
if(arrowTable[2].current == 0){
moveHat(Hat::BOTTOM_LEFT);
}
else{
moveHat(Hat::LEFT);
}
}
}
}
else{
if(arrowTable[3].current == 0){
if(arrowTable[0].current == 0){
moveHat(Hat::TOP_RIGHT);
}
else{
if(arrowTable[2].current == 0){
moveHat(Hat::BOTTOM_RIGHT);
}
else{
moveHat(Hat::RIGHT);
}
}
}
else{
if(arrowTable[0].current == 0){
moveHat(Hat::TOP);
}
else{
if(arrowTable[2].current == 0){
moveHat(Hat::BOTTOM);
}
else{
moveHat(Hat::CENTER);
}
}
}
arrowTable[i].prev = arrowTable[i].current;
}
SwitchControlLibrary().MoveHat(static_cast<uint8_t>(newestArrow.older->arrowSymbol));
}

Binary file not shown.

File diff suppressed because one or more lines are too long

Before

Width:  |  Height:  |  Size: 1.2 MiB

Binary file not shown.

File diff suppressed because one or more lines are too long

Before

Width:  |  Height:  |  Size: 1.2 MiB