Official ArduinoBoy Repository for serial MIDI communication to the Nintendo Gameboy.
Arduinoboy is software for the Arduino hardware platform that allows serial communication (MIDI) to the Nintendo Gameboy for music applications such as LittleSoundDJ, Nanoloop., and mGB
Slave your Game Boy running LittleSoundDJ to your midi sequencer or Digital audio workstation.
You can send the arduinoboy midi notes to change sync resolution and start/stop the LSDJ sequencer.
LSDJ Slave Mode Midi Note Effects:
C-2
Sends a Sequencer Start CommandC#2
Sends a Sequencer Stop CommandD-2
Toggles Normal Tempo D#2
Toggles 1/2 TempoE-2
Toggles 1/4 TempoF-2
Toggles 1/8 TempoHigher note values than these map LSDJ song position row offset on a Song Start.
In LSDJ the sync
mode should be set to Slave
Send Midi sync with LSDJ as a midi clock master, LSDJ also sends a Midi Note on message that corresponds to the song row number on play.
In LSDJ the sync
mode should be set to Master
This mode emulates the PC Keyboard Mode built into LSDJ, allowing you to control the following aspects of LSDJ:
Features:
PC Keyboard mode midi note map
C-1
Mute Pu1 Off/OnC#1
Mute Pu2 Off/OnD-1
Mute Wav Off/OnD#1
Mute Noi Off/OnE-1
Livemode Cue SequenceF-1
Livemode Cursor UpF#1
Livemode Cursor DownG-1
Livemode Cursor LeftG#1
Live mode Cursor RightA-1
Table UpA#1
Table DownB-1
Cue TableC-2 to C-8
. In LSDJ the sync
mode should be set to Keyboard
Sync Nanoloop. to external midi clock signals sent to the midi in.
In Nanoloop, the sync mode should be set to slave
.
mGB is a Gameboy cartridge program (You need a Flash Cart and Transfer hardware) That enables the Gameboy to act as a MIDI supported sound module that allows full control of the Game Boy sound hardware.
It works with the old DMG Gameboy as well as GBC/GBA.
Lsdj will sync to incoming MIDI sync, and incoming MIDI notes are mapped to LSDJ's song row #. The currently selected row's MIDI note is displayed on the top right of the LSDJ screen, and incoming MIDI notes will also display the relative song row number in the same location.
In LSDJ the sync
mode should be set to MI.MAP
.
This requires a special version of LSDJ, which can be found in your account on the LSDJ website.
Each of the 4 gameboy channels send MIDI data on 4 midi channels by the use of effects commands:
Nxx
- Sends a MIDI Note - Absolute to the value placed in the effect. N00 sends note off, N01
-N6F
send midi notes 1 to 112.Qxx
- Sends a MIDI Note relative to the current channel's pitch. The effect value is a offset. so Q0C
in PU1
would send a note 1 octave higher than what PU1
is currently playing. This is useful as a table command to track midi notes as normal notes in the sequencer.Xxx
- Sends a MIDI CC - By default in Arduinoboy the high nibble selects a CC#, and the low nibble sends a value 0-F
to 0-127
. This can be changed to allow just 1 midi CC with a range of 00
-6F
, or 7 CCs with scaled or unscaled values.Yxx
- Sends a program/patch/preset change.By default each channel of LSDJ is mapped to midi channels 1-4. For example note commands from PU1 will be sent to midi channel 1.
In LSDJ the sync
mode should be set to Midiout
.
This requires a special version of LSDJ, which can be found in your account on the LSDJ website.
The Arduinoboy Editor for Max for PC/OSX machines is a gui editor that allows you to edit the various global midi settings of your arduinoboy without editing or flashing code, over midi. It used to required the now deprecated Max Runtime, but you can also run it using a demo of Cycling '74's Max application
Midi In/Out
Connect your arduinoboy to these ports on your system. Once it has connected, all the lights on your arduinoboy should flash in order, and the editor will show a green Connected
.Mode
Setting this will tell your arduinoboy what mode to boot into automatically. This is handy if you built your own arduinoboy and decided you wanted to skimp out on LEDs and a button.LSDJ Slave Mode settings
- The midi channel LSDJ slave mode will receive its commands on.LSDJ Master Mode settings
- The midi channel LSDJ Master mode will send its midi notes mapped to row number on.Keyboard Mode settings
- What channel LSDJ will look for its keyboard mode midi commands. No idea what compatibility mode does.mGB midi settings
- Map each incoming midi channel to a specific Gameboy channel in mGB.LSDJ Livesync/Livemap settings
- The midi channel Livesync/Livemap will listen to incoming midi commands from.LSDJ Midiout settings
- Here you can set the following:
Note midi channel
- The channel each LSDJ channel will send it's midi note commands on.CC midi channel
- The channel each LSDJ channel will send it's Continuous Controller commands on.CC 0
- The initial CC each channel will send. The type of data it will send is based on the next setting.CC Mode
- Game Boys have limitations! You can either have arduinoboy send one CC with many values, or 7 with limited 8bit values. By default in Arduinoboy the high nibble selects a CC#, and the low nibble sends a value [0-F] to [0-127]. This can be changed to allow just 1 midi CC with a range of 00-6F, or 7 CCs with scaled or unscaled values.CC Scaling
- Set wether the 7 CCs are scaled or unscaled.