首页 > 编程 > HTML > 正文

HTML5 video标签(播放器)学习笔记-(二)-播放控制

2020-03-24 15:49:37
字体:
来源:转载
供稿:网友

HTML5 video标签(播放器)学习笔记(二):播放控制

本文的目录:

1.获取影片总时长

2.播放、暂停

3.获取影片已播放时间和设置播放点

4.音量的获取和设置

第一、获取影片总时长

对播放器(video)操作,首先要得到的是影片的一些信息,其中一个就是总时长,除了内容以为,总时长也是第一时间要显示的。在对video进行操作的的前先给video标签添加一个ID,这样方便我们获取video元素



代码如下:

<video id="myVideo" controls preload="auto" width=300 height="165"

poster="http://img0.ph.126.net/I10JqUUJDmlEtE_XYl4hOg==/6608842237655242020.jpg"

src="http://www.w3cschool.cc/try/demo_source/mov_bbb.mp4">

</video>

设置一个ID后,那么就可以开始操作了,要获取总时长,要用到video的一个事件-loadedmetadata,这个事件的触发表示元数据(媒体的一些基本信息)已经加载完成,用addEventListener监听事件



代码如下:

var myVideo = document.getElementById('myVideo');//获取video元素

myVideo.addEventListener("loadedmetadata", function(){

//要执行的代码

});

好了,已经监听了,那么接下来要做的就是获取总时长,其实就是一个属性-duration

var myVideo = document.getElementById('myVideo')//获取video元素

,tol = 0

;

myVideo.addEventListener("loadedmetadata", function(){

tol = myVideo.duration;//获取总时长

});

需要注意的是获取到的在总时长的单位为秒,显示的时候根据需要去转换。

第二、播放、暂停

对播放器来说最基本的一个功能就是播放和暂停了,而在获取总时长后,接着的操作也就是播放和暂停。这个时候用到了video的两个方法就是play和pause



代码如下:

var myVideo = document.getElementById('myVideo')//获取video元素

,tol = 0

;

myVideo.addEventListener("loadedmetadata", function(){

tol = myVideo.duration;//获取总时长

});</p> <p> //播放

function play(){

myVideo.play();

}</p> <p> //暂停

function pause(){

myVideo.pause();

}



需要注意的是,当播放结束后再运行play方法将会从头播放。

第三、获取影片的播放时间和设置播放点

播放器能播放和暂停后,那么接下来需要看到的就是影片播放了多久,播放到哪个时间点了。这个操作跟获取总时长很相似,都是需要监听一个事件和获取一个属性的值,那么用到的是video的timeupdate事件和html' target='_blank'>currentTime属性

代码如下:

//播放时间点更新时

myVideo.addEventListener("timeupdate", function(){

var currentTime = myVideo.currentTime;//获取当前播放时间

console.log(currentTime);//在调试器中打印

});



运行后会在控制台看到很多数据...

我们经常会接到一个要求,那就是上次看到了10分钟了,这次看要从第十分钟开始看,那么这个时候就需要设置播放点了,设置播放点用得还是currentTime属性,currentTime属性是可读写的,要注意的是设置值的单位是秒,如果播放点不是秒为单位那就要进行转换



代码如下:

//设置播放点

function playBySeconds(num){

myVideo.currentTime = num;

}

第四、音量的获取和设置

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表