[![Travis](https://img.shields.io/travis/captbaritone/winamp2-js.svg)]() [![Codecov](https://img.shields.io/codecov/c/github/captbaritone/winamp2-js.svg)]() # Winamp2-js A reimplementation of Winamp 2.9 in HTML5 and JavaScript. **[Give it a try!](https://jordaneldredge.com/projects/winamp2-js/)** Works in modern versions of Edge, Firefox, Safari and Chrome. IE is [not supported](http://caniuse.com/#feat=audio-api). ![Screenshot of Winamp2-js](./preview.png) ## Features - Decodes the actual skin file in your browser so you can load your favorite Winamp 2 skins! - Load local audio or skin files via drag-and-drop, eject button, or "options" button (upper left-hand corner) - Both visualization modes: oscilloscope and spectrum - Hotkeys - "Shade" mini-mode - "Doubled" mode, where the main window is twice as large: `Ctrl-D` A more detailed list of features can be found in [features.md](./features.md). ## Use Winamp2-js in your project **PRE ALPHA** Several people have expressed interest in including Winamp2-js inside their website. In an attempt to try this out, I have published Winamp2-js as an NPM package. You can attempt to use it in your JS project like so: Install the package: ``` npm install --save winamp2-js npm install --save babel-polyfill ``` Create a DOM element somewhere in your HTML document: ```
``` Initialize Winamp2-js in your JavaScript: ``` import 'babel-polyfill'; import Winamp from 'winamp2-js'; const winamp = new Winamp({ initialTrack: { name: "1. DJ Mike Llama - Llama Whippin' Intro", url: "https://d38dnrh1liu4f5.cloudfront.net/projects/winamp2-js/mp3/llama-2.91.mp3" }, initialSkin: { url: "https://d38dnrh1liu4f5.cloudfront.net/projects/winamp2-js/skins/base-2.91.wsz" } }); winamp.render(document.getElementById('winamp2-js')); // In response to a user selecting a track from your UI: winamp.loadTrackUrl(url, name); ``` *Notes:* * This should not be considered "production" code. * Winamp2-js does not support Internet Explorer. * Winamp2-js was built to run on it's own page, it may not play well with surrounding CSS. * You will probably need to include [babel-polyfill](https://babeljs.io/docs/usage/polyfill/) on the page that includes Winamp2-js. * Skin and audio URLs are subject to [CORS](https://developer.mozilla.org/en-US/docs/Web/HTTP/Access_control_CORS). Please ensure they are either served from the same domain, or that the other domain is served with the correct headers. * This API is subject to change at any time. * Please reach out to me. I'd love to help you set it up, and understand how it's being used. I plan to expand this API as I learn how people want to use it. ## Development yarn # Or: npm install npm start Open `http://localhost:8080/webpack-dev-server/` in your browser. ## Building npm install npm run build Open `index.html` in your browser. ## Deploying These commands assume you have an SSH key to my server, which you probably don't have. Feel free to adapt them to your own server. npm run deploy ### Reverting npm run revert # Reverts quickly to the previous deploy HASH= npm run deploy # Runs a new deploy at a given hashlike. ### Advanced ussage There are some "feature flags" which you can manipulate by passing a specially crafted URL hash. Simply supply a JSON blob after the `#` of the URL to change these settings: * `skinUrl` (string) Url of the default skin to use. Note, this file must be served with the correct Allows Origin header. * `audioUrl` (string) Url of the default audio file to use. Note, this file must be served with the correct Allows Origin header. * `playlistEnabled` (boolean) Should the incomplete Playlist window be made avalaible. * `noMarquee` (boolean) Enable/disable to scrolling of the song title in the main window. It can be nice to turn this off when debugging Redux actions, since the scrolling generates a lot of noise. * `hideAbout` (boolean) Selectively hide the byline and GitHub link at the bottom of the page. Useful for taking screenshots. * `initialState` (object) Override the [initial Redux state](js/reducers.js). Values from this object will be recursively merged into the actual default state. __Note:__ These are intended mostly as development tools and are subject to change at any time. ## Reference - [skinspecs.pdf](http://members.xoom.it/skinart/tutorial/skinspecs..pdf) - [Skinner's Atlas 1.5 by Jellby](http://forums.winamp.com/showthread.php?p=951257) - [Winamp Skinning Tutorial](http://people.xmms2.org/~tru/promoe/Winamp_skinning_tutorial_1_5_0.pdf) - Sacrat Skinning tutorial parts [1](http://www.hugi.scene.org/online/hugi26/hugi%2026%20-%20graphics%20skinning%20sacrat%20winamp%20skinning%20tutorial%20-%201.htm), [2](http://www.hugi.scene.org/online/hugi26/hugi%2026%20-%20graphics%20skinning%20sacrat%20winamp%20skinning%20tutorial%20-%202.htm), [3](http://www.hugi.scene.org/online/hugi26/hugi%2026%20-%20graphics%20skinning%20sacrat%20winamp%20skinning%20tutorial%20-%203.htm), [4](http://www.hugi.scene.org/online/hugi26/hugi%2026%20-%20graphics%20skinning%20sacrat%20winamp%20skinning%20tutorial%20-%204.htm), and [5](http://www.hugi.scene.org/online/hugi26/hugi%2026%20-%20graphics%20skinning%20sacrat%20winamp%20skinning%20tutorial%20-%205.htm), - [Winamp Wiki](http://wiki.winamp.com/wiki/Creating_Classic_Skins) ## Predecessors - [Webamp2x](http://forums.winamp.com/showthread.php?threadid=91850) An impressive implementation from 2002(!). - [JsAmp](http://freecog.net/2005/jsamp/demo/MainWindow.xhtml) An implementation from 2005 by @twm (via [Hacker News](https://news.ycombinator.com/item?id=15317723)). - [LlamaCloud Comp](https://vimeo.com/20149683) From 2011 by [Lee Martin](http://www.leemartin.com/) (via [Twitter](https://twitter.com/leemartin/status/910235793737814017)) - [Winamp em HTML5 e Javascript](http://www.tidbits.com.br/winamp-em-html5-e-javascript) In 2010 a developer named Danilo posted one of his HTML5 experiments: "an audio player simulating good old Winamp". You will have to download the zip file. - [JuicyDrop](http://cggaurav.github.io/juicydrop/) An HTML5 implementation with less empasis on being true to the skin, but fully featured visualizations. @cggaurav is keeping it alive on [GitHub](https://github.com/cggaurav/juicydrop) - [Spotiamp](http://spotiamp.com/) The folks at Spotify reimplemented Winamp as a frontend for Spotify. Not in a browser, and only runs on Windows. ## Thanks - Research and feature prototyping: @PAEz Thank you to [Justin Frankel](http://www.1014.org/) and everyone at Nullsoft for Winamp which inspired so many of us. ## License While the Winamp name, interface, and, sample audio file are surely property of Nullsoft, the code within this project is released under the [MIT License](LICENSE.txt). That being said, if you do anything interesting with this code, please let me know. I'd love to see it.