Skip to content
This repository has been archived by the owner on Feb 8, 2019. It is now read-only.

jsocol/html5loopz

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 

Repository files navigation

HTML5 Loopz

HTML5 Loop(z|s) is a track/loop mixer in HTML5 using nothing but HTML, CSS and JavaScript. It targets Firefox >= 4 because it uses TypedArrays and the Mozilla audio-writing API (Audio().mozWriteAudio()). Other browser support would be great.

We generate audio on the fly from JS by writing the waveform directly into the audio system. Right now we can mix down and render 4 channel audio somewhere between "insanely" fast and "holy shit" fast.

Credits

Matt Claypotch and James Socol created this as a one-day hack for an event Jeff Balogh put together.

TODO

V1:

  • Make the UI correctly add samples to channels. (Timing is off.)
  • Finish the drag/drop events. (Moving and Removing need implemetation.)
  • Investigate audio writing issues. (Writing data too quickly?)
  • Store serialized Timelines in localStorage with names.
  • Add more clips.
  • Make phat beatz with Kumar!

V+:

  • Drag/drop + FileAPI: add custom samples from .wav/.ogg.
  • Share Timelines (requires server-side component) via URL.
  • Bounce down to stereo.
  • Keyframed output channel fade control.
  • Generate .wav files in humongous data URIs--let people download/save.
  • Add/remove channels.
  • On-the-fly waveform rendering (instead of pre-rendering the whole thing).
  • Timeline UI zooming and scaling.
  • Timeline transforms (e.g.: scale by X, pitch modulate, volume controls).

Vlolmaybe:

  • Bounce down to 5.1.

About

FruityLoops/FL Studio in HTML and JS.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published