中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

如何實現(xiàn)HTML5video播放控制-創(chuàng)新互聯(lián)

本篇內(nèi)容主要講解“如何實現(xiàn)HTML5 video播放控制”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“如何實現(xiàn)HTML5 video播放控制”吧!

創(chuàng)新互聯(lián)成立與2013年,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目做網(wǎng)站、成都網(wǎng)站建設(shè)網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元周至做網(wǎng)站,已為上家服務(wù),為周至各地企業(yè)和個人服務(wù),聯(lián)系電話:18980820575

本文的目錄:

1.獲取影片總時長
2.播放、暫停
3.獲取影片已播放時間和設(shè)置播放點
4.音量的獲取和設(shè)置

第一、獲取影片總時長

對播放器(video)操作,首先要得到的是影片的一些信息,其中一個就是總時長,除了內(nèi)容以為,總時長也是第一時間要顯示的。在對video進(jìn)行操作的的前先給video標(biāo)簽添加一個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>


設(shè)置一個ID后,那么就可以開始操作了,要獲取總時長,要用到video的一個事件-loadedmetadata,這個事件的觸發(fā)表示元數(shù)據(jù)(媒體的一些基本信息)已經(jīng)加載完成,用addEventListener監(jiān)聽事件



代碼如下:

var myVideo = document.getElementById('myVideo');//獲取video元素
myVideo.addEventListener("loadedmetadata", function(){
   //要執(zhí)行的代碼
});
    好了,已經(jīng)監(jiān)聽了,那么接下來要做的就是獲取總時長,其實就是一個屬性-duration
var myVideo = document.getElementById('myVideo')//獲取video元素
   ,tol = 0
;
myVideo.addEventListener("loadedmetadata", function(){
   tol = myVideo.duration;//獲取總時長
});


需要注意的是獲取到的在總時長的單位為秒,顯示的時候根據(jù)需要去轉(zhuǎn)換。

第二、播放、暫停

對播放器來說最基本的一個功能就是播放和暫停了,而在獲取總時長后,接著的操作也就是播放和暫停。這個時候用到了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();
}



    需要注意的是,當(dāng)播放結(jié)束后再運(yùn)行play方法將會從頭播放。

    第三、獲取影片的播放時間和設(shè)置播放點

    播放器能播放和暫停后,那么接下來需要看到的就是影片播放了多久,播放到哪個時間點了。這個操作跟獲取總時長很相似,都是需要監(jiān)聽一個事件和獲取一個屬性的值,那么用到的是video的timeupdate事件和currentTime屬性



代碼如下:


//播放時間點更新時
myVideo.addEventListener("timeupdate", function(){
   var currentTime = myVideo.currentTime;//獲取當(dāng)前播放時間
   console.log(currentTime);//在調(diào)試器中打印
});



    運(yùn)行后會在控制臺看到很多數(shù)據(jù)...

    我們經(jīng)常會接到一個要求,那就是上次看到了10分鐘了,這次看要從第十分鐘開始看,那么這個時候就需要設(shè)置播放點了,設(shè)置播放點用得還是currentTime屬性,currentTime屬性是可讀寫的,要注意的是設(shè)置值的單位是秒,如果播放點不是秒為單位那就要進(jìn)行轉(zhuǎn)換



代碼如下:

//設(shè)置播放點
function playBySeconds(num){
   myVideo.currentTime = num;
}


    第四、音量的獲取和設(shè)置

    播放器播放的過程中能暫停、播放,知道現(xiàn)在播放到哪里了和可以從某個時間點開始播放,那么接下來操作的就是音量了。這一點跟第三相似,獲取音量可以直接用volume屬性就可以了,但是在這里還要介紹的是音量改變的觸發(fā)事件,方面以后需要自定義UI使用,那就是volumechange事件



代碼如下:


//音量改變時
myVideo.addEventListener("volumechange", function(){
   var volume = myVideo.volume;//獲取當(dāng)前音量
   console.log(volume);//在調(diào)試器中打印
});



    當(dāng)你通過控制條來改變音量時,你會看到調(diào)試?yán)锩嬗泻芏鄶?shù)據(jù)。要注意的是音量的范圍值為0~1,一般在UI中都是用百分比,所以需要的時候要進(jìn)行轉(zhuǎn)換。

    音量是可以通過改變屬性來設(shè)置的,跟播放的時間點是相似的,只不過音量設(shè)置的是volume屬性



代碼如下:

//設(shè)置音量
function setVol(num){
   myVideo.volume = num;
}



    下面是完整的代碼:



代碼如下:

<!DOCTYPE html>
<html>
<head>
   <title>Video step2</title>
   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
</head>
<body>
   <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>
<script>
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();
}</p> <p>//播放時間點更新時
myVideo.addEventListener("timeupdate", function(){
   var currentTime = myVideo.currentTime;//獲取當(dāng)前播放時間
   console.log(currentTime);//在調(diào)試器中打印
});</p> <p>//設(shè)置播放點
function playBySeconds(num){
   myVideo.currentTime = num;
}</p> <p>//音量改變時
myVideo.addEventListener("volumechange", function(){
   var volume = myVideo.volume;//獲取當(dāng)前音量
   console.log(volume);//在調(diào)試器中打印
});</p> <p>//設(shè)置音量
function setVol(num){
   myVideo.volume = num;
}
</script>
</body>
</html>


到此,相信大家對“如何實現(xiàn)HTML5 video播放控制”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

當(dāng)前名稱:如何實現(xiàn)HTML5video播放控制-創(chuàng)新互聯(lián)
當(dāng)前地址:http://www.rwnh.cn/article18/hcddp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)、小程序開發(fā)網(wǎng)站內(nèi)鏈、網(wǎng)站導(dǎo)航靜態(tài)網(wǎng)站、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
莱西市| 泰宁县| 康定县| 常山县| 沙河市| 宣城市| 贵州省| 克山县| 信阳市| 贺州市| 房山区| 新泰市| 裕民县| 曲松县| 吕梁市| 开封市| 卢龙县| 凌海市| 宝坻区| 恩平市| 阳西县| 阿拉善盟| 怀安县| 永泰县| 柳州市| 龙里县| 清水县| 静安区| 临澧县| 新郑市| 比如县| 城市| 泗阳县| 新和县| 南丹县| 宜章县| 樟树市| 吉木乃县| 阳谷县| 广元市| 洱源县|