歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

HTML5 Video DOM 入門體驗

HTML5的一個新特性就是內置對多媒體的支持,<video> 元素很好用,也支持了不錯的API接口,下面用了一個案例來說明怎麼對<video> 元素的控制。

  1. <!DOCTYPE >  
  2. <html>  
  3. <head>  
  4.     <title></title>  
  5.   
  6.     <script src="js/jquery-1.7.1.min.js" type="text/javascript"></script>  
  7.   
  8.     <script type="text/javascript">  
  9.         $(  
  10.         function() {  
  11.             $(":button").click(  
  12.             function() {  
  13.                 var h;  
  14.                 switch ($(":button").index($(this))) {  
  15.                     case 0:  
  16.                         if ($("video")[0].paused) {  
  17.                             $("video")[0].play();  
  18.                             $(this).val("暫停");  
  19.                         }  
  20.                         else {  
  21.                             $("video")[0].pause();  
  22.                             $(this).val("播放");  
  23.                         }  
  24.                         break;  
  25.                     case 1:  
  26.                         h = document.getElementsByTagName("video")[0].height == 0 ?  
  27.                             document.getElementsByTagName("video")[0].videoHeight - 10 :  
  28.                             document.getElementsByTagName("video")[0].height - 10; ;  
  29.                         document.getElementsByTagName("video")[0].height = h;  
  30.                         document.getElementsByTagName("video")[0].videoHeight = h;  
  31.                         break;  
  32.                     case 2:  
  33.                         h = document.getElementsByTagName("video")[0].height == 0 ?  
  34.                             document.getElementsByTagName("video")[0].videoHeight + 10 :  
  35.                             document.getElementsByTagName("video")[0].height + 10; ;  
  36.                         document.getElementsByTagName("video")[0].height = h;  
  37.                         document.getElementsByTagName("video")[0].videoHeight = h;  
  38.                         break;  
  39.                 }  
  40.             }  
  41.             );  
  42.         }  
  43.         );  
  44.   
  45.   
  46.         $(  
  47.         function() {  
  48.             $("#video1").on(  
  49.             "canplay",  
  50.             function(e) {  
  51.                 $(":button").removeAttr("disabled");  
  52.                 console.log(e);  
  53.             }  
  54.             );  
  55.             $("#video1").on(  
  56.             "canplaythrough",  
  57.             function(e) {  
  58.                 $("ol>li:eq(0)").html("全部加載完畢,你可以斷網看電影了!");  
  59.                 console.log(e);  
  60.             }  
  61.             );  
  62.             $("#video1").bind(  
  63.             "playing waiting ended play pause",  
  64.             function(e) {  
  65.                 var vObj = document.getElementById("video1");  
  66.                 $("ol>li:eq(1)").html(vObj.duration + ":" + vObj.startTime + ":" + vObj.currentTime);  
  67.                 console.log(e);  
  68.             }  
  69.             );  
  70.             $("#video1").on(  
  71.             "stalled",  
  72.             function(e) {  
  73.                 $("ol>li:eq(2)").html("你的網絡不給力啊,正在等數據呢");  
  74.                 console.log(e);  
  75.             }  
  76.             );  
  77.             $("#video1").on(  
  78.             "error",  
  79.             function(e) {  
  80.                 switch (e.target.error.code) {  
  81.                     case e.target.error.MEDIA_ERR_ABORTED:  
  82.                         $("ol>li:eq(3)").html("媒體資源獲取異常");  
  83.                         break;  
  84.                     case e.target.error.MEDIA_ERR_NETWORK:  
  85.                         $("ol>li:eq(3)").html("網絡錯誤");  
  86.                         break;  
  87.                     case e.target.error.MEDIA_ERR_DECODE:  
  88.                         $("ol>li:eq(3)").html("媒體解碼錯誤");  
  89.                         break;  
  90.                     case e.target.error.MEDIA_ERR_SRC_NOT_SUPPORTED:  
  91.                         $("ol>li:eq(3)").html("視頻格式被不支持");  
  92.                         break;  
  93.                     default:  
  94.                         $("ol>li:eq(3)").html("這個是神馬錯誤啊");  
  95.                         break;  
  96.                 }  
  97.                 console.log(e);  
  98.             }  
  99.             );  
  100.             $("#video1").on(  
  101.             "suspend abort progress",  
  102.             function(e) {  
  103.                 var vObj = document.getElementById("video1");  
  104.                 $("ol>li:eq(1)").html(vObj.duration + ":" + vObj.startTime + ":" + vObj.currentTime);  
  105.                 console.log(e);  
  106.             }  
  107.             );  
  108.             $("#video1").on(  
  109.             "progress error abort",  
  110.             function(e) {  
  111.                 switch (e.target.readyState) {  
  112.                     case 0:  
  113.                         $("ol>li:eq(3)").html("當前播放位置無有效媒介資源");  
  114.                         break;  
  115.                     case 1:  
  116.                         $("ol>li:eq(3)").html("加載中,媒介資源確認存在,但當前位置沒有能夠加載到有效媒介數據進行播放");  
  117.                         break;  
  118.                     case 2:  
  119.                         $("ol>li:eq(3)").html("已獲取到當前播放數據,但沒有足夠的數據進行播放");  
  120.                         break;  
  121.                     case 3:  
  122.                         $("ol>li:eq(3)").html("已獲取到後續播放數據,可以進行播放");  
  123.                         break;  
  124.                     default:  
  125.                     case 4:  
  126.                         $("ol>li:eq(3)").html("可以進行播放,且浏覽器確認媒體數據以某一種速度進行加載,可以保證有足夠的後續數據進行播放,而不會使浏覽器的播放進度趕上加載數據的末端");  
  127.                         break;  
  128.                 }  
  129.                 console.log(e);  
  130.             }  
  131.             );  
  132.         }  
  133.         );  
  134.          
  135.       
  136.     </script>  
  137.   
  138. </head>  
  139. <body>  
  140.     <video id="video1" autobuffer>  
  141.     <source src="video-test.mp4" type="video/mp4" />  
  142.     對不起你的浏覽器不支持HTML5的新特性,要不你下載一個  
  143.     <a href="http://info.msn.com.cn/ie9/">IE9</a>?   
  144.   </video>  
  145.     <input type="button" value="播放" disabled />  
  146.     <input type="button" value="縮小" disabled />  
  147.     <input type="button" value="放大" disabled />  
  148.     <ol>  
  149.         <li></li>  
  150.         <li></li>  
  151.         <li></li>  
  152.         <li></li>  
  153.         <li></li>  
  154.     </ol>  
  155. </body>  
  156. </html>  
對 Video的控制重要的方法就是play、paused、stop。重要的事件有:

canplay 通知用戶可以播放了,但不一定資源全部下載好

canplaythrough 資源都下載完畢了

error 出錯時候

事件參數中有一個target對象,他有一個readyState值,可以得到不同的狀態信息。具體的值,可以通過開發者工具獲得,或看相關文檔。

Copyright © Linux教程網 All Rights Reserved