JFugue is an open source programming library that allows one to program music in the Java programming language without the complexities of MIDI. It was first released in 2002 by David Koelle. Version 2 was released under a proprietary license.[1] Versions 3 and 4 were released under the LGPL-2.1-or-later license.[2][3] The current version, JFugue 5.0, was released in March 2015, under the Apache-2.0 license.[4] Brian Eubanks has described JFugue as "useful for applications that need a quick and easy way to play music or to generate MIDI files."[5]
Example
Here's an example Java program that will play the C-major scale in JFugue.
importorg.jfugue.player.Player;publicclassHelloWorld{publicstaticvoidmain(String[]args){Playerplayer=newPlayer();player.play("C D E F G A B");}}
The string passed to JFugue contains a series of musical instructions that JFugue parses and turns into musical events, which by default are rendered in MIDI. This format, called "Staccato," can represent all of the musical features of MIDI [6] and is specifically designed to be easy for people to read and write.[7] While the default use case for JFugue is to convert Staccato to MIDI, the architecture allows it to read and write musical information from and to a variety of formats (e.g., MIDI to MusicXML,[8] Staccato to LilyPond). Below is an example converting a MIDI file to the Staccato format.
MidiParserparser=newMidiParser();StaccatoParserListenerlistener=newStaccatoParserListener();parser.addParserListener(listener);parser.parse(MidiSystem.getSequence(newFile("YourMidiFile.mid")));// Change to the name of a MIDI file that you own the rights toPatternstaccatoPattern=listener.getPattern();System.out.println(staccatoPattern);
JFugue 5.0 contains a set of classes that represent ideas in music theory, including intervals, scales, chords, and chord progressions.
The notion of Patterns is integral to JFugue. Patterns are used to represent phrases of music that can be combined, repeated, and altered using tools that are aware of the musical content of the pattern.
Patternpattern1=newPattern("A B C");Patternpattern2=newPattern("G F E");pattern1.add(pattern2).repeat(3);Playerplayer=newPlayer();player.play(pattern1);
JFugue 5.0 makes extensive use of fluent interfaces, also known as method chaining, which lets developers write short, expressive pieces of code like the following:
Chord[]chords=newChordProgression("I IV V").setRoot("C").getChords();
Advanced Features
JFugue is capable of producing microtonal music by using a Staccato element consisting of the letter 'm' followed by the frequency in Hertz of the desired tone. Like other notes in JFugue, this tone may be followed by a duration (such as 'w' for a whole note or 'q' for a quarter note) and note dynamics (e.g., "note on" and "note off" velocities). JFugue converts the microtone frequency to a sequence of MIDI Pitch Wheel and Note events to achieve the desired tone.
Playerplayer=newPlayer();player.play("m440.0q A4q");// These sound the sameplayer.play("m568.7w");// Whole duration note at 568.7 Hertz
JFugue provides an intuitive programming interface for creating beats and rhythms. The characters in the strings below each correspond to a percussion note that is played on the percussive MIDI Channel (the tenth channel); default settings are provided for common sounds (e.g., "O" for "[BASS_DRUM]q"), although any Java Map or Character to String may be passed to the Rhythm constructor.
In addition to allowing music to be converted from one music format to another, the architecture of JFugue can be used to create programmatic tools that are capable of both performing computations on incoming music (from any format) and changing incoming music. The example below is a simple tool that keeps track of all instruments used in a musical piece.
publicclassInstrumentToolDemo{publicstaticvoidmain(String[]args)throwsInvalidMidiDataException,IOException{MidiParserparser=newMidiParser();// Remember, you can use any Parser!InstrumentToolinstrumentTool=newInstrumentTool();parser.addParserListener(instrumentTool);parser.parse(MidiSystem.getSequence(newFile("YourMidiFile.mid")));// Change to a real filenameList<String>instrumentNames=instrumentTool.getInstrumentNames();for(Stringname:instrumentNames){System.out.println(name);}}}classInstrumentToolextendsParserListenerAdapter{privateList<String>instrumentNames;publicInstrumentTool(){super();instrumentNames=newArrayList<String>();}@OverridepublicvoidonInstrumentParsed(byteinstrument){StringinstrumentName=MidiDictionary.INSTRUMENT_BYTE_TO_STRING.get(instrument);if(!instrumentNames.contains(instrumentName)){instrumentNames.add(instrumentName);}}publicList<String>getInstrumentNames(){returnthis.instrumentNames;}}
JFugue provides functionality on top of Java's MIDI Transmitter and Receiver classes to reduce the amount of code that a developer would need to write to connect to external MIDI devices.
Uses in Other Applications
JFugue has been used in a number of applications, including software projects and artistic installations.
TransProse, which turns classic novels into music, uses JFugue[9]
The JFugue Music NotePad provides a user interface for composing music[10]
JFrets is an application for teaching and training guitar tablature[11]
Log4JFugue is a utility for converting log files created by log4j into musical patterns; this allows one to listen for changes in a log file, which provides a much different experience than reading through the file line-by-line.[12][13]
Audovia is a database application for making music using JFugue MusicStrings[14]
JFugue has been used to play music when a software build fails or succeeds.
JFugue is one of the few Java libraries that lets one do something interesting in as little as one or two lines of code. This distinction earned JFugue a place in the book "Groovy in Action"[15]