This is a javascript library that can play module music files. It is based on the libopenmpt C/C++ library. To translate libopenmpt into Javascript emscripten was used. For audio output inside the browser WebAudio API is used.
Please note: The compiled libopenmpt.js
in this repository is based on an outdated version of libopenmpt. Newer versions contain bugfixes and other improvements. Download the latest version from the libopenmpt developers here and replace libopenmpt.js.mem
and libopenmpt.js
.
If you prefer to compile libopenmpt.js
yourself (to save space or make custom changes) follow the instructions in the "Development" section.
- Play all tracker formats supported by libopenmpt (including mod, xm, s3m, it)
- Simple Javascript API
- Pause/Resume
- Tested with Google Chrome and Firefox
- Play local (HTML5) and remote files (XHR)
- Stereo playback
- Module metadata
- Looping mode
- Playback information (e.g. position, speed, bpm)
- Mixer settings (e.g. sampling rate, resolution)
- Seekbar support
See it in action here.
Just drop a module (e.g. from modarchive.org) on the demo page and enjoy.
Download the latest emscripten SDK. Follow the instructions for your OS. Make sure emcc
and em++
commands are available in the PATH.
Next download and extract the libopenmpt source code (unix like) from https://lib.openmpt.org/libopenmpt/.
Use this command inside the libopenmpt source folder to build:
make CONFIG=emscripten
If it compiles successfully these files (and a few more) will be created in the bin
directory:
libopenmpt.js
is libopenmpt compiled to JavaScript.libopenmpt.js.mem
is the memory initialization filelibopenmpt.js
will download/require it when loaded.libopenmpt_test.js
(andlibopenmpt_test.j.mem
) is the libopenmpt test suite and can be run in NodeJS.
Only the first two files are needed for chiptune2.js.
The stylesheet is built with SASS+Compass. To build this yourself, follow the Compass installation instructions, then change into the chiptune2.js directory and use this command:
compass watch
The stylesheet .css file with rebuild every time you make a change to the source file in the sass
folder.
Thanks to everyone!
All code in this project is MIT (X11) licensed. The only exception are the compiled libopenmpt parts which remain under the OpenMPT project BSD license.
License text below:
Copyright © 2013-2017 The chiptune2.js contributers.
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.