网页嵌入快播播放器并实现服务器视频文件连续播放

上篇我们在网页中(html、jsp、php)嵌入了快播播放器,嵌入代码如下:

	<object classid="clsid:F3D0D36F-23F8-4682-A195-74C92B03D4AF" width="560" height="420" id="QvodPlayer" name="QvodPlayer" onError="downLoadQvod();">    				 <param name="url" id="qvodurl0" value="http://192.168.1.254:8089/ftp/ftpupload//2_1001_025201.AVI">  				 <param name="Autoplay" value="1">     				 <param name="Showcontrol" value="1">    	</object>  


参数介绍:url:播放视频文件的地址  Autoplay:是否自动播放,1:是,0:否  Showcontrol:是否显示控制栏,也就是下面的声音控制以及进度条 1:是,0:否,界面如下:注意:下载的快播版本不同会有不同的页面效果

 

在项目中我们可能会有这样的需求,就是从服务器端获取很多的视频文件地址,我们播放一个后自动跳转到下一个,开始我也是从快播方面考虑,在其论坛上http://bbs.kuaibo.com/找了很多相关方面的资料,发现其有自己的内部实现方式,可能要在其后台进行相应的发布和地址格式转换等等,想要研究的看这篇博客:http://bbs.kuaibo.com/thread-19410-1-1.html,后来想来想去,还是自己用js解决了,在里面使用了我们的定时器。代码如下:

<script type="text/javascript">  		 function downLoadQvod(){  		    if(window.confirm('请您先安装QvodPlayer软件,然后刷新本页才可以正常播放!')){  				window.open('<%=basePath%>video/qvod-setup.exe');  			  }  		 }    		 function play(){  		   QvodPlayer.url="F:/30230201/02-53-02.AVI";                  QvodPlayer.play();  		 }             		 var i=0;  		 function getState(){  		 //将请求的地址封装为数组  		  var   urlArray=["F:/30230201/02-52-01.AVI","F:/30230201/02-53-02.AVI","F:/30230201/02-53-03.AVI"];  		  var state = QvodPlayer.PlayState;  		   if(state==0&&i<urlArray.length){  		      QvodPlayer.url=urlArray[i];  			  QvodPlayer.play();  			  i++;  		   }  		 }             		 //设置定时器,1s种请求一次  		 setInterval("getState()",1000);  	</script>

我们也可以点击按钮后出发定时器:

	 //单个视频播放  		 function singlePlay(path){  			QvodPlayer.url="${video_path}"+path;  			QvodPlayer.play();  		 }  		   		 //多个视频连续播放  		 function multiPlay(index){  			 var urls=$("#s_"+index).text();  			 var i=1;  			 if(urls!=""){  				 var urlArray=urls.split(",");  				 singlePlay(urlArray[0]);  				 setInterval(function(){  					 var state = QvodPlayer.PlayState;  					  if(state==0&&i<urlArray.length-1){  						  singlePlay(urlArray[i]);  						  i++;  					   }  				 },1000);  			 }  		 }


这样,每1s中就是判断上一个视频文件是否播放完毕,播放完后自动跳转到下一集,不足的是没有做到像快播那样自动缓冲下一集的功能,只是一个文件的跳转而已!!

上面我们可以看到快播里面一个方法:QvodPlayer.PlayState;它是调用了快播中的一个属性,快播给我们的js和vb提供了相应的接口,正是因为这些接口的存在,我们才可以在页面中可以对快播玩转自如,下面把它提供的接口给大家瞧瞧:

1、属性接口:
1)URL:播放文件地址。URL值格式:qvod://文件大小|文件hash值|文件名|
如:qvod://145485901|E4284D21B54DCB7181EA853B88746D693ACEA079|美丽的选择-第三部-05.rmvb|
2) AutoPlay:是否自动播放。0:不自动播放  1:自动播放。默认是不自动播放。
< PARAM NAME='AutoPlay'  VALUE='0'>
3) Showcontrol:是否显示控制栏,0=不显示  1= 显示 默认参数是显示
< PARAM NAME='Showcontrol'  VALUE='0'>

4)NextWebPage:播放当前节目后自动导航到下一集或者其它网页的功能
默认为空即不导航。网页地址请以http://开头.
<;PARAM NAME='NextWebPage' VALUE='http://www.vod588.com/dy_player/b22cbb3c.html?262614'>

5)NumLoop:是否循环播放当前节目
值:0 为不循环,大于0为循环次数,递减到0后即停止循环,-1为一直循环。
默认为0.

6)QvodAdUrl: 网页中的链接地址是qvod://格式时,可以在网页中用此参数指定播放前的缓冲页面地址
注:3.0.0.58版本及将来发布的版本才支持。
<PARAM NAME='QvodAdUrl' VALUE='http://buffer-ad.qvod.com/index_bak.asp'>

2、方法接口:
1)播放
Play():        
2)停止                        
Stop():        
3)暂停
Pause():                        

4)设置当前播放位置
Currentpos:         
例如想设置播放位置在一分钟则:
c++等语言:
long newValue = 60;
put_Currentpos(newValue);
javastricpt/vb/vbstricpt等脚本语言:
var pos = 60;
QvodPlayer.Currentpos = 60;

5) 得到当前播放位置
Currentpos:
c++等语言:               
double newValue = 0;
newValue  = get_Currentpos();
javastricpt/vb/vbstricpt等脚本语言:
var pos = 0;
pos  = QvodPlayer.Currentpos;

6) 得到播放持续时间 
Duration:               
c++等语言:
double newValue = 0;
newValue  = get_Duration();
javastricpt/vb/vbstricpt等脚本语言:
var pos = 0;
pos  = QvodPlayer.Duration;

7) 设置全屏与否 
Full (BOOL bFull):        
如设置全屏
c++等语言:
BOOL bFull = TRUE;//全屏则为TRUE,取消全屏则为FALSE
put_Full (bFull );
javastricpt/vb/vbstricpt等脚本语言:
var pos = true;
QvodPlayer.Full= true;


8) 得到是否全屏 
Full:
c++等语言:
BOOL bFull = TRUE;
bFull  = get_Full ();
javastricpt/vb/vbstricpt等脚本语言:
var pos = true;
pos  = QvodPlayer.Full;        

9) 设置静音
Mute():
c++等语言:
BOOL bMute= TRUE;//静单为TRUE,取消静音则为FALSE;
put_Mute(bMute);
javastricpt/vb/vbstricpt等脚本语言:
var pos = true;
QvodPlayer.Mute = pos ;        

10) 得到是否静音状态
BOOL GetMute():
c++等语言:
BOOL bMute = TRUE;
Mute  = get_Mute ();
javastricpt/vb/vbstricpt等脚本语言:
var pos = true;
pos  = QvodPlayer.Mute;        
               
11) 得到当前播放状态
PlayState():
c++等语言:
PLAYSTATE state= Undefined ;
state= get_PlayState ();
javastricpt/vb/vbstricpt等脚本语言:
var state;
state = QvodPlayer.PlayState;

播放状态值:        
enum enum_PalyState
{
_S_Init = 0,
_S_Stop,
_S_Pause,
_S_Playing,
_S_Buffering,
_S_Waiting,
_S_MediaEnded,
_S_Ready,
_S_Conning,
_S_BTDowning,
_S_CreateDS,
_S_Stoping
};//Undefined = 0,准备就绪 Stopped = 1,停止; Paused = 2,暂停; Playing = 3,播放中; Buffering = 4,缓冲中; Waiting = 5,等待中; MediaEnded = 6,播放结束Ready = 7, 准备读;Reconnecting = 8,重连中; BTDowning = 9 BT种子下载中; Createing = 10,正在连接中; Stoping=11 正在停止;

刚开始播的时候的状态是Createing
上面只是一部分,其他的就不一一例举了,想去了解,点击这里查看更多:http://bbs.kuaibo.com/thread-592-1-1.html

你可能感兴趣的:(JavaScript,qvod,快播)