·您当前的位置:主页 > 技术教程 > Html5技术 >

[html5]html5视频全屏实现的源代码

时间:2016-02-17 09:34酷播
[html5]html5视频全屏实现的源代码

[html5]html5视频全屏实现的源代码

  1. <!doctype  html> 
  2. <html> 
  3. <head> 
  4. <meta charset="utf-8" /> 
  5. <title>全屏问题</title> 
  6. <meta http-equiv="content-type" content="text/html; charset=utf-8"/> 
  7. <meta http-equiv="imagetoolbar" content="no"/> 
  8. <meta name="apple-mobile-web-app-capable" content="yes"/> 
  9. <meta http-equiv="X-UA-Compatible" content="IE=Edge"> 
  10. <style type="text/css"> 
  11. *{ 
  12.     padding: 0px; 
  13.     margin: 0px; 
  14.   
  15. body div.videobox{ 
  16.     width: 400px; 
  17.     height: 320px; 
  18.     margin: 100px auto; 
  19.     background-color:#000; 
  20.   
  21. body div.videobox video.video 
  22. width: 100%; 
  23.     height: 100%; 
  24.   
  25. :-webkit-full-screen { 
  26.   
  27.   
  28. :-moz-full-screen { 
  29.   
  30.   
  31. :-ms-fullscreen { 
  32.     
  33.   
  34. :-o-fullscreen { 
  35.     
  36.   
  37. :full-screen {  
  38.    
  39.   
  40. :fullscreen { 
  41.    
  42.   
  43. :-webkit-full-screen video { 
  44.   width: 100%; 
  45.   height: 100%; 
  46. :-moz-full-screen video{ 
  47.     width: 100%; 
  48.     height: 100%; 
  49.     </style> 
  50. </head> 
  51. <body> 
  52.    
  53.   
  54. <div id="videobox"> 
  55.        
  56.     <video controls="controls" preload="preload" id="video" poster="poster.jpg"> 
  57.       <source src="./movie.ogg" type="video/ogg" /> 
  58.       <source src="./movie.mp4" type="video/mp4" /> 
  59.       <source src="./movie.webm" type="video/webm" /> 
  60.       <object data="./movie.mp4" width="100%" height="100%"> 
  61.         <embed width="100%" height="100%" src="./movie.swf" /> 
  62.       </object> 
  63.   
  64.     </video> 
  65.     <button id="fullScreenBtn">全屏</button> 
  66. </div> 
  67.    
  68.    
  69. <script type="text/javascript"> 
  70.    
  71. //反射調用 
  72. var invokeFieldOrMethod = function(element, method)  
  73.    var usablePrefixMethod; 
  74.    ["webkit", "moz", "ms", "o", ""].forEach(function(prefix) { 
  75.        if (usablePrefixMethod) return; 
  76.        if (prefix === "") { 
  77.            // 无前缀,方法首字母小写 
  78.            methodmethod = method.slice(0,1).toLowerCase() + method.slice(1);    
  79.        } 
  80.        var typePrefixMethod = typeof element[prefix + method]; 
  81.        if (typePrefixMethod + "" !== "undefined") { 
  82.            if (typePrefixMethod === "function") { 
  83.                usablePrefixMethod = element[prefix + method](); 
  84.            } else { 
  85.                usablePrefixMethod = element[prefix + method]; 
  86.            } 
  87.        } 
  88.    }); 
  89.      
  90.        return usablePrefixMethod; 
  91. }; 
  92.      
  93. //進入全屏 
  94.  function launchFullscreen(element)  
  95.    { 
  96.     //此方法不可以在異步任務中執行,否則火狐無法全屏 
  97.      if(element.requestFullscreen) { 
  98.        element.requestFullscreen(); 
  99.      } else if(element.mozRequestFullScreen) { 
  100.        element.mozRequestFullScreen(); 
  101.      } else if(element.msRequestFullscreen){  
  102.        element.msRequestFullscreen();   
  103.      } else if(element.oRequestFullscreen){ 
  104.         element.oRequestFullscreen(); 
  105.     } 
  106.     else if(element.webkitRequestFullscreen) 
  107.      { 
  108.        element.webkitRequestFullScreen(); 
  109.      }else{ 
  110.        
  111.         var docHtml  = document.documentElement; 
  112.         var docBody  = document.body; 
  113.         var videobox  = document.getElementById('videobox'); 
  114.         var  cssText = 'width:100%;height:100%;overflow:hidden;'
  115.         docHtml.style.cssText = cssText; 
  116.         docBody.style.cssText = cssText; 
  117.         videobox.style.cssText = cssText+';'+'margin:0px;padding:0px;'; 
  118.         document.IsFullScreen = true
  119.   
  120.       } 
  121.    } 
  122. //退出全屏 
  123.    function exitFullscreen() 
  124.    { 
  125.        if (document.exitFullscreen) { 
  126.          document.exitFullscreen(); 
  127.        } else if (document.msExitFullscreen) { 
  128.          document.msExitFullscreen(); 
  129.        } else if (document.mozCancelFullScreen) { 
  130.          document.mozCancelFullScreen(); 
  131.        } else if(document.oRequestFullscreen){ 
  132.             document.oCancelFullScreen(); 
  133.         }else if (document.webkitExitFullscreen){ 
  134.          document.webkitExitFullscreen(); 
  135.        }else{ 
  136.         var docHtml  = document.documentElement; 
  137.         var docBody  = document.body; 
  138.         var videobox  = document.getElementById('videobox'); 
  139.         docHtml.style.cssText = ""
  140.         docBody.style.cssText = ""
  141.         videobox.style.cssText = ""
  142.         document.IsFullScreen = false
  143.     } 
  144.   } 
  145. document.getElementById('fullScreenBtn').addEventListener('click',function(){ 
  146.     launchFullscreen(document.getElementById('video'));  
  147.     window.setTimeout(function exit(){ 
  148. //檢查瀏覽器是否處於全屏 
  149. if(invokeFieldOrMethod(document,'FullScreen') || invokeFieldOrMethod(document,'IsFullScreen') || document.IsFullScreen) 
  150. exitFullscreen(); 
  151.    },5*1000); 
  152. },false); 
  153.   
  154. </script> 
  155. </body> 
  156.    
  157. </html> 

~~~~~~~~~~~~~~~~~~~~2014-11-30 更新,已修复的buglist如下~~~~~~~~~~~~~~~~~~~~~~~~~~~~

  1. bug,之前写的Demo 不能做到很好的兼容 firefox全屏失败

FullScreenDeniedNotInputDriven=全屏请求被拒绝,因为 Element.mozRequestFullScreen()
 不是在一个短期运行的由用户引发的事件处理代码段中运行的。

  2.bug IE浏览器无法全屏,这里只让它放大了

  3.IE浏览器无法判断是否全屏

  4.之前忽略了 欧朋浏览器

热门文章推荐

请稍候...