This is a Pump it Up IO board (PIUIO) clone based on the Raspberry Pi Pico microcontroller.
Though designed for dj505's PicoFX handpump controller, this will work with DIY hand pump controller builds, and can probably be adapted for pad use, too.
Can be used as ButtonBoard (menu button IO), just configure cmake with -DBUTTON_BOARD=1
To enable PicoFX lights, configure cmake with -DCAB_LIGHTS_WS2812=1
You don't need many components to put one together:
- Raspberry Pi Pico
- 12x switches (for the 10 pad switches, plus test and service buttons)
- 10x LEDs and appropriate resistors
By default the pins are configured as shown below, but the pins can be changed in piuio_config.h
.
See the Pi Pico SDK repo for instructions on preparing the build environment. All the required CMake files should already be present and ready for compilation.
General overview:
- Add the SDK via your method of choice (see the pico-sdk repo)
- Run
git submodule update --init
inside the SDK directory to set up the other required libraries (namely tinyusb) - Create the "build" folder inside the "piuio-pico" folder.
- Inside the build folder, run
cmake ..
, then runmake
. You'll get a .UF2 file in the build folder that you can upload to the Pico! - With the Pico unplugged from the PC, hold the "BOOTSEL" button on the Pico, then plug in the Pico.
- The Pico will now show up as a "flash drive" in your OS. Copy the .UF2 file onto the Pico, and the code will be uploaded!
Using a hand controller with games connected to the official Pump it Up online service is considered cheating by Andamiro and may lead to actions being taken against your account. As such, this use case is not officially endorsed by piuio-pico.
This project is based off of the tinyusb device USB examples (specifically webusb_serial and hid_generic_input)
Protocol information from the PIUIO_Arduino and piuio_clone repositories.