HTML5實(shí)現(xiàn)音頻和視頻嵌入的方法

簡(jiǎn)介
HTML5未出來(lái)之前,在線(xiàn)的音頻和視頻都是借助Flash或者第三方工具實(shí)現(xiàn)的,現(xiàn)在HTML5也支持了這方面的功能。在一個(gè)支持HTML5的瀏覽器中,不需要安裝任何插件就能播放音頻和視頻。原生的支持音頻和視頻,為HTML5注入了巨大的發(fā)展?jié)摿Α?/p>
html實(shí)現(xiàn)音頻嵌入(傳統(tǒng)方式):這種方式雖然可以實(shí)現(xiàn),但是要瀏覽器支持Flash而且并不能實(shí)現(xiàn)控制,所以要實(shí)現(xiàn)起來(lái)很麻煩。
<object height="200" width="200" data="2_1.swf" > </object> <embed src="2_1.mp4" type="">
那么也就是說(shuō)HTML5存在一個(gè)很大的問(wèn)題就是兼容性。音頻
HTML5支持的音頻格式:
視頻
視頻格式:
由上可知,HTML5貌似支持的格式有點(diǎn)少哈,所以當(dāng)你發(fā)現(xiàn)用HTML5放置音頻和視頻不顯示時(shí),應(yīng)該就是格式不支持的問(wèn)題。注: MP4有3種編碼,mpg4(xdiv),,mpg4(xvid),avc(h264), 只有h264才是公認(rèn)的MP4標(biāo)準(zhǔn)編碼(在這也是被坑了,其他格式的只有聲音沒(méi)有圖像。)遇到這種問(wèn)題,就用視頻格式轉(zhuǎn)換器,轉(zhuǎn)換一下格式就OK啦。
音頻實(shí)現(xiàn)起來(lái)很簡(jiǎn)單:這里工具條使用了瀏覽器默認(rèn)的工具條。
<audio src="htmls/1.mp3" controls="controls" loop="loop" preload="auto" > 你的瀏覽器不支持video元素 </audio>
視頻雖然也可以使用瀏覽器默認(rèn)的,但無(wú)法實(shí)現(xiàn)私人訂制,所以從學(xué)技術(shù)的角度講,還是要學(xué)習(xí)一下自己做工具實(shí)現(xiàn)功能(audio也可參照此方法)。
audioVideo.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>網(wǎng)頁(yè)放置視頻</title> <style type="text/css"> </style> <script type="text/javascript" src="js/ControlBar.js"></script> </head> <body> <audio src="htmls/1.mp3" controls="controls" loop="loop" preload="auto" > 你的瀏覽器不支持video元素 </audio> <video id="myPlayer" width="600" height="400" src="htmls/2_1.mp4" controls="controls" loop="loop" poster="3.jpg"> 你的瀏覽器不支持audio元素 <!-- MP4有3種編碼,mpg4(xdiv),,mpg4(xvid),avc(h264), 只有h264才是公認(rèn)的MP4標(biāo)準(zhǔn)編碼 --> </video> <div id="progress"></div> <!-- 音量控制 --> <input id="volume" type="range" min="0" max="1" step="0.1" onchange="Volume(this)"> <!-- 速率和時(shí)間進(jìn)度的信息 --> <span id="rate">1</span>fps <span id="info"></span> <button onclick="Play(this)" id="btn1">播放</button> <button onclick="Fast()">快進(jìn)</button> <button onclick="Slow()">慢進(jìn)</button> <button onclick="Prev()">后退</button> <button onclick="Next()">前進(jìn)</button> <button onclick="Muted(this)">靜音</button> </body> </html>
顯示(html)與功能實(shí)現(xiàn)(js)分離,由外部導(dǎo)入
ControlBar.js
//使用腳本檢測(cè)瀏覽器的標(biāo)簽支持情況 var support = !!document.createElement("audio").canPlayType; if (!support) { alert("你的瀏覽器不支持本視頻播放"); } // 定義全局的視頻對(duì)象 var e1 = null; window.addEventListener("load", function() { e1 = document.getElementById("myPlayer"); }); /*前進(jìn):一分鐘 */ function Next() { e1.currentTime+=10; //設(shè)置屬性currentTime,快進(jìn)10s } /*后退:一分鐘 */ function Prev() { e1.currentTime-=10; //設(shè)置屬性currentTime,后退10s } /*播放/暫停*/ function Play(e) { if(e1.paused){ e1.play(); document.getElementById("btn1").innerHTML="暫停" }else{ e1.pause(); document.getElementById("btn1").innerHTML="播放" } } /*慢進(jìn):小于等于1時(shí),每次都只減慢0.2的速率;大于1時(shí),每次減1 */ function Slow(){ if(e1.playbackRate<=1){ e1.playbackRate-=0.2; }else{ e1.playbackRate-=1; } document.getElementById("rate").innerHTML=fps2fps(e1.playbackRate); } /*慢進(jìn):小于等于1時(shí),每次都只減慢0.2的速率;大于1時(shí),每次減1 */ function Fast(){ if(e1.playbackRate<1){ e1.playbackRate+=0.2; }else{ e1.playbackRate+=1; } document.getElementById("rate").innerHTML=fps2fps(e1.playbackRate); } function fps2fps(fps){ if(fps<1){ return fps.toFixed(1); }else{ return fps; } } /*靜音*/ function Muted(e){ if(e1.muted){ e1.muted=false; e.innerHRML="X"; document.getElementById("volume").value=e1.volume; }else{ e1.muted=true; e.innerHRML="x"; document.getElementById("volume").value=0; } } /*調(diào)整音量*/ function Volume(e){ if(e1.muted==true){ e1.muted=false; } e1.volume=e.value; } /* 進(jìn)度信息:控制進(jìn)度條,并顯示進(jìn)度時(shí)間*/ function Progress(){ var p1=document.getElementById("progress"); p1.style.width=(e1.currentTime/e1.duration)*720+"px"; document.getElementById("info").innerHTML=s2time(e1.currentTime)+"/"+s2time(e1.duration); } function s2time(s){ var m=parseFloat(s/60).toFixed(0); s=parseFloat(s%60).toFixed(0); return (m<10? "0"+m:m)+":"+(s<10?"0"+s:s); } /* 網(wǎng)頁(yè)加載完畢后,把進(jìn)度處理函數(shù)添加至視頻對(duì)象的timeupdate事件中*/ window.addEventListener("load",function(){ e1.addEventListener("timeupdate",Progress); }); /*給window.onload事件添加進(jìn)度處理函數(shù)*/ window.addEventListener("load",Progress);
實(shí)現(xiàn)的功能:播放,暫停,快進(jìn),慢進(jìn),前進(jìn),后退,音量控制,進(jìn)度條和時(shí)間顯示。由此可見(jiàn)通過(guò)Audio或Video的屬性和方法可以實(shí)現(xiàn)更復(fù)雜的功能。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
- HTML5 Audio標(biāo)簽?zāi)軌蛑С謜av, mp3, ogg, acc, webm等格式,但有個(gè)很重要的音樂(lè)文件格式midi(擴(kuò)展名mid)卻在各大瀏覽器中都沒(méi)有內(nèi)置的支持。這篇文章給大家介紹html5中audio2018-08-24
詳解移動(dòng)端HTML5音頻與視頻問(wèn)題及解決方案
這篇文章主要介紹了詳解移動(dòng)端HTML5音頻與視頻問(wèn)題及解決方案的相關(guān)資料,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-22- 這篇文章主要給大家總結(jié)介紹了關(guān)于HTML5中視頻音頻的使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-07-07
- 本期的教程主要是為了展示Html5新增的2014-12-30
- 這篇文章主要介紹了HTML5自定義mp3播放器源碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-06