天天看點

html播放器控制,HTML5 video标簽(播放器)學習筆記(二):播放控制

介紹了html5标簽video(播放器)初始化需要做的一些工作,如何簡單快速使用html5的播放器,本文将重點介紹如何用js來操作video标簽,也就是如何對video做一些簡單基本的操作,包括了播放器的播放、暫停,音量的讀取、設定等寫相關操作,進而開始播放器的擴充之路。

本文的目錄:

1.擷取影片總時長

2.播放、暫停

3.擷取影片已播放時間和設定播放點

4.音量的擷取和設定

第一、擷取影片總時長

對播放器(video)操作,首先要得到的是影片的一些資訊,其中一個就是總時長,除了内容以為,總時長也是第一時間要顯示的。在對video進行操作的的前先給video标簽添加一個id,這樣友善我們擷取video元素

複制代碼代碼如下:

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

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

設定一個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;//擷取總時長

});

//播放

function play(){

myvideo.play();

}

//暫停

function pause(){

myvideo.pause();

}

需要注意的是,當播放結束後再運作play方法将會從頭播放。

第三、擷取影片的播放時間和設定播放點

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

複制代碼代碼如下:

//播放時間點更新時

myvideo.addeventlistener("timeupdate", function(){

var currenttime = myvideo.currenttime;//擷取目前播放時間

console.log(currenttime);//在調試器中列印

});

運作後會在控制台看到很多資料...

我們經常會接到一個要求,那就是上次看到了10分鐘了,這次看要從第十分鐘開始看,那麼這個時候就需要設定播放點了,設定播放點用得還是currenttime屬性,currenttime屬性是可讀寫的,要注意的是設定值的機關是秒,如果播放點不是秒為機關那就要進行轉換

複制代碼代碼如下:

//設定播放點

function playbyseconds(num){

myvideo.currenttime = num;

}

第四、音量的擷取和設定

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

複制代碼代碼如下:

//音量改變時

myvideo.addeventlistener("volumechange", function(){

var volume = myvideo.volume;//擷取目前音量

console.log(volume);//在調試器中列印

});

當你通過控制條來改變音量時,你會看到調試裡面有很多資料。要注意的是音量的範圍值為0~1,一般在ui中都是用百分比,是以需要的時候要進行轉換。

音量是可以通過改變屬性來設定的,跟播放的時間點是相似的,隻不過音量設定的是volume屬性

複制代碼代碼如下:

//設定音量

function setvol(num){

myvideo.volume = num;

}

下面是完整的代碼:

複制代碼代碼如下:

video step2

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

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

var myvideo = document.getelementbyid('myvideo')//擷取video元素

,tol = 0 //總時長

;

myvideo.addeventlistener("loadedmetadata", function(){

tol = myvideo.duration;//擷取總時長

});

//播放

function play(){

myvideo.play();

}

//暫停

function pause(){

myvideo.pause();

}

//播放時間點更新時

myvideo.addeventlistener("timeupdate", function(){

var currenttime = myvideo.currenttime;//擷取目前播放時間

console.log(currenttime);//在調試器中列印

});

//設定播放點

function playbyseconds(num){

myvideo.currenttime = num;

}

//音量改變時

myvideo.addeventlistener("volumechange", function(){

var volume = myvideo.volume;//擷取目前音量

console.log(volume);//在調試器中列印

});

//設定音量

function setvol(num){

myvideo.volume = num;

}

總結:通過這四個步驟來了解html5标簽video(播放器)的基本操作,而這些操作主要是通過js來監聽video的事件和對video屬性的讀寫來完成的,熟悉這四點即可靈活的在使用播放器,再根據應用場景來調整即可。