Skip to content

A easy to build taiko controller e-box. Compatible with Arduino Leonardo and Pro Micro. Support Nintendo Switch and PC.

License

Notifications You must be signed in to change notification settings

ryumiyax/LeonardoTaiko

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

47 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LeonardoTaiko

中文文档

A easy to build e-box with Arduino Leonardo/ProMicro.

Senpuu no Mai
Play demo: Senpuu no Mai [Heaven] Full Combo.

Feature

  • Nintendo Switch Support
  • Easy to build.

Hardware Parts

  • Arduino Leonardo/Pro Micro
  • Piezo sensor x4
  • 1MOhm resistor x4
  • Bread borad and wires(you can print your own pcb if you want)

Circuit Connection

4 piezo sensors, one pin to the GND, and the other to the A0-A3. Connect 1MOhm resistor to each sensor parallelly.

Note: Piezo sensor will generate ositive and negative voltage when working, so positive/negative to GND probably doesn't matter. You've heard that negative voltage will probably damage the analog pin. However since the current generated by the sensor is really really low, I would say it's most likely safe. If that concern you, you can use diodes or diode bridges to fix this issue.

How to use

In Arduino IDE, board manager, download Arduino AVR Board.

Then, you need to download Keyboard and NintendoSwitchLibrary in your Arduino IDE's library manager.

Then compile and upload the code to the board. then it should work fine. By default {A3, A0, A1, A2} are mapped to {'f','d','j','k'} on keyboard. For Switch, it would be {Button::LCLICK, Button::ZL, Button::RCLICK, Button::ZR}. See more at [Keymapping]https://github.com/judjdigj/LeonardoTaiko?tab=readme-ov-file#keymapping

Nintendo Switch Support

You need to change the VID and PID first.
In board.txt( Arduino IDE 1.8.x ).

leonardo.vid.1=0x0f0d
leonardo.pid.1=0x0092

leonardo.build.vid=0x0f0d
leonardo.build.pid=0x0092

Location of board.txt can be various depends on your IDE version. For Arudino IDE 1.8.19, it should be in C:\Users\USERNAME\AppData\Local\Arduino15\packages\arduino\hardware\avr\1.8.6

Then connect Pin1 to GND, hit reset button. (Or plug into the Switch while connecting) It should work fine now.

To switch back to PC mode, connect Pin0 to GND and hit reset button. (or plug into the PC while connecting).

Extend Key

Uncomment extendKey() can map D0 and D1 to Button::PLUS and Hat::RIGHT. In case you want configuration in NS2. However I'm sure sure if there will be any negative effect on the perfermance.

Keymapping

//{A3, A0, A1, A2}

const uint16_t keymapping_ns[4] = {Button::A, Hat::UP, Hat::DOWN, Button::B};

const int keymapping[4] = {'f','d','j','k'};

Change the value to change the keymapping.

Switch button definition list (more information at Nintendo Switch Library):

Button::Y
Button::B
Button::A
Button::X
Button::L
Button::R
Button::ZL
Button::ZR
Button::MINUS
Button::PLUS
Button::LCLICK
Button::RCLICK
Button::HOME
Button::CAPTURE
Hat::UP
Hat::UP_RIGHT
Hat::RIGHT
Hat::DOWN_RIGHT
Hat::DOWN
Hat::DOWN_LEFT
Hat::LEFT
Hat::UP_LEFT
Hat::NEUTRAL

Debug

uncomment analogMonitor() and comment all the section in main loop below. Then you can check each sensors analog value after passing the threshold.

Also some commented line can be found for different debug purposes.

//    Serial.println("DECAY");
//    Serial.println(threshold);  //Check decay, in order to set proper k_increase and k_decay.

Algorithm

Once a analog value is higher the threshold, a input will be detected.

To Avoid Mistaken Input

We all know AC Taiko was built with 4 parts: left rim, left surface, right surface, right rim. Taiko

However, unlike electronic drum set, where each piezo sensors are seperated, there will always be some connection between each part of the Taiko drum, no matter the base wooden plate or the rubber surface. So when you hit one part, the other 3 parts will also be vibrated, causing all the sensors delivering signals. Noise If the noise signal from the other parts was detected before the actual part that got hit, a mistaken input will happen.

To prevent mistaken input, we need to create a buffer window. It will start storage all the analog input into buffer for a short period. Since the noise analog value on other sensor should be smaller than the one which actual got hit, comparing each value in buffer, the largest value should be generated by the actual sensor got hit. noise2

The parameter cd_length will effect the buffer size. If it was set too large, it will take a significant time to find the largest number, causing input latency. If it was too small, the buffer windows may not cover the largest value from the sensor.

To Avoid Double input on One Hit.

If the buffer time and key press time is too short, even shorter than the vibrating time, when the whole input process is over, the sensor will still sent signal, and again once it's higher than the threshold, another input will be triggered. Causing double input in one hit. The harder you hit the drum, the more significant this issue will be. noise3 That's why I imported dynamic threshold. the harder you hit the drum, the higher the threshold will be raised. which let the threshold higher than the vibration. noise4 The dynamic threshold will be the maximun analogValue in buffer multiplied by k_increase. and in every loop the current threshold will be multiplied by k_decay until it's back to the original threshold.

Simultaneous Input (Big Notes)

This algorithm, doesn't support simultaneous input (you need that to hit big notes on console version of Taiko no Tatsujin for a higher score). However technically you can do some key mapping trick to make one hit equal to 2 key pressed.

Others

You can also imply some smoothing filter to preprocessing the raw analog input signal. In my case, the sensors are good enough.

Parameters (and the recommended value):

min_threshold = 100

The value to trigger a input. use 5V as reference, divided the signal from 0 to 1024. The lower it was set, the more sensitive the drum will get. If it's lower than the idle noises which piezo sensor will definitely generated, random input will occur.

outputDuration_pc = 7 and outputDuration_ns = 25

In millisecond. When an input is triggered, a key will be pressed. This parameter decide how long a key should be pressed. During the this period, there will be no other action.

The longer it was set, the less roll you can get from

For PC the simulator runs at 120fps which means roughly 8 millisecs per frame. That's reason why recommended value is 8.

For Nintendo Switch. A really short button press time (below 20ms) will not be recognized. So the recommended value should be larger than 20. I personally use 25.

cd_length = 20

How many loops to read all 4 sensors' analogValue. Since cd_length define one loop for all 4 sensors, buffer_size should be 4*cd_length.
Which means you can change this value to adjust the buffer size. The smaller it was set, the faster response you will get after hit the drum.

k_increase = 0.7

Every time a hit was detected, the threshold will change to the largest pin value multiplied by k_increase. Which can prevent double input when the cd_length/buffer_size was set too low.

k_decay = 0.99

Every loop the current threshold will multiply k_decay in order to go back to the original threshold.

Credit

Nintendo Switch support from NintendoSwitchControlLibrary by lefmarna.
Algorithm inspired by multiple Taiko project, including:
ArduinoTaikoController by LuiCat.
Taiko-Input by sachikoxz12.

About

A easy to build taiko controller e-box. Compatible with Arduino Leonardo and Pro Micro. Support Nintendo Switch and PC.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C 53.9%
  • C++ 46.1%