Special notes for Version 3.3.0:
-
The build process has switched over to webpack. The minimization is now done with UglifyJS. This shouldn't cause any side effects.
-
The "editor" version of the library has been rolled into the "basic" version. There is only the "basic" and "midi" versions now, since the editor code doesn't add much to the size.
-
The npm version has a new export called "signature" that gives your javascript code some version information.
-
The documentation has all been moved to the
/docs
folder. -
The examples have all been moved to the
/examples
folder.
Special note for Version 3.2.0:
abcjs is proud to announce that it can now be installed with npm
. Instead of including the minimized files on your page, you can use the library by doing the following in your project:
npm install --save abcjs
Note that the minimized versions will still be maintained, so you can still copy the minimized file to your project.
Special notes for Version 3.0:
In-browser MIDI is now supported. There are some extra dependencies when using that feature. Downloadable MIDI is still supported with no extra dependencies.
- ABC 1.6 is pretty much implemented.
- Many of the new features of ABC 2.1 are being implemented now.
- The old support for MIDI using QuickTime is removed and midi.js is used instead.
- Added viewPortHorizontal and scrollHorizontal to the renderParams.
- Add class "slur" to slurs and ties.
- Add "hint measure"
- Allow scrolling in the animation.
- Handle %%titlecaps directive.
- Add curly brace to indicate piano part (with inspiration from Anthony P. Pancerella).
- Add invisible marker to the top of each system so that it can be found easily.
- Add an option to put each line in a separate svg so that browsers will paginate correctly.
-
The default MIDI program has been changed to "0".
-
There are a number of new MIDI parameters.
"Bouncing Ball" cursor:
ABCJS.startAnimation(paper, tune, options)
paper: the output div that the music is in.
tune: the tune object returned by renderAbc.
options: a hash containing the following:
hideFinishedMeasures: true or false [ false is the default ]
showCursor: true or false [ false is the default ]
bpm: number of beats per minute [ the default is whatever is in the Q: field ]
renderABC()
now returns the object that was created by the process. This allows further processing.
highlight()
and unhighlight()
now can be passed an optional class name and color.
Descriptive classes to all SVG elements: If you include { add_classes: true }
in the rendering params,
then a set of classes are applied to each SVG element so they can be manipulated with css.
There is a new public entry point that is designed for those who want some information about what is in a tunebook before processing it.
// Tunebook is the contents of the text file containing one or more
// ABC-formatted tunes, plus global header info, and inter-tune text.
var book = new ABCJS.TuneBook(tunebook);
var fileHeader = book.header;
var numberOfTunes = book.tunes.length;
for (var i = 0; i < numberOfTunes; i++) {
var title = book.tunes[i].title;
var tuneAndHeader = book.tunes[i].abc;
var justTheTune = book.tunes[i].pure;
var id = book.tunes[i].id;
}
var tune = book.getTuneById(id);
tune = book.getTuneByTitle(title);
The variable book
contains:
Member | Description |
---|---|
book.header | This is all of the text that appears before the first tune starts in the file. |
book.tunes.length | This is how many tunes are in that file. |
book.tunes[i].title | This is the first title found for the particular tune. White space is trimmed from both the beginning and end. |
book.tunes[i].abc | This is the particular tune with the global header information added to it. This is what should be passed to the parser in most cases. |
book.tunes[i].pure | This is the particular tune without the header. |
book.tunes[i].id | This is the id (that is, the text on the X: line). White space is trimmed from both the beginning and end. |
book.getTuneById | This will find the FIRST tune in the tune book with the id. |
book.getTuneByTitle | This will find the FIRST tune in the tune book with the title. |
IMPORTANT: Version 1.1 has removed all globals and any side effects of ABCJS except for this single global:
window.ABCJS
This means that you will have to modify your pages to use the new syntax. All of the old entry points are still available with a slightly different name. Here is a list of all recommended entry points:
New name | Old name |
---|---|
ABCJS.numberOfTunes | numberOfTunes |
ABCJS.renderAbc | renderABC |
ABCJS.renderMidi | renderMidi |
ABCJS.Editor | ABCEditor |
ABCJS.plugin | abc_plugin |