spacer

Webref WebRef   Sitemap · Experts · Tools · Services · Newsletters · About i.com

home / experts / javascript / column51


A Streaming Media JukeBox

Developer News
Microsoft Shows Off Silverlight 4, IE9 Plans
Metasploit Expands Vulnerability Test Framework
HyperCard Reborn?

The JukeBox's Script

Our streaming media jukebox is very similar to our audio jukebox from Column 21. We first define an array of object:

var streams = new Array();

Then we define the object constructor as:

function makeStream(url, name) {
  this.url = url;
  this.name = name;
}

Finally, we populate the array with several ASX and ASF files:


streams[0] = new makeStream("http://msdn.microsoft.com/downloads/samples/
 Internet/imedia/netshow/smedia/NS3/JavaScript/Buttons/control.asx",
 "Microsoft Promo for Windows Media Player");
  // (The three lines above should be joined as one line.
  // They have been split for formatting purposes.)
streams[1]=new makeStream(
 "http://www.advintsol.com/webmaster030399/webmaster.asx",
 "Microsoft Training for Windows Media Player");
  // (The three lines above should be joined as one line.
  // They have been split for formatting purposes.)
streams[2]=new makeStream(
 "mms://netshow.microsoft.com/ms/sbnasfs/wmt/turtle28.asf", "The Turtle");
  // (The two lines above should be joined as one line.
  // They have been split for formatting purposes.)
streams[3]=new makeStream("mms://netshow.microsoft.com/ms/sbnasfs/wmt/wmt.asf",
"Flying Windows Media Player logo");
  // (The two lines above should be joined as one line.
  // They have been split for formatting purposes.)

Once I know the number of elements in the array, I can dynamically write a drop-down list:

with (document) {
  writeln('<SELECT NAME="streams" onChange="change()">');
  for (var i = 0; i < streams.length; i++) {
    writeln('<OPTION VALUE="', streams[i].url, '">', streams[i].name);
  }
  writeln("</SELECT>");
}

The event handler kicks in whenever there is a change in the selection:

function change() {
  var list = document.playerCtrl.streams;
  var streamURL = list.options[list.selectedIndex].value;
  document.mediaPlayer.stop();
  document.mediaPlayer.fileName = streamURL;
}

We first extracts the URL of the currently selected item. We then call the Media Player's stop() method and then restart the new selection by assigning its URL to the Media Player's fileName property.

http://www.internet.com

Produced by Yehuda Shiran and Tomer Shiran

internet.commediabistro.comJusttechjobs.comGraphics.com

Search:

WebMediaBrands Corporate Info

Legal Notices, Licensing, Permissions, Privacy Policy.
Advertise | Newsletters | Shopping | E-mail Offers | Freelance Jobs

webref The latest from WebReference.com Browse >
Rolling Out Your Own HTML Application Version Control · HTML 5: Client-side Storage · Working with Ajax Server Extensions
Sitemap · Experts · Tools · Services · Email a Colleague · Contact FREE Newsletters 
 The latest from internet.com
Wi-Fi Product Watch, November 2009 · Chip Market Recovering From '08 Collapse · Low-Cost Tools to Kickstart Your New Business


Created: October 25, 1999
Revised: November 23, 1999

URL: http://www.webreference.com/js/column51/jukebox.html