菜单

视频播放–踩坑小计

2019年1月24日 - 金沙前端

Chrome 模拟器

加载成功:

澳门金沙国际 1

点击播放:

澳门金沙国际 2

浅谈html5 video 移动端填坑记,浅谈html5

正文介绍了html5 video 移动端填坑记,分享给大家,具体如下:

<video id="video" 
  style="object-fit:fill" 
  autoplay
  webkit-playsinline 
  playsinline 
  x5-video-player-type="h5"
  x5-video-player-fullscreen="true"
  x5-video-orientation="portraint" 
  src="video.mp4" />
</video>
<!--
  object-fit: fill   视频内容充满整个video容器
  poster:"img.jpg" 视频封面
  autoplay: 自动播放
     auto - 当页面加载后载入整个视频
     meta - 当页面加载后只载入元数据
     none - 当页面加载后不载入视频

  muted:当设置该属性后,它规定视频的音频输出应该被静音

  webkit-playsinline playsinline:   内联播放

  x5-video-player-type="h5" :  启用x5内核H5播放器
  x5-video-player-fullscreen="true"  全屏设置。ture和false的设置会导致布局上的不一样
  x5-video-orientation="portraint" :声明播放器支持的方向,可选值landscape 横屏,portraint竖屏。
                                     默认值portraint。无论是直播还是全屏H5一般都是竖屏播放,
                                     但是这个属性需要x5-video-player-type开启H5模式
-->

自动播放

设置autoplay属性

<video autoplay></video>

挪动浏览器中

唯独在重重活动浏览器里,都是需要用户的真正操作来(touchend、click、doubleclick
或 keydown 事件等专业的风浪)触发调用video.play(),才能自动播放影音视频。

 dom.addEventListener('click', function () {
   video.play()
})

微信中

也得以在  wx.ready()里触发video.play()

wx.ready(function () {
  video.play()
})

内联播放

设置属性 webkit-playsinline playsinline

<video id="video" webkit-playsinline playsinline /></video>

在iOS
Safari和一部分安卓的部分浏览器下播放视频的时候,不可能在h5页面中播放录像,系统会自行接管视频

如若急需在h5页面内广播视频,须要在视频标签上添加 
webkit-playsinline,在iOS10自此,要求添加playsinline,提议还要添加那多少个特性。同时还要求app支持这种情势

webview.allowsInlineMediaPlayback = YES;

ios手Q和微信都帮衬那种情势,可是android 微信就挂了

android 微信

android微信内置浏览器选拔腾讯X5内核,不遵守X5web标准,video强制全屏就是以此。录像播放已毕后还会油不过生QQ自己的录像推荐

据称,其有个白名单,白名单下的录像资源,就不会全屏。不过腾讯曾经无法再追加白名单了。尿性,无解。。。。。。

当下还有一个解决办法,就是使用h5  canvas 播放 video

canvas 播放视频

动用canvas 遭逢的坑:video 必须加 x5-video-player-type=”h5″
属性,否则,在活动端就会卡死不能够播放录像,个人觉得是因为视频被接管的案由促成。

<div class="wrapper">
  <video id="video" style="display: none" autoplay src="video.mp4" x5-video-player-type="h5"></video>
  <canvas id="canvas"></canvas>
</div>
<script>
  var video = document.querySelector('#video')
  var canvas = document.querySelector('#canvas')
  var wrapper = canvas.parentNode
  var width = wrapper.offsetWidth
  var height = wrapper.offsetHeight
  var ctx = c.getContext('2d')
  var time = null
  canvas.width = width
  canvas.height = height

  canvas.addEventListener('click', function () {
    video.play()
  })

  video.addEventListener('play', function () {
      time = window.setInterval(function () {
        ctx.drawImage(v, 0, 0, width, height);
      }, 20);
  }, false);

  video.addEventListener('pause', function () {
      window.clearInterval(time);
  }, false);

  video.addEventListener('ended', function () {
      window.clearInterval(time);
  }, false);
</script>

终极发现,就算采纳canvas播放视频,android微信中得以屏蔽全屏录像播放完的推荐视频。不过还不可能明令禁止录像播放时
的全屏问题。依旧得万恶的白名单。吐槽。。。。。。。。。。。。。。。。
更坑爹的是尚未找到js触发退出全屏的方法。

ios黑屏问题

ios 在播音视频时,会并发短暂的黑屏,然后正常呈现。

解决方法:

在视频上层覆盖一个
添加一个div并用一张图片填充,创造播放前加载假象。然后监听事件 timeupdate
,视频播放有画面时移除那个“div块”

video.addEventListener('timeupdate', function(){
  if(video.currentTime > 0.1){
      posterImg.hidden();
  }
})

Media 方法和性能

HTMLVideoElement和HTML奥迪(Audi)oElement 均连续自HTMLMediaElement

// 媒体错误
MediaObj.error; //null:正常
MediaObj.error.code; //1.用户终止 2.网络错误 3.解码错误 4.URL无效

//媒体当前状态
MediaObj.currentSrc; //返回当前资源的URL
MediaObj.src = value; //返回或设置当前资源的URL
MediaObj.canPlayType(type); //是否能播放某种格式的资源
MediaObj.networkState; //0.此元素未初始化 1.正常但没有使用网络 2.正在下载数据 3.没有找到资源
MediaObj.load(); //重新加载src指定的资源
MediaObj.buffered; //返回已缓冲区域,TimeRanges
MediaObj.preload; //none:不预载 metadata:预载资源信息 auto:

//准备状态
MediaObj.readyState;//1:HAVE_NOTHING 
                    //2:HAVE_METADATA 
                   //3.HAVE_CURRENT_DATA 
                  //4.HAVE_FUTURE_DATA 
                 //5.HAVE_ENOUGH_DATA
MediaObj.seeking; //是否正在seeking

//回放状态
MediaObj.currentTime = value; //当前播放的位置,赋值可改变位置
MediaObj.startTime; //一般为0,如果为流媒体或者不从0开始的资源,则不为0
MediaObj.duration; //当前资源长度 流返回无限
MediaObj.paused; //是否暂停
MediaObj.defaultPlaybackRate = value;//默认的回放速度,可以设置
MediaObj.playbackRate = value;//当前播放速度,设置后马上改变
MediaObj.played; //返回已经播放的区域,TimeRanges,关于此对象见下文
MediaObj.seekable; //返回可以seek的区域 TimeRanges
MediaObj.ended; //是否结束
MediaObj.autoPlay; //是否自动播放
MediaObj.loop; //是否循环播放
MediaObj.play(); //播放
MediaObj.pause(); //暂停

//视频控制
MediaObj.controls;//是否有默认控制条
MediaObj.volume = value; //音量
MediaObj.muted = value; //静音

//TimeRanges(区域)对象
TimeRanges.length; //区域段数
TimeRanges.start(index) //第index段区域的开始位置
TimeRanges.end(index) //第index段区域的结束位置

//【★★★**相关事件**★★★】
//事件分发
var eventTester = function(e){
    Media.addEventListener(e,function(){
        console.log((new Date()).getTime(),e)
    },false);
}
//事件监听
eventTester("loadstart"); //客户端开始请求数据
eventTester("progress"); //客户端正在请求数据
eventTester("suspend"); //延迟下载
eventTester("abort"); //客户端主动终止下载(不是因为错误引起)
eventTester("loadstart"); //客户端开始请求数据
eventTester("progress"); //客户端正在请求数据
eventTester("suspend"); //延迟下载
eventTester("abort"); //客户端主动终止下载(不是因为错误引起),
eventTester("error"); //请求数据时遇到错误
eventTester("stalled"); //网速失速
eventTester("play"); //play()和autoplay开始播放时触发
eventTester("pause"); //pause()触发
eventTester("loadedmetadata"); //成功获取资源长度
eventTester("loadeddata"); //
eventTester("waiting"); //等待数据,并非错误
eventTester("playing"); //开始回放
eventTester("canplay"); //可以播放,但中途可能因为加载而暂停
eventTester("canplaythrough"); //可以播放,歌曲全部加载完毕
eventTester("seeking"); //寻找中
eventTester("seeked"); //寻找完毕
eventTester("timeupdate"); //播放时间改变
eventTester("ended"); //播放结束
eventTester("ratechange"); //播放速率改变
eventTester("durationchange"); //资源长度改变
eventTester("volumechange"); //音量改变

如上就是本文的全体内容,希望对大家的就学抱有帮忙,也希望我们多多匡助帮客之家。

video 移动端填坑记,浅谈html5
本文介绍了html5 video 移动端填坑记,分享给大家,具体如下: video
id=video style=object-fit:fill autoplay w…

总结:

在经验过各样优化和调动后,大家可以在h5直播页做到看直播,看弹幕,发弹幕,发送礼物,表情,查看排行等种种作用,再同盟上手Q里的隐藏titlebar的_wv=16777217,可以完成全屏播放效果,做到了媲美原生播放的体验。

当今的h5的播放还有很多的突显和包容性的题目,希望那份指南可以帮您在遇见同样的坑时能尽早爬出来,并优化你的h5播放体验,吸引到更加多的用户
: D


越多出色内容欢迎关心腾讯 Bugly的微信公众账号:

澳门金沙国际 3

腾讯
Bugly是一款专为移动开发者打造的质料监控工具,辅助开发者快速,便捷的定位线上运用崩溃的事态以及缓解方案。智能合并功用协助开发同学把每日上报的数千条
Crash
依照根因合并分类,每天晚报会列出影响用户数最多的垮台,精准定位作用辅助开发同学定位到出题目的代码行,实时举报可以在发布后火速的询问应用的成色景况,适配最新的
iOS, Android 官方操作系统,鹅厂的工程师都在应用,快来插足大家呢!

android下html5的视频播放一贯是前者兼容的重灾区,种种体验差,被夸夸其谈已久。但从前的紫禁城穿越H5,和吴亦凡(英文名:)入伍H5,利用的视频技术,貌似又给人一种新面貌。

现象三:播放控制

video
元素有提供多少个表现事件供开发者控制视频播放,包容性相比较好的有 onended 、
__ontimeupdate、onplay、onplaying ,__稍许事件在不相同浏览器不一致装备上的的显示意况并不一样,

例如:ios
下监听’canplay‘(是不是已缓冲了足足的多少足以流畅播放),当加载时是不会接触的,尽管__preload=”auto”
__也没用,但在 pc 的 Chrome 调试器下,是会在加载阶段就接触。ios
需求播放后才会触发。

2)系统接管播放

俺们上面说道调用h5的webkitRequestFullScreen方法来进入录像的全屏,那么那一个主意会使浏览器完全接管视频播放,如图所示

澳门金沙国际 4

那种接管的结果是此时的大家是不曾章程控制视频的播报,也远非艺术在地点浮动大家的dom元素,如弹幕,礼物那些,会全盘被视频盖在底下,所以大家的靶子即是解决那种系统接管的问题

前段时间做某项目,恰好也是一个类似视频全屏的,上面跟我们享用下经历的坑和填坑的措施。

检测是还是不是自动播放?

好在无论是 Safari 如故Chrome,在限制了自动播放的还要,提供了检测视频是还是不是能自动播放的建制,以便于开发者在发现不能自动播放时有备选方案:

var promise = document.querySelector(‘video’).play(); if (promise 澳门金沙国际,!==
undefined) { promise.catch(error => { // Auto-play was prevented //
Show a UI element to let the user manually start playback }).then(()
=> { // Auto-play started }); }

1
2
3
4
5
6
7
8
9
10
var promise = document.querySelector(‘video’).play();
 
if (promise !== undefined) {
    promise.catch(error => {
        // Auto-play was prevented
        // Show a UI element to let the user manually start playback
    }).then(() => {
        // Auto-play started
    });
}

小编简介:
文赫,二〇一五年投入腾讯,作为前端开发工程师参加承办Q游戏公会,游戏中央,企鹅电竞等连串,具有丰裕的移动端支出和直播开发经历。

ios端问题实际上没什么,基本都在android端,基本每一个涵盖视频的连串都会遭逢的,当然有尤其须求的发生的事态另说了就,问题主要性有多少个地方:

视频播放–踩坑小计

2018/06/09 · JavaScript
· 视频

原文出处:
chenjsh36   

 

趁着流量时代的来到和硬件技术的升级换代,越来越多的网站希望能在PC端或活动端播放自己的视频,而
<video>的包容性的逐步完善,使得开发者更愿意利用它来促成视频播放场景。

本篇小说紧要罗列__视频播放的通用场景及各场景下踩过的坑__,希望能__支持开发者在蒙受须要开发时能更快地选拔合适的技巧方案同时裁减采坑的次数__。

3)使用伪全屏(样式全屏)

体制全屏的主导是设置video标签的宽高,使其撑满整个webview,看上去像全屏一样

可是因为录像一般都是16:9的宽高比,所以在竖屏景色下不可以很好的做到铺满整整屏幕

澳门金沙国际 5

而貌似用户进入页面基本都是竖屏,所以大家将要考虑怎么让用户在竖屏点击全屏按钮时,能体会到像终端app一样自动进入横屏全屏的体会,上面有三种方案

1.在用户点击全屏时候,通过css3属性旋转显示器

经过css的transform,大家得以把dom元素旋转显示

经过-webkit-transform:
rotate(90deg)并设置video的高度为当前webview的幅度,video的肥瘦为当下webview的莫大来促成旋转全屏.

那种形式的显示没有太大题材,但因为是通过css控制的页面dom突显,对于原生的半空中不能够很好的支配,如系统的键盘

澳门金沙国际 6

在拉起键盘输入弹幕的时候,键盘不受控制如故竖屏呈现了
一经页面不涉及与原生组件的竞相,那么这种方案是一种很实用且包容性相比好的方案

2.用户在点击全屏时,通过js api来支配webview旋转横屏

在手Q里,大家和终点的同校同盟添加了决定webview横竖屏的接口
在用户点击全屏的时候,先判断当前是或不是横屏

    /**
     * 是否横屏
     */
    function isHorizontal() {       
        if (window.orientation != undefined) {        
            return (window.orientation == 90 || window.orientation == -90);
        } else {         
            return window.innerWidth > window.innerHeight;
        }
    }

//设置webview为横竖屏
 mqq.ui.setWebViewBehavior({         
      orientation: 0 //0是竖屏,1是横屏
 });

假诺是竖屏则强制webview旋转进入横屏,同时监听页面的resize方法,页面横竖屏变化的时候会触发那个格局,在那些方法里再动态的调动video的宽高来铺满整个显示器

澳门金沙国际 7

注:

后面我们发现x5插入了一段js来威逼视频的全屏的轩然大波

澳门金沙国际 8

满意条件的video标签全屏时都会被X5接管,别的调用webkitEnterFullscreen方法时,X5也会接管播放器。

假定发现在x5内核下无法使用伪全屏而被浏览器接管,可以问问下x5同事为您的域名开启白名单,不接管你域名下的视频播放

自然想自己计算个,发现有人计算的很全,就copy过来了。前边发现有新的题目再想办法补充进来呢。

何以又允许自动播放?

2. 页面内联播放问题

在iOS
Safari和一部分安卓的一部分浏览器下播放录像的时候,无法在h5页面中播放视频,系统会自行接管视频

假若须求在h5页面内播放视频,须要在录像标签上添加
webkit-playsinline,在iOS10后头,要求添加playsinline,提议还要丰盛那八个属性,同时要求app援助那种形式,手Q和微信都扶助这种方式

    //在html
    <video id="player" webkit-playsinline playsinline >    //在app内设置webview属性
    webview.allowsInlineMediaPlayback = YES;

补充:
ios safari自动播放可以经过关闭声音解决,如添加muted属性。
而移动端chrome浏览器必须经过用户输入才能接触播放。

为何 IOS 下微信和钉钉可以自动播放带响声的视频?

的确发现在微信日常能看到自动播放的H5,不过作者自己写的安装了
autoplay、playsInline
的录像播放样例,在微信上依然不可以自动播放,而在钉钉上却足以自动播放

系统-浏览器 带声音 不带声音
IOS 钉钉 支持 支持
IOS Safari 禁止 自动播放
IOS 微信 禁止 禁止

因而查询资料,IOS WebAPP 开发都是依据 IOS
提供的浏览器内核进行支付的
,所以在 WebAPP 的 webview
中可以修改自动播放的表现,钉钉显明是永葆自动播放,微信则是明令禁止自动播放,不过提供了安置事件来协助自动播放:

微信下通过 WeixinJSBridgeReady 事件展开自动播放:

document.addEventListener( ‘WeixinJSBridgeReady’, function() {
video.play(); }, false );

1
2
3
4
5
6
7
document.addEventListener(
  ‘WeixinJSBridgeReady’,
  function() {
    video.play();
  },
  false
);

6. 视频的基础代谢

咱俩精通video暴光了play和pause方法来提供录像的广播和间断,可是h5没有标准的刷新方法,假使我们想完结视频的基础代谢,则必要经过js完毕

var player = $('#player')[0];
player.load();
setTimeout(function () {
     player.play();
})

填补–自动播放

android始终无法自动播放,不多说。值得一提的是经测现在ios10后版本的safari和微信都不让视频自动播放了(顺带音频也无法自动播放了),但微信提供了一个事件WeixinJSBridgeReady,在微信嵌入webview全局的这些事件触发后,视频还能自动播放,这些理应是当今在ios端微信的录像自动播放的可比可靠的法门,其余如手q或者其余浏览器,指出就辅导用户出发触屏的作为操作出发相比好。

//也可以在这个事件触发后播放一次然后暂停(这样以后视频会处于加载状态,为后面的流畅播放做准备)
document.addEventListener("WeixinJSBridgeReady", function (){ 
    video.play();
    video.pause();
}, false)

思考

3. 视频的万丈问题

在安卓下,一些浏览器如QQ浏览器和UC浏览器,系统会把视频的层级调到最高,所以一旦想在页面上显示dom元素,都会被录像盖住,单纯的设置该dom的z-index是无济于事的,如图所示

澳门金沙国际 9

化解方案:

  1. 在弹出会突显在视频上方dom的时候抛锚视频播放
  2. 将录像所在的dom的父元素的莫大设为1
  3. 拍卖完弹出的事件后将视频所在的父元素中度还原

  4. 视频的默许播放图标


在iOS下会有一个默认的播放图标,如图所示

澳门金沙国际 10

在iOS都会默许突显,无法经过js控制,可是足以经过css样式将其逃匿

    video::-webkit-media-controls-start-playback-button {
            display: none;
    }
  1. 全屏处理;

  2. 自动播放;

  3. 播音控制;

  4. 暗藏播放控件;

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图