最近做的些web页面,内嵌许多小视频,在ios和安卓手机上播放时,遇到不少问题:
- 在微信浏览器内播放时,视频会自动全屏
- 如果每个视频都有一张自定义的图片作为封面,在显示视频的同时,如果没有给这个视频设置高度,视频的容器在安卓手机上会被视频的封面撑大到变形
解决办法:
给video标签加一些属性,调用h5原生video,我写了个例子,加了注释,如果有错误,烦指正,谢谢!
如果你的video标签也加了上面的属性,那么,你的视频可以在IOS手机上的小窗口播放,同时,视频封面同视频的宽度与高度也保持一致了。
经过各种尝试,在iOS下,可以给video添加webkit-playsinline属性,使视频在页面上原本位置播放,但这个属性在安卓上无效。
/****华丽丽的分割线,以下内容摘抄自网络,供参考****/
IOS微信浏览器是Chrome内核,下面大部分属性都支持,安卓微信浏览器是X5内核,一些属性是不支持的,比如可以设置局部播放的属性 playsinline,因此,始终是全屏。
下面的内容用以解释上面的内容:
2017-01-20 17:07:32
preload="auto" :属性规定在页面加载后载入视频。如果设置了 autoplay 属性,则忽略该属性。
一般参数可能的值:
· auto - 当页面加载后载入整个视频
· meta - 当页面加载后只载入元数据
· none - 当页面加载后不载入视频
muted:当设置该属性后,它规定视频的音频输出应该被静音
controls="controls" :属性规定浏览器应该为视频提供播放控件。
autoplay="autoplay": 视频自动播放设置,但是有经验的人都应该知道,autoplay标签在手机上不兼容,APP中设置问题导致无法自动播放,无论安卓或IOS。需要模拟自动播放只能通过一些事件触发。
webkit-playsinline playsinline:视频播放时局域播放,不脱离文档流 。但是这个属性比较特别, 需要嵌入网页的APP比如WeChat中UIwebview 的allowsInlineMediaPlayback = YES webview.allowsInlineMediaPlayback = YES,才能生效。换句话说,如果APP不设置,你页面中加了这标签也无效,这也就是为什么安卓手机WeChat 播放视频总是全屏,因为APP不支持playsinline,而ISO的WeChat却支持。
这里就要补充下,如果是想做全屏直播或者全屏H5体验的用户,ISO需要设置删除 webkit-playsinline 标签,因为你设置 false 是不支持的 ,安卓则不需要,因为默认全屏。但这时候全屏是有播放控件的,无论你有没有设置control。 做直播的可能用得着播放控件,但是全屏H5是不需要的,那么去除全屏播放时候的控件,需要以下设置:同层播放。
x5-video-player-type:启用同层H5播放器,就是在视频全屏的时候,div可以呈现在视频层上,也是WeChat安卓版特有的属性。同层播放别名也叫做沉浸式播放,播放的时候看似全屏,但是已经除去了control和微信的导航栏,只留下"X"和"<"两键。目前的同层播放器只在Android(包括微信)上生效,暂时不支持iOS。笔者想过为什么同层播放只对安卓开放,因为安卓不能像ISO一样局域播放,默认的全屏会使得一些界面操作被阻拦,如果是全屏H5还好,但是做直播的话,诸如弹幕那样的功能就无法实现了,所以这时候同层播放的概念就解决了这个问题。不过笔者在测试的过程中发现,不同版本的ISO和安卓效果略有不同。
x5-video-orientation:声明播放器支持的方向,可选值landscape 横屏, portraint竖屏。默认值portraint。无论是直播还是全屏H5一般都是竖屏播放,但是这个属性需要x5-video-player-type开启H5模式
x5videoplayerfullscreen:全屏设置。笔者还未能领悟这个标签的用意,在测试过程中发现,ture和false的设置会导致布局上的不一样,如图 Click标签先后的位置。
另外补充下,ISO 微信浏览器是Chrome的内核,相关的属性都支持,也是为什么X5同层播放不支持的原因。安卓微信浏览器是X5内核,一些属性标签比如playsinline就不支持,所以始终全屏。
/****貌似到这里,了解了为什么安卓手机的全屏视频了****/
2017-01-20 17:13:55
还有个问题,在Android的微信里面,就算加上了上面的属性,还会出现上下有黑边,不能全屏的问题。
解决办法:给video加上object-fit: fill;的style属性。
/****关于微信内置浏览器不能小窗口播放视频的问题-知乎答****/
2017-01-20 17:40:38
开发者需要特别注意小窗播放需要前端同时适配iOS10和iOS10以下的低版本
适配建议:需要完全按照以下代码设置video标签才可同时兼容不同的iOS版本
作者:Lying
链接:https://www.zhihu.com/question/36423771/answer/93953992
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
/****还没测试的 video.js 据说,很好用,安卓微信浏览器不会全屏播放****/
2017-01-20 17:44:22
知友:张艳红
2,效果见我私官网: http://gethover.com 。
3, 另外此框架支持IE8浏览器 。
作者:张艳红
链接:https://www.zhihu.com/question/36423771/answer/108443996
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
<link href="http://vjs.zencdn.net/5.8.8/video-js.css" rel="stylesheet"> <script src="http://vjs.zencdn.net/ie8/1.1.2/videojs-ie8.min.js">script> <script src="http://vjs.zencdn.net/5.8.8/video.js">script>
HTML:
<div class="video-play-content"> <div class="videoPlayer video-js" id="videoContainer" style="height: 200px;margin-bottom: 15px;"> <video id="video" width="100%" height="200" preload controls style="object-fit: fill" webkit-playsinline="true" x-webkit-airplay="true" playsinline="true" x5-video-player-type="h5" x5-video-player-fullscreen="true"> video> <div id="videoControls"> <div class="video-box"> <img id="playBtn" src="" /> div> div> div> <div id="audioControls"> <audio id="audio" width="100%" height="50" preload controls> <source src="../video/wssf.mp3" type="audio/mp3">source> audio> <div id="audioControls"> <div class="audio-box"> <img id="audioPlayBtn" src="../img/doctor/play-audio.png" style="-webkit-appearance:none;" /> <div class="audio-detail"> <div class="audio-title">骨髓灰质炎疫苗选择div> <div class="audio-size"><span class="audio-time">24:26span><span class="audio-size">11.44span>MBdiv> div> div> div> div> div>
CSS:
body{ color: #555; font-family:Helvetica; margin: 15px; /*去掉默认外观*/ -webkit-appearance:none; /*长按不触发系统菜单*/ -webkit-touch-callout: none; /*禁止选中文字*/ -webkit-user-select:none; } @font-face { font-family: 'MicrosoftYaHei'; src: url('MicrosoftYaHei.eot'); /* IE9 Compat Modes */ src: url('MicrosoftYaHei.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('MicrosoftYaHei.woff') format('woff'), /* Modern Browsers */ url('MicrosoftYaHei.ttf') format('truetype'), /* Safari, Android, iOS */ url('MicrosoftYaHei.svg#MicrosoftYaHei') format('svg'); /* Legacy iOS */ } html{ font-size:13px; height: 100%; -webkit-tap-highlight-color: transparent; } @media screen and (min-width:321px) and (max-width:375px){ html{font-size:11px} .logo-box{ position: absolute; top: -56px; left: 50%; transform: translateX(-50%); } } @media screen and (min-width:376px) and (max-width:414px){ html{font-size:12px} .logo-box{ position: absolute; top: -56px; left: 50%; transform: translateX(-50%); } } @media screen and (min-width:415px) and (max-width:639px){html{font-size:15px}} @media screen and (min-width:640px) and (max-width:719px){html{font-size:20px}} @media screen and (min-width:720px) and (max-width:749px){html{font-size:22.5px}} @media screen and (min-width:750px) and (max-width:799px){html{font-size:23.5px}} @media screen and (min-width:800px){html{font-size:25px}} .main{ margin-bottom: 40px; } .video-js { display: block; vertical-align: top; box-sizing: border-box; color: #fff; background-color: #000; position: relative; padding: 0; font-size: 12px; line-height: 1; font-weight: normal; font-style: normal; font-family: Arial, Helvetica, sans-serif; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; height: 200px; } .videoPlayer{ width: 100%; position: relative; margin-bottom: 15px; /*background: #555;*/ } #video{ android:layout_margin="0dp"; android:padding="0dp"; } #audioControls,.video-explain-3{ margin-bottom: 15px; } #playBtn{ width: 5.5em; position: absolute; top: 72px; left: 50%; transform: translateX(-50%); z-index: 9; cursor: pointer; } .audio-box{ width: 100%; margin: auto; height: 80px; background: #e2e2e2; position: relative; display: flex; justify-content: space-around; align-items: center; } #audioPlayBtn { width: 5em; position: absolute; top: 10.5%; left: 6%; z-index: 9; cursor: pointer; } .vaccine{ width: 100%; margin: 15px 0; } .video-info{ margin-bottom: 20px; color: #999; } .audio-time{ margin-right: 10px; }
修改一下判断浏览系统的方法:
function isIOSOrAndroid() { var browser = { versions: function() { var u = navigator.userAgent, app = navigator.appVersion; return { //移动终端浏览器版本信息 trident: u.indexOf('Trident') > -1, //IE内核 presto: u.indexOf('Presto') > -1, //opera内核 webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核 gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核 mobile: !!u.match(/AppleWebKit.*Mobile.*/) || !!u.match(/AppleWebKit/), //是否为移动终端 ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端 android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或者uc浏览器 iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1, //是否为iPhone或者QQHD浏览器 iPad: u.indexOf('iPad') > -1, //是否iPad webApp: u.indexOf('Safari') == -1 //是否web应该程序,没有头部与底部 }; }(), language: (navigator.browserLanguage || navigator.language).toLowerCase() } if(browser.versions.ios || browser.versions.iPhone || browser.versions.iPad) { $('.videoPlayer').css('margin-bottom', '15px'); iOSPlay(); } else if(browser.versions.android) { androidPlay(); } }
移动端HTML5
html5 audio音频播放全解析 : http://www.open-open.com/lib/view/open1407401112973.html