Thursday, May 6, 2010

Help us move from Flash to HTML5 (part 1).

We found out that about 1 million internet users (those using an iPad) are unable to use our http://RadioWeave.com/ social/streaming radio site because it doesn't support Flash.

So we've tried to convert everything to HTML5, to get the same or good-enough functionality out of HTML5. There's no problem with the graphic stuff (HTML and Javascript can move images around just fine, thank you very much), but now we're down to replacing Flash audio with HTML5 audio, and it's giving us trouble.

To make the very best audio experience (under even bad wifi connections), this is what we've been doing with the Flash Sound and SoundChannel classes:
  • buffer the downloading of MP3 files, a few ahead of time
  • measure download rates (so we can download hifi or lofi files accordingly)
  • play during download
  • measure how much has been downloaded to display that information to the user
  • allow user to pause/play/pause
  • allow the user to reposition where in the track to play
With HTML5's <audio> tag and "HTMLAudioElement" we can download an MP3 file and make it play (although even this tends to crash Safari on OSX about as much as our Flash code would if pushed). What we haven't figured out is how to know exactly when buffering has made progress, how much is buffered, how fast it is buffering, when playing starts, and how to restart play from any given position.

We keep hearing that Flash is dead and no longer needed because HTML5 is ready to replace Flash.

So, come on you Flash haters. A little help, please? Let us know (in the comments, so everyone can benefit) how to replace our Flash sound capabilities with HTML5.

Thanks.

3 comments:

  1. ...umm wait till 2022:

    "Ian Hickson, editor of the HTML5 specification, expects the specification to reach the W3C Candidate Recommendation stage during 2012, and W3C Recommendation in the year 2022 or later:

    http://wiki.whatwg.org/wiki/FAQ#When_will_HTML5_be_finished.3F

    ReplyDelete
  2. Thanks for the info, but it still doesn't answer the question. When HTML5 is ready in 2022, what code will I use to replace flash audio with HTML5 audio?

    ReplyDelete
  3. I know...just being funny.

    The truth is we use Flash to cover things that are not covered in HTML X because Flash offers a nice feature set that works across the browsers (for desktop/laptops that is).

    I think it'll be a while before HTML 5 has a equivalent feature set w/ cross-browser support.

    HTML feels a lot like DHTML did back in 1999

    ReplyDelete