整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          HTML5 Audio(音頻)

          TML5 提供了播放音頻文件的標(biāo)準(zhǔn)。

          互聯(lián)網(wǎng)上的音頻

          直到現(xiàn)在,仍然不存在一項(xiàng)旨在網(wǎng)頁上播放音頻的標(biāo)準(zhǔn)。

          今天,大多數(shù)音頻是通過插件(比如 Flash)來播放的。然而,并非所有瀏覽器都擁有同樣的插件。

          HTML5 規(guī)定了在網(wǎng)頁上嵌入音頻元素的標(biāo)準(zhǔn),即使用 <audio> 元素。

          瀏覽器支持

          Internet Explorer 9+, Firefox, Opera, Chrome, 和 Safari 都支持 <audio> 元素.

          注意: Internet Explorer 8 及更早IE版本不支持 <audio> 元素.

          HTML5 Audio - 如何工作

          如需在 HTML5 中播放音頻,你需要使用以下代碼:

          實(shí)例

          <audiocontrols><sourcesrc="horse.ogg"type="audio/ogg"><sourcesrc="horse.mp3"type="audio/mpeg">您的瀏覽器不支持 audio 元素。</audio>

          control 屬性供添加播放、暫停和音量控件。

          在<audio> 與 </audio> 之間你需要插入瀏覽器不支持的<audio>元素的提示文本 。

          <audio> 元素允許使用多個(gè) <source> 元素. <source> 元素可以鏈接不同的音頻文件,瀏覽器將使用第一個(gè)支持的音頻文件

          音頻格式及瀏覽器支持

          目前, <audio>元素支持三種音頻格式文件: MP3, Wav, 和 Ogg:

          瀏覽器MP3WavOgg
          Internet Explorer 9+YESNONO
          Chrome 6+YESYESYES
          Firefox 3.6+YESYESYES
          Safari 5+YESYESNO
          Opera 10+YESYESYES

          音頻格式的MIME類型

          FormatMIME-type
          MP3audio/mpeg
          Oggaudio/ogg
          Wavaudio/wav

          HTML5 Audio 標(biāo)簽

          標(biāo)簽描述
          <audio>定義了聲音內(nèi)容
          <source>規(guī)定了多媒體資源, 可以是多個(gè),在 <video> 與 <audio>標(biāo)簽中使用

          如您還有不明白的可以在下面與我留言或是與我探討QQ群308855039,我們一起飛!

          音頻是網(wǎng)頁承載內(nèi)容很重要的一個(gè)元素,也是必不可少的網(wǎng)頁表現(xiàn)形式(圖、文、表、視、音)之一。缺少聲音的網(wǎng)站,就如同人不能說話一樣。曾經(jīng)網(wǎng)頁要想播放音頻,必須得用第三方插件flash。隨著html5標(biāo)準(zhǔn)逐漸普及,如今幾乎所有的瀏覽器都使用html5來播放音頻。

          目標(biāo)

          1. 如何設(shè)置音頻播放?
          2. 支持哪幾種音頻格式?

          音頻播放標(biāo)簽--audio

          作用是在 HTML 頁面中嵌入音頻元素,來播放聲音文件或者音頻流。

          網(wǎng)頁版的音樂播放器

          audio標(biāo)簽的屬性

          src 音頻的播放源(必須)

          controls 瀏覽器自帶的控制條(必須)

          autoplay 自動(dòng)播放

          loop 循環(huán)播放

          preload 預(yù)加載

          音頻代碼

          每一種瀏覽器自帶的音頻播放控制器都不一樣,但功能都一樣。網(wǎng)上看到的播放器,大多數(shù)都是改過它的樣式。

          瀏覽器自帶的音頻控制條

          支持多個(gè)格式--source標(biāo)簽

          <audio> 元素支持三種視頻格式: MP4, WebM, 和 Ogg。

          如果不確定音頻格式是哪個(gè)格式,可以使用source標(biāo)簽。<source> 元素可以鏈接不同格式的視頻文件,瀏覽器將使用第一個(gè)可識(shí)別的格式。

          支持多種格式

          總結(jié)

          audio總結(jié)

          篇文章主要介紹了HTML5實(shí)現(xiàn)音頻和視頻嵌入的方法的相關(guān)資料,原生的支持音頻和視頻,為HTML5注入了巨大的發(fā)展?jié)摿Γ【幱X得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

          簡介

          HTML5未出來之前,在線的音頻和視頻都是借助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)起來很麻煩。

          <object height="200" width="200" data="2_1.swf" >

          </object>

          <embed src="2_1.mp4" type="">

          那么也就是說HTML5存在一個(gè)很大的問題就是兼容性。音頻

          HTML5支持的音頻格式:



          視頻

          視頻格式:



          由上可知,HTML5貌似支持的格式有點(diǎn)少哈,所以當(dāng)你發(fā)現(xiàn)用HTML5放置音頻和視頻不顯示時(shí),應(yīng)該就是格式不支持的問題。注: MP4有3種編碼,mpg4(xdiv),,mpg4(xvid),avc(h264), 只有h264才是公認(rèn)的MP4標(biāo)準(zhǔn)編碼(在這也是被坑了,其他格式的只有聲音沒有圖像。)遇到這種問題,就用視頻格式轉(zhuǎn)換器,轉(zhuǎn)換一下格式就OK啦。

          音頻實(shí)現(xiàn)起來很簡單:這里工具條使用了瀏覽器默認(rèn)的工具條。

          ?

          1

          2

          3

          <audio src="htmls/1.mp3" controls="controls" loop="loop" preload="auto" >

          你的瀏覽器不支持video元素

          </audio>



          視頻雖然也可以使用瀏覽器默認(rèn)的,但無法實(shí)現(xiàn)私人訂制,所以從學(xué)技術(shù)的角度講,還是要學(xué)習(xí)一下自己做工具實(shí)現(xiàn)功能(audio也可參照此方法)。

          audioVideo.html

          <!DOCTYPE html>

          <html>

          <head>

          <meta charset="UTF-8">

          <title>網(wǎng)頁放置視頻</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)頁加載完畢后,把進(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í)間顯示。由此可見通過Audio或Video的屬性和方法可以實(shí)現(xiàn)更復(fù)雜的功能。


          主站蜘蛛池模板: 国产高清在线精品一区小说 | 亚洲电影一区二区三区| 成人精品一区二区三区中文字幕 | 无码人妻精品一区二区三区9厂 | 亚洲日韩AV一区二区三区中文| 国产精品视频免费一区二区三区| 农村乱人伦一区二区| 中文字幕一区二区人妻| 波多野结衣中文一区二区免费| 日本一区频道在线视频| 水蜜桃av无码一区二区| 99精品高清视频一区二区| 在线观看日韩一区| 久久久无码精品人妻一区| 精品无码日韩一区二区三区不卡| 中文字幕人妻丝袜乱一区三区| 无码精品蜜桃一区二区三区WW| 人妻精品无码一区二区三区| 精品国产乱子伦一区二区三区 | 国产一区二区视频在线播放| 国产婷婷色一区二区三区深爱网 | 精品国产a∨无码一区二区三区| 亚洲免费一区二区| 国产色精品vr一区区三区| 精品福利一区3d动漫| 成人一区专区在线观看| 久久久国产精品无码一区二区三区| 日韩在线不卡免费视频一区 | 精品女同一区二区| 日本精品一区二区久久久| 精品国产天堂综合一区在线| 人妻夜夜爽天天爽一区| 最新中文字幕一区| 精品一区二区三区在线观看l| 蜜桃臀无码内射一区二区三区| 无码人妻一区二区三区在线视频| 精品一区二区三区无码免费视频| 亚洲av无码一区二区三区乱子伦| 一区二区中文字幕| 日韩精品人妻一区二区三区四区| 免费高清在线影片一区|