videoplayer(demo view)
此组件,主要是实现html5 video player 视频播放功能,主要实再现了视频的通常的播放控制功能。 ##1.1 主要功能##
- 播放暂停功能
- 进度条控制及拖放
- 音量控制
- 全屏控制,分为虚拟全屏和原生全屏
- ...
##1.2 问题反馈
- email: ahmzj@163.com
- QQ: 316933268
the player plugin relative jquery.1.7 + ##2.1 include files## at fire,you have to include js file and style sheet.
<link rel="stylesheet" href="../src/css/videoplayer.css">
<script type="text/javascript" src="../src/js/videoplayer.js"></script>
##2.2 init to do
/**
* param {String} videoSelector,is a dom id or jquery selector
* param {Data} params.it set videoplayer params and some events
*/
var videoplayer = videoPlayer(videoSelector,params);
demo
var videoplayer2=videoPlayer('mod_player2',{
autoPlay:false,
muted:true,
setSource:function(canplayType){
//if(canplayType == 'mp4'){
// return 'http://mediaelementjs.com/media/echo-hereweare.mp4'
//}
if (canplayTypes.indexOf('m3u8') >= 0) {
return 'http://play.ergeyy.com/vedios/stream/xiaopingguo.m3u8'
}
},
success:function(videoElement,node,videoObj){
console.log('----success ',arguments)
videoElement.addEventListener('timeupdate',function(){
//when timeupdata event to do ...
},false);
videoObj.timeupdate(function(currentTime){
//when video play to do, speed is 1s
});
},
//fires when a problem is detected
error:function(){
}
});
##params##
###width### width {Number ::853}:播放器默认宽度
var videoplayer2=videoPlayer('mod_player2',{
//....
width:853,
//...
});
###height### height {Number ::480}:播放器默认高度
var videoplayer2=videoPlayer('mod_player2',{
//....
height:480,
//...
});
###muted###
muted {boolean :: false}:默认是否静音
var videoplayer2=videoPlayer('mod_player2',{
//....
muted:true,
//...
});
###setSource### setSource {function}:设置视频源地址
var videoplayer2=videoPlayer('mod_player2',{
setSource:function(canplayType){
//canplayType : ['mp4', 'ogg', 'webm']
if (canplayTypes.indexOf('m3u8') >= 0) {
return 'http://play.ergeyy.com/vedios/stream/xiaopingguo.m3u8'
}
//if(canplayType == 'mp4'){
// return 'http://mediaelementjs.com/media/echo-hereweare.mp4'
//}
}
});
###success### success {function}:播放成功时执行
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
/**
*params videoElement {domObj} is video dom object
*params videoObj {videoPlayerObject} is videoPlayer object
*/
videoElement.addEventListener('timeupdate',function(){
//when timeupdata event to do ...
},false);
videoObj.timeupdate(function(currentTime){
//when video play to do, speed is 1s
});
},
});
###canfast### canfast {boolean ::false}:是否可以快进
var videoplayer2=videoPlayer('mod_player2',{
//....
canfast:true,
//...
});
###virtualFullScreen### virtualFullScreen{boolean ::true} 是否虚拟全屏
var videoplayer=videoPlayer('mod_player',{
virtualFullScreen:true,
});
##API##
###videoplyer 方法###
play([showControllBar]) 播放视频
@showControllBar [boolean :false] 是否显示控制板,默认为false,主要配合pause使用。
var videoplayer = photofigure(imgdata,2);
videoplayer.play();
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use play method
videoObj.play();
//user video Element default method
videoElement.play();
},
});
pause([hideControllBar]) 暂停视频
@hideControllBar [boolean:false] 是否隐藏控制面板,默认为false,不隐藏。
var videoplayer = photofigure(imgdata,2);
videoplayer.pause();
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use pause method
videoObj.pause();
//user video Element default method
videoElement.pause();
},
});
fullScreen() 进入全屏模式
var videoplayer = photofigure(imgdata,2);
videoplayer.fullScreen();
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use fullScreen method
videoObj.fullScreen();
},
});
unFullScreen() 退出全屏模式
var videoplayer = photofigure(imgdata,2);
videoplayer.unFullScreen();
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use unFullScreen method
videoObj.unFullScreen();
},
});
setCurrentTime(newTime) 设置当前播放点,单位:秒
var videoplayer = photofigure(imgdata,2);
videoplayer.setCurrentTime(23);
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use video element set currentTime
videoElement.currentTime=23
//or
//set currentTime
videoObj.setCurrentTime(23);
},
});
getContiune() {boolean} 获取是否可以连续的值
timeupdate(callback) 监控更新时间,时间间隔为 1s
var videoplayer = photofigure(imgdata,2);
videoplayer.timeupdate(function(currenTime){
console.log('currenTime:',currenTime)
});
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use timeupdate method
videoObj.timeupdate(function(currenTime){
console.log('currenTime:',currenTime)
});
},
});
待整理。。。
chrome55+,系统全屏时,会有下载按钮,解决方式是添加css
video::-internal-media-controls-download-button {
display:none;
}
video::-webkit-media-controls-enclosure {
overflow:hidden;
}
video::-webkit-media-controls-panel {
width: calc(100% + 30px); /* Adjust as needed */
}
##videoPlayer Events事件方法##
videoObj.on('next',function) 当点击next时,触发
var videoplayer = photofigure(imgdata,2);
videoplayer.on('next',function(){
console.log('switch next one');
})
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use next event
videoplayer.on('next',function(){
console.log('switch next one');
})
},
});
videoObj.on('continue',function) 当点击连播时,触发
var videoplayer = photofigure(imgdata,2);
videoplayer.on('continue',function(currentStatus){
console.log('can contnue play:',currentStatus);
})
//or
var videoplayer2=videoPlayer('mod_player2',{
success:function(videoElement,node,videoObj){
//use continue event
videoplayer.on('continue',function(currentStatus){
console.log('can contnue play:',currentStatus);
})
},
});
待整理。。。
#下面是video标签的属性,方法 和事件#
- src :视频的属性
- poster:视频封面,没有播放时显示的图片
- preload:预加载
- autoplay:自动播放
- loop:循环播放
- controls:浏览器自带的控制条
- width:视频宽度
- height:视频高度
html 代码
<video id="media" src="http://www.sundxs.com/test.mp4" controls width="400px" heigt="400px"></video>
//audio和video都可以通过JS获取对象,JS通过id获取video和audio的对象
获取video对象
Media = document.getElementById("media");
##Media方法和属性:##
HTMLVideoElement和HTMLAudioElement 均继承自HTMLMediaElement
- Media.error; //null:正常
- Media.error.code; //1.用户终止 2.网络错误 3.解码错误 4.URL无效
***//网络状态 ***
- Media.currentSrc; //返回当前资源的URL
- Media.src = value; //返回或设置当前资源的URL
- Media.canPlayType(type); //是否能播放某种格式的资源
- Media.networkState; //0.此元素未初始化 1.正常但没有使用网络 2.正在下载数据 3.没有找到资源
- Media.load(); //重新加载src指定的资源
- Media.buffered; //返回已缓冲区域,TimeRanges
- Media.preload; //none:不预载 metadata:预载资源信息 auto:
***//准备状态 ***
- Media.readyState;//1:HAVE_NOTHING 2:HAVE_METADATA 3.HAVE_CURRENT_DATA 4.HAVE_FUTURE_DATA 5.HAVE_ENOUGH_DATA
- Media.seeking; //是否正在seeking
***//回放状态 ***
- Media.currentTime = value; //当前播放的位置,赋值可改变位置
- Media.startTime; //一般为0,如果为流媒体或者不从0开始的资源,则不为0
- Media.duration; //当前资源长度 流返回无限
- Media.paused; //是否暂停
- Media.defaultPlaybackRate = value;//默认的回放速度,可以设置
- Media.playbackRate = value;//当前播放速度,设置后马上改变
- Media.played; //返回已经播放的区域,TimeRanges,关于此对象见下文
- Media.seekable; //返回可以seek的区域 TimeRanges
- Media.ended; //是否结束
- Media.autoPlay; //是否自动播放
- Media.loop; //是否循环播放
- Media.play(); //播放
- Media.pause(); //暂停
*** //视频控制 ***
- Media.controls;//是否有默认控制条
- Media.volume = value; //音量
- Media.muted = value; //静音
***TimeRanges(区域)对象 *** - TimeRanges.length; //区域段数
- TimeRanges.start(index) //第index段区域的开始位置
- TimeRanges.end(index) //第index段区域的结束位置
//相关事件
var eventTester = function(e){
Media.addEventListener(e,function(){
console.log((new Date()).getTime(),e)
},false);
}
- eventTester("loadstart"); //客户端开始请求数据
- eventTester("progress"); //客户端正在请求数据
- eventTester("suspend"); //延迟下载
- eventTester("abort"); //客户端主动终止下载(不是因为错误引起)
- eventTester("loadstart"); //客户端开始请求数据
- eventTester("progress"); //客户端正在请求数据
- eventTester("suspend"); //延迟下载
- eventTester("abort"); //客户端主动终止下载(不是因为错误引起),
- eventTester("error"); //请求数据时遇到错误
- eventTester("stalled"); //网速失速
- eventTester("play"); //play()和autoplay开始播放时触发
- eventTester("pause"); //pause()触发
- eventTester("loadedmetadata"); //成功获取资源长度
- eventTester("loadeddata"); //
- eventTester("waiting"); //等待数据,并非错误
- eventTester("playing"); //开始回放
- eventTester("canplay"); //可以播放,但中途可能因为加载而暂停
- eventTester("canplaythrough"); //可以播放,歌曲全部加载完毕
- eventTester("seeking"); //寻找中
- eventTester("seeked"); //寻找完毕
- eventTester("timeupdate"); //播放时间改变
- eventTester("ended"); //播放结束
- eventTester("ratechange"); //播放速率改变
- eventTester("durationchange"); //资源长度改变
- eventTester("volumechange"); //音量改变