WEB开发网
开发学院图形图像Flash 巧用Flash的Media组件实现多首mp3连播 阅读

巧用Flash的Media组件实现多首mp3连播

 2006-12-31 10:44:25 来源:WEB开发网   
核心提示:Flash MX 2004 的Media组件确实不错,大家在使用的时候可能发现MediaDisplay组件只能播放一首mp3,巧用Flash的Media组件实现多首mp3连播,如果要让它播放完一首歌曲后再接着播放另一首歌曲就不行了,今天就来给大家介绍一下怎样用MediaController和MediaDisplay组件

Flash MX 2004 的Media组件确实不错,大家在使用的时候可能发现MediaDisplay组件只能播放一首mp3,如果要让它播放完一首歌曲后再接着播放另一首歌曲就不行了。今天就来给大家介绍一下怎样用MediaController和MediaDisplay组件实现多首mp3的连播。本文源文件下载

播放器界面如图:

思路:

歌曲列表用一外部XML文件来记录,便于修改。开始的时候定义一XML对象,并载入外部XML文件,载入后再将歌曲列表提取出来放入一数组中。接着用attachMovie()方法将MediaController和MediaDisplay组件载入舞台,然后设置各自的参数,并将二者相关联(Media.associateController()或者Media.associateDisplay()方法都行)当一首歌曲播放完后,触发MediaDisplay的complete事件,在此事件中我将MediaController和MediaDisplay组件卸载并重新载入MediaController和MediaDisplay组件(使用attachMovie()方法)并给一新的实例名,并设置MediaDisplay组件的播放内容为下一首歌曲,如此往复来播放所有的歌曲。

制作步骤:

1.新建一个FLASH文档,设置舞台大小:220*70。

2.将组件MediaController和MediaDisplay拖入舞台,然后从舞台上删除。这样做的目的是将这两个组件载入库中,为接下来用attachMovie()方法将MediaController和MediaDisplay组件载入舞台做好准备。

3.新建一层,命名为function。在该层的第一帧上输入如下AS代码:

function init(){
flagNum = 1;
//播放歌曲的标示
mp3Num = 0;
attachController();
};
//将MediaController和MediaDisplay组件载入舞台并初始化
function attachController(){
//将MediaDisplay组件载入舞台并给定义实例名 "mp3Container" + flagNum
 _root.attachMovie("MediaDisplay","mp3Container" + flagNum,2);
 //设置组件初始参数
 with(_root["mp3Container" + flagNum]){
  _x = 250;
  _y = 0;
  setMedia(myArray[mp3Num],"MP3");
}
//将MediaController组件载入舞台并给定义实例名 "mp3Controller" + flagNum
_root.attachMovie("MediaController","mp3Controller" + flagNum,1);
//设置组件初始参数
with(_root["mp3Controller" + flagNum]){
  _x = 0;
  _y = 0;
  activePlayControl = false;
  controllerPolicy = "on";
  //将MediaController和MediaDisplay组件相关联
  associateDisplay(_root["mp3Container" + flagNum]);
 };
};
function playNext(){
//将MediaController和MediaDisplay组件从舞台上删除
  _root["mp3Controller" + flagNum].removeMovieClip();
  _root["mp3Container" + flagNum].removeMovieClip();
  flagNum += 1;
  mp3Num += 1;
  //如果播放到歌曲的最后一首,将mp3Num = 0,意为将从头开始播放
  if(mp3Num == mp3Total) mp3Num = 0;
  //重新载入MediaController和MediaDisplay组件,并给一新的实例名
    attachController();
    //因为每播放完一首歌曲后MediaController和MediaDisplay组件从舞台上被卸载
    //然后又重新载入MediaController和MediaDisplay组件并给了另外一个实例名
    //所以要重新向注册的监听器广播事情
    _root["mp3Container" + flagNum].addEventListener("complete", myListener);
};

4.新建一层,命名为action,在该层第一帧输入一下AS代码:

1 2  下一页

Tags:Flash Media 组件

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接