扩展jQuery Media Plugin,使它变得更完整

作为一款万能播放器插件,总能少了对媒体控制的接口呢。由是偶利用空闲时间把这个插件完善了一下。使之具体播放、暂停、停止的功能。具体实现步骤如下:

第一步:打开 jQuery.Media.js文件定义一个全局变量,用来识别当前播放器的类型

 var curPlayer;//全局变量:当前播放器的类型。

 

第二步:为插件生成的对象创建一个ID,默认是没带ID的。先找到$.fn.media.defaults = {……},这里面定义了一些默认参数,在这里面添加一个playerid: 'MyPlayer'。然后修改function generate这个方法,在方法里找到变量a的赋值语句,修改为var a = ['<object id="'+opts.playerid+'" width="' + opts.width + '" height="' + opts.height + '" '];

 

第三步:给全局变量curPlayer赋值,把当前播放器的类型赋给它。同样也是修改function generate这个方法,在方法里的第一行加入 curPlayer = player;//当前播放器的类型

 

以上步骤实现了插件生成的播放器对象拥有了一个ID,接下来是控制操作的实现。

 

第四步:为兼容IE,FF,Opera浏览器获取对播放器的ID,自定义一个方法。

function getMovieObject(movieName) 
 { 
   if (window.document[movieName]) 
   { 
       return window.document[movieName]; 
   } 
   if (navigator.appName.indexOf("Microsoft Internet")==-1) 
   { 
     if (document.embeds && document.embeds[movieName]) 
       return document.embeds[movieName]; 
   } 
   else // if (navigator.appName.indexOf("Microsoft Internet")!=-1) 
   { 
     return document.getElementById(movieName); 
   } 
 }

 

第五步:播放、暂停、停止的控制功能实现。

/*播放*/
$.fn.Play = function(ObjectId){
 if(ObjectId==null){
  ObjectId = $.fn.media.defaults.playerid;
 }
 var MovieObject = getMovieObject(ObjectId);//获取当前播放器的ID
 switch(curPlayer.toLowerCase())
 {
  case "flash":
  MovieObject.Play();  
  break;
  case "quicktime":
  MovieObject.Play();
  break;
  case "real":
  MovieObject.DoPlay();
  break;
  case "winmedia":
  MovieObject.controls.play();
  break;
 }
}
/*暂停*/ 
$.fn.Pause = function(ObjectId){
 if(ObjectId==null){
  ObjectId = $.fn.media.defaults.playerid;
 }
 var MovieObject = getMovieObject(ObjectId);//获取当前播放器的ID
 switch(curPlayer.toLowerCase())
 {
  case "flash":
  MovieObject.StopPlay(); 
  break;
  case "quicktime":
  MovieObject.Stop();
  break;
  case "real":
  MovieObject.DoPause();
  break;
  case "winmedia":
  MovieObject.controls.pause();
  break;
 }
}
/*停止控制*/
$.fn.Stop = function(ObjectId){
 if(ObjectId==null){
  ObjectId = $.fn.media.defaults.playerid;
 }
 var MovieObject = getMovieObject(ObjectId);//获取当前播放器的ID
 switch(curPlayer.toLowerCase())
 {
  case "flash":
  MovieObject.Rewind();
  break;
  case "quicktime":
  MovieObject.Rewind();
  break;
  case "real":
  MovieObject.DoStop();
  break;
  case "winmedia":
  MovieObject.controls.stop();
  break;
 }
}

 

第六步:调用实例

<html>
<script type="text/javascript" src="js/jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="js/jquery.media.js"></script>
<title>Demo</title>
<body>
 <a href="demo.swf"
   class="media {width: 450, height: 250, caption: false }">
   Watch my movie!</a><br/>
   <a href="#" onClick="$('a.media').Play();">Play</a>
   <a href="#" onClick="$('a.media').Pause();">Pause</a>
<br/>  

<script type="text/javascript">
$('a.media').media();
</script>
</body>
</html>

说明:如果页面中需要放置一个以上的视频,实例如下:

创建$('a.media').media({playerid:'myflash'});

控制 <a href="#" onClick="$('a.media').Pause(‘myflash’);">Pause</a>

 

 

第一次写博客,表达的不好,请见谅。本章示例下载http://download.csdn.net/source/2432977

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值