/Arduinoboy

Official ArduinoBoy Repository for serial MIDI communication to the Nintendo Gameboy.

Primary LanguageMaxGNU General Public License v2.0GPL-2.0

Arduinoboy

Unofficial ArduinoBoy Repository for serial MIDI communication to the Nintendo Gameboy.

This is a fork of trash80's official code. It adds the following changes:

  • Mode button input pin has been moved from pin 3 to pin 2.
  • Mode button uses an internal pull up resistor instead of an external pull down resistor
  • Added dependency on this library to handle PS/2 communication. To install, download the library, and extract it into your Arduino Libraries folder (typically Documents/Arduino/libraries). Do not attempt to install a PS/2 library from the Arduino library manager as that version will not work with this code.
  • Added a midi device name ("teensyboy") when using USB midi with a teensy

ScreenShot

About

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

Current Features

  • Affordable and easily accessible parts for assembly.
  • Accurate MIDI Sync, Start and Stop commands.
  • Push Button selector sets the sync/state modes (7 modes available)
  • mGB Mode: Full MIDI in support across all Gameboy Channels, including a unique "poly" mode allows you to play your Game Boy like a synthesizer.
  • Midi Out Doubles as a Midi Thru
  • "Filtering" data for only sync messages, no dedicated MIDI line required.
  • Can be powered by the Game Boy's gamelink port.
  • USB upgradeable via Arduino.
  • Midi settings configurable using a Mac/PC editor built in Max.
  • Tested and works with DMG (Original), Gameboy Color, and Advance/SP.

Modes Details

Mode 1 - LSDJ as MIDI Slave Sync

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:

  • 48 - C-2 Sends a Sequencer Start Command
  • 49 - C#2 Sends a Sequencer Stop Command
  • 50 - D-2 Toggles Normal Tempo
  • 51 - D#2 Toggles 1/2 Tempo
  • 52 - E-2 Toggles 1/4 Tempo
  • 53 - F-2 Toggles 1/8 Tempo

Higher note values than these map LSDJ song position row offset on a Song Start.

In LSDJ the sync mode should be set to Slave

Mode 2 LSDJ as MIDI Master Sync.

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

Mode 3 LSDJ PC Keyboard mode.

This mode emulates the PC Keyboard Mode built into LSDJ, allowing you to control the following aspects of LSDJ:

Features:

  • The first octave controls M-U-T-E,
  • Cursor control (LSDJ Live mode only),
  • Table selection
  • Table cue.

PC Keyboard mode midi note map

  • 36 - C-1 Mute Pu1 Off/On
  • 37 - C#1 Mute Pu2 Off/On
  • 38 - D-1 Mute Wav Off/On
  • 39 - D#1 Mute Noi Off/On
  • 40 - E-1 Livemode Cue Sequence
  • 41 - F-1 Livemode Cursor Up
  • 42 - F#1 Livemode Cursor Down
  • 43 - G-1 Livemode Cursor Left
  • 44 - G#1 Live mode Cursor Right
  • 45 - A-1 Table Up
  • 46 - A#1 Table Down
  • 47 - B-1 Cue Table
  • 48+ - Notes from this note up will accept midi in from an external keyboard or sequencer and allow you to play the notesC-2 to C-8.
  • Midi Program Change messages will select from instrument table
  • Default Midi channel is 16. You can set this in the top of the main source file in the archive, or via the Max Pat editor.

In LSDJ the sync mode should be set to Keyboard

Mode 4 MIDI to Nanoloop sync

Sync Nanoloop. to external midi clock signals sent to the midi in.

In Nanoloop, the sync mode should be set to slave.

Mode 5 Full MIDI with mGB

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.

Mode 6 LSDJ MIDIMAP

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.

Mode 7 LSDJ MIDIOUT

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.

Max Editor

Editor gui 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

Maxpat Settings

  • 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.

Future Features & wishlist

  • Build instructions, and a Arduino Shield

How To build an Arduinoboy

ScreenShot ScreenShot

Video Demos

Thanks To