Web播放器 TcPlayer——腾讯直播sdk的网页播放器

https://www.qcloud.com/document/product/267/7479javascript

功能介绍

腾讯云Web播放器主要解决在手机浏览器和PC浏览器上播放音视频流的问题,使您的视频内容能够不依赖用户安装App就能够在朋友圈、微博等社交平台进行传播。html

本文档适合有必定Javascript语言基础的开发人员阅读。前端

基础知识

对接以前先要了解以下的基础知识,很是有必要:java

  • 直播和点播
    直播是指视频源是实时的,一旦主播停播了,这个地址就已经失去意义了,并且因为是实时直播,因此播放器在播直播视频的时候是没有进度条滴。
    点播是指视频源是一个服务器上的文件,文件只要没有被提供方删除,就随时能够播放, 并且因为整个视频都在服务器上,因此播放器在播点播视频的时候是有进度条的哦。web

  • 协议的支持
    Web播放器的视频播放能力自己不是网页代码实现的,而是靠浏览器的支持,因此其兼容性并不像咱们想象的那么好,您必需要接受一个事实:不是全部的手机浏览器都能有符合预期的表现,有些手机浏览器甚至根本就不支持视频播放。api

    最多见的用于网页直播的视频源地址是以m3u8结尾的地址,咱们称其为HLS (HTTP Live Streaming),这是苹果推出的标准。因为苹果的影响力,目前各手机浏览器产品对这种格式的兼容性最好,但它有个自然的问题,就是延迟比较大,通常是20-30秒左右的延迟,没有办法,在手机浏览器上咱们并无其它选择。跨域

    在PC上状况会好不少,由于PC上的浏览器目前尚未抛弃flash控件,而flash控件不追求洁癖,支持的视频源格式挺多的,并且各浏览器上的flash控件都是Adobe它家本身开发,因此兼容性很是好。(悄悄滴告诉你,Chrome最近对flash的态度不太友好)
    浏览器

对接攻略

Step 1:页面准备工做

在须要播放视频的页面(包括PC或H5)中引入初始化脚本安全

<script src="//imgcache.qq.com/open/qcloud/video/vcplayer/TcPlayer-2.2.0.js" charset="utf-8"></script>; 

注意:直接用本地网页是调试不了的,由于腾讯云Web播放器处理不了这种状况下的跨域问题。服务器

Step 2:HTML里放置容器

在须要展现播放器的页面位置加入播放器“容器”,也就是放一个div,而后给它取个名字,好比: id_test_video 。以后视频的画面都会在这个容器里渲染,容器的大小控制您可使用div的属性进行控制,示例代码以下:

<div id="id_test_video" style="width:100%; height:auto;"></div> 

Step 3:对接视频的播放

接下来就要写 javascript 代码了,这些代码的做用是去指定的 URL 地址拉取音视频流,并将视频画面呈现到Step2中添加的容器里。

3.1 一次简单的播放

以下是一条典型的直播URL地址,它是HLS(m3u8)协议的,若是主播还在直播中的话,那么用 VLC 等播放器是能够直接打开该 URL 进行观看的:

http://2157.liveplay.myqcloud.com/2157_358535a.m3u8 // m3u8播放地址 

咱们如今要在手机浏览器上播放这个 URL 的视频,javascript代码能够这样写:

var player = new TcPlayer('id_test_video', { "m3u8": "http://2157.liveplay.myqcloud.com/2157_358535a.m3u8", //请替换成实际可用的播放地址 "autoplay" : true, //iOS下safari浏览器,以及大部分移动端浏览器是不开放视频自动播放这个能力的 "coverpic" : "http://www.test.com/myimage.jpg", "width" : '480',//视频的显示宽度,请尽可能使用视频分辨率宽度 "height" : '320'//视频的显示高度,请尽可能使用视频分辨率高度 }); 

这段代码就能够支持在PC以及手机浏览器上播放HLS(m3u8)协议的直播视频了,不过,前面咱们有说过,HLS(m3u8)协议的视频虽然兼容性还不错(部分Android手机依然不支持),但其延迟很是高,大约20秒以上的延迟。

3.2 PC上实现更低的延迟

那么对于PC浏览器而言,咱们是否能够作的更好呢?固然能够,由于PC浏览器支持flash,它可强大多了,如今咱们的代码要这样写:

var player = new TcPlayer('id_test_video', { "m3u8": "http://2157.liveplay.myqcloud.com/2157_358535a.m3u8", "flv": "http://2157.liveplay.myqcloud.com/live/2157_358535a.flv", //增长了一个flv的播放地址,用于PC平台的播放 请替换成实际可用的播放地址 "autoplay" : true, //iOS下safari浏览器,以及大部分移动端浏览器是不开放视频自动播放这个能力的 "coverpic" : "http://www.test.com/myimage.jpg", "width" : '480',//视频的显示宽度,请尽可能使用视频分辨率宽度 "height" : '320'//视频的显示高度,请尽可能使用视频分辨率高度 }); 

跟前一段代码的区别就在于,咱们增长了一个flv的播放地址,腾讯云Web播放器若是发现目前的浏览器是PC浏览器,会主动选择flv链路,由于能够实现更低的延迟。

固然,前提条件是FLV和HLS(m3u8)这两个地址都是能够出流的,若是您使用腾讯云的视频直播服务,这个问题是不须要犯愁的,由于腾讯云的每一条直播频道都默认支持FLV、RTMP和HLS(m3u8)三种播放协议。

3.3 播放不了怎么办?

若是您发现视频不能播放,基本上逃不出以下几个缘由:

  • (缘由一) 视频源有问题
    若是是直播URL,那必定要检查一下是否是主播已经中止推流了,状态不处于“直播中”的状况,能够用浮窗提示一下观众:“主播已经离开”。
    若是是点播URL,那要检查您要播放的文件是否还在服务器上,好比要播放的地址是否已经被其它人从点播系统移除了。

  • (缘由二) 本地网页调试
    目前腾讯云的 Web 播放器是不支持本地网页去调试的(即经过file://协议来打开视频播放的网页),主要是浏览器有跨域安全限制。因此您若是是在Windows上随便放一个test.html文件而后测试,是确定播放不了的,须要将其上传到一个服务器上进行测试。固然前端工程师能够经过反向代理的方式对线上的页面进行本地代理以实现本地调试,这是主流可行的本地调试办法。

  • (缘由三) 手机兼容问题
    FLV 和 RTMP 这两种地址,在普通的手机浏览器上都是不支持的(最新版本的QQ浏览器支持flv协议的播放,但普及度还不高),只能用HLS(m3u8)。

  • (缘由四) 跨域安全问题
    PC浏览器的视频播放是基于Flash控件实现的,但作过Flash开发的同窗都知道,Flash控件会作跨域访问检查,当您要播放的视频所存放的服务器没有部署跨域策略时,才会碰到这个问题。解决方法就是:在视频服务器的根域名下的跨域配置文件 crossdomain.xml 中增长 qq.com 域名:

    <cross-domain-policy> <allow-access-from domain="*.qq.com" secure="false"/> </cross-domain-policy> 

Step 4:给播放器设置封面

在前面的代码例子中,您应该注意到 “coverpic” 这个参数了,在这里将详细介绍这个属性的使用方法。

备注:封面功能有可能在部分移动端播放环境下失效,因为移动端视频播放环境相对 PC 来讲比较复杂,各个浏览器和 APP 的 Webview 对 H5 video 实现的方式并不统一。若是遇到功能失效的状况,欢迎向咱们的技术支持反馈(反馈内容包括系统、浏览器或APP的版本等关键信息),咱们将尽量去支持。

4.1 简单设置封面

coverpic能够传入一个图片地址做为播放器的封面,将在播放器区域内居中而且以图片的实际分辨率进行显示

"coverpic" : "http://www.test.com/myimage.jpg" 

4.2 设置封面的展示样式

coverpic 同时支持传入一个对象,对象中能够进行设置封面的展示样式 style 和图片地址 src。

style支持的样式有3种:

  • "default" 居中而且以图片的实际分辨率进行显示。
  • "stretch" 拉伸铺满播放器区域,图片可能会变形。
  • "cover" 优先横向等比拉伸铺满播放器区域,图片某些部分可能没法显示在区域内。
"coverpic" : {"style":"stretch", "src":"http://www.test.com/myimage.jpg"} 

4.3 实现用例

这里有一个线上的示例代码,里面使用了cover方式显示封面,在PC浏览器中右键“查看页面源码”便可查看页面的代码实现:
http://imgcache.qq.com/open/qcloud/video/vcplayer/demo/tcplayer-cover.html

备注:在某些移动端设置封面会无效,具体说明请查看常见问题

Step 5:多清晰度的支持

5.1 原理介绍

咱们知道优酷、土豆、腾讯上的视频有些是有多清晰度选择的,这个效果如何实现呢?

这里要特别科普一下:播放器自己是没有能力去改变视频的清晰度的,在视频源产生的地方其实只有一种清晰度,咱们称之为原画,而原画视频编码格式和封装格式有不少种,在 Web 端没法彻底支持播放全部的视频格式,点播支持必须是以 H.264 为视频编码,以 mp四、flv 为封装格式的视频。

那么多清晰度是怎么实现的呢? 这里就是视频云发挥做用的地方了:

  • 对于直播,来自主播那一端的原始视频会在腾讯云进行实时的转码,分出多路转码后的视频,好比咱们常说的高清-HD,以及标清-SD,每一路视频都有其对应的地址:

    http://2157.liveplay.myqcloud.com/2157_358535a.m3u8 // 原画 http://2157.liveplay.myqcloud.com/2157_358535a_900.m3u8 // 高清 http://2157.liveplay.myqcloud.com/2157_358535a_550.m3u8 // 标清 
  • 对于点播,一个视频文件上传到腾讯云之后,您能够操做对该视频文件进行转码,产生另外几种清晰度的视频,好比咱们常说的高清-HD,以及标清-SD,须要注意的是,上传后的原始视频是未通过腾讯云转码的,不能直接用于播放。

    http://200002949.vod.myqcloud.com/200002949_b6ffc.f240.m3u8 // 原画,用转码后的超清替换 http://200002949.vod.myqcloud.com/200002949_b6ffc.f230.av.m3u8 // 高清 http://200002949.vod.myqcloud.com/200002949_b6ffc.f220.av.m3u8 // 标清 

    备注:上传后的原始视频是未通过腾讯云转码的,不能直接用于播放

5.2 代码实现

以下的代码是让播放器支持多种清晰度的支持,也就是在播放器的用户界面上展现多种清晰度线路的选择。

var player = new TcPlayer('id_test_video', { "m3u8" : "http://200002949.vod.myqcloud.com/200002949_b6ffc.f240.m3u8",//请替换成实际可用的播放地址 "m3u8_hd" : "http://200002949.vod.myqcloud.com/200002949_b6ffc.f230.av.m3u8", "m3u8_sd" : "http://200002949.vod.myqcloud.com/200002949_b6ffc.f220.av.m3u8", "autoplay" : true, //iOS下safari浏览器,以及大部分移动端浏览器是不开放视频自动播放这个能力的 "coverpic" : "http://www.test.com/myimage.jpg", }); 

5.3 实现用例

这里有一个线上的示例代码,里面使用了多种分辨率的设置以及切换功能,在PC浏览器中右键“查看页面源码”便可查看页面的代码实现:
http://imgcache.qq.com/open/qcloud/video/vcplayer/demo/tcplayer-clarity.html?autoplay=true

正常状况将看到这样的效果:

pc端现已支持多种清晰度播放并支持切换的功能,移动端还没有支持。

Step 6:定制错误提示语

咱们默认的提示语您可能以为不符合您的需求,好比“网络错误,请检查网络配置或者播放连接是否正确”或者“视频解码错误”等等,咱们担忧这些提示语在您看来可能太干瘪了,因此腾讯云Web播放器将支持提示语定制:

6.1 代码实现

以下是让播放器支持自定义提示语的核心代码,设置的提示语主要落在wording属性上。

var player = new TcPlayer('id_test_video', { "m3u8" : "http://200002949.vod.myqcloud.com/200002949_b6ffc.f0.m3u8",//请替换成实际可用的播放地址 "autoplay" : true, //iOS下safari浏览器是不开放这个能力的 "coverpic" : "http://www.test.com/myimage.jpg", "wording": { 2032: "请求视频失败,请检查网络", 2048: "请求m3u8文件失败,多是网络错误或者跨域问题" } }); 

6.2 实现用例

这里有一个线上的示例代码,里面使用了自定义提示文案的功能,在PC浏览器中右键“查看页面源码”便可查看页面的代码实现:
http://imgcache.qq.com/open/qcloud/video/vcplayer/demo/tcplayer.html?m3u8=http://2527.vod.myqcloud.com/2527_b393eb1.f230.av.m3u8

6.3 错误码对照表

Code 提示语 说明
1 网络错误,请检查网络配置或者播放连接是否正确 (H5提示的错误)
2 网络错误,请检查网络配置或者播放连接是否正确 视频格式WEB播放器没法解码(H5提示的错误)
3 视频解码错误 (H5提示的错误)
4 当前系统环境不支持播放该视频格式 (H5提示的错误)
5 当前系统环境不支持播放该视频格式 播放器判断当前浏览器环境不支持播放传入的视频,多是当前浏览器不支持MSE或者Flash插件未启用
10 请勿在file协议下使用播放器,可能会致使视频没法播放  
11 使用参数有误,请检查播放器调用代码  
12 请填写视频播放地址  
13 直播已结束,请稍后再来 RTMP正常播放过程当中触发事件 (NetConnection.Connect.Closed) (Flash提示的错误)
1001 网络错误,请检查网络配置或者播放连接是否正确 网络已断开( NetConnection.Connect.Closed) (Flash提示的错误)
1002 获取视频失败,请检查播放连接是否有效 拉取播放文件失败( NetStream.Play.StreamNotFound),多是服务器错误或者视频文件不存在 (Flash提示的错误)
2032 获取视频失败,请检查播放连接是否有效 (Flash提示的错误)
2048 没法加载视频文件,跨域访问被拒绝 请求m3u8文件失败,多是网络错误或者跨域问题 (Flash提示的错误)

备注:
Code 1 ~ 4 对应的是 H5 的原生事件。
因为Flash的黑盒特性以及H5视频播放标准的不肯定性,错误提示语会不按期更新。

源码参考

这里有一个线上的示例代码,在PC浏览器中右键“查看页面源码”便可查看页面的代码实现:

http://imgcache.qq.com/open/qcloud/video/vcplayer/demo/tcplayer.html?autoplay=true

您也用它来测试播放器的效果,在连接后面加上须要播放的视频地址,刷新后就会播放这个视频地址:

http://imgcache.qq.com/open/qcloud/video/vcplayer/demo/tcplayer.html?autoplay=true&m3u8=http://2527.vod.myqcloud.com/2527_b3907044441c11e6a46d294f954f93eb.f230.av.m3u8 

参数列表

下面列出了播放器支持的全部参数,并进行了详细的说明。

参数 类型 默认值 参数说明
m3u8 String 原画m3u8 播放URL 
示例: http://2157.liveplay.myqcloud.com/2157_358535a.m3u8
m3u8_hd String 高清m3u8 播放URL 
示例: http://2157.liveplay.myqcloud.com/2157_358535ahd.m3u8
m3u8_sd String 标清m3u8 播放URL 
示例: http://2157.liveplay.myqcloud.com/2157_358535asd.m3u8
flv String 原画flv 播放URL 
示例: http://2157.liveplay.myqcloud.com/2157_358535a.flv
flv_hd String 高清flv 播放URL 
示例: http://2157.liveplay.myqcloud.com/2157_358535ahd.flv
flv_sd String 标清flv 播放URL 
示例: http://2157.liveplay.myqcloud.com/2157_358535asd.flv
mp4 String 原画mp4 播放URL 
示例: http://200002949.vod.myqcloud.com/200002949_b6ffc.f0.mp4
mp4_hd String 高清mp4 播放URL 
示例: http://200002949.vod.myqcloud.com/200002949_b6ffc.f40.mp4
mp4_sd String 标清mp4 播放URL 
示例: http://200002949.vod.myqcloud.com/200002949_b6ffc.f20.mp4
rtmp String 原画rtmp 播放URL 
示例: rtmp://2157.liveplay.myqcloud.com/live/2157_280d88
rtmp_hd String 高清rtmp 播放URL 
示例: rtmp://2157.liveplay.myqcloud.com/live/2157_280d88hd
rtmp_sd String 标清rtmp 播放URL 
示例: rtmp://2157.liveplay.myqcloud.com/live/2157_280d88sd
width Number 必选,设置播放器宽度,单位为像素 
示例: 640
height Number 必选,设置播放器高度,单位为像素 
示例: 480
volume Number 0.5 设置初始音量,范围:0~1 [v2.2.0+] 
示例: 0.6
live Boolean false 必选,设置视频是否为直播类型,将决定是否渲染时间轴等控件,以及区分点直播的处理逻辑 
示例: true
autoplay Boolean false 是否自动播放
备注:该选项只对大部分PC平台生效 
示例: true
coverpic String / Object 预览封面,能够传入一个图片地址或者一个包含图片地址 src 和显示样式 style 的对象。
style可选属性:
default 居中1:1显示 
stretch 拉伸铺满播放器区域,图片可能会变形 
cover 优先横向等比拉伸铺满播放器区域,图片某些部分可能没法显示在区域内 
示例: "http://www.test.com/myimage.jpg
或者
{"style": "cover", "src": "http://www.test.com/myimage.jpg"}
controls String "default" default 显示默认控件,none 不显示控件,system 移动端显示系统控件 备注:若是须要在移动端使用系统全屏,就须要设置为system。默认全屏方案是使用 Fullscreen API + 伪全屏的方式例子 
示例: "system"
flash Boolean true 是否优先使用 flash 播放视频,
备注:该选项只对PC平台生效 [v2.2.0+] 
示例: true
h5_flv Boolean false 是否启用 flv.js 的播放 flv。启用时播放器将在支持 MSE 的浏览器下,采用 flv.js 播放 flv,然而并非全部支持 MSE 的浏览器均可以使用 flv.js ,因此播放器不会默认开启这个属性。[v2.2.0+] 
示例: true
x5_player Boolean false 是否启用 TBS 的播放 flv。启用时播放器将在 TBS 模式下(例如 Android 的微信、QQ浏览器)将 flv 播放地址直接赋给 <video> 播放。TBS 视频能力 [v2.2.0+] 
示例: true
x5_type String 经过 video 属性 “x5-video-player-type” 声明启用同层H5播放器,支持的值:h5 (该属性为TBS内核实验性属性,非 TBS 内核不支持)。TBS H5同层播放器接入规范 
示例: "h5"
x5_fullscreen String 经过 video 属性 “x5-video-player-fullscreen” 声明视频播放时是否进入到 TBS 的全屏模式,支持的值:true (该属性为 TBS 内核实验性属性,非 TBS 内核不支持) 。 
示例: "true"
x5_orientation Number 经过 video 属性 “x5-video-orientation” 声明 TBS 播放器支持的方向,可选值:0(landscape 横屏), 1:(portraint竖屏), 2:(landscape | portrait跟随手机自动旋转)。 (该属性为 TBS 内核实验性属性,非 TBS 内核不支持) [v2.2.0+] 
示例: 0
wording Object 自定义文案 
示例: { 2032: '请求视频失败,请检查网络'}
listener Function 事件监听回调函数,回调函数将传入一个JSON格式的对象 
示例: function(msg){
//进行事件处理 
}

实例方法列表

下面列出了播放器实例支持的方法。

方法 参数 返回值 说明 示例
play() 开始播放视频 player.play()
pause() 暂停播放视频 player.pause()
togglePlay() 切换视频播放状态 player.togglePlay()
mute(muted) {Boolean} [可选] true,false {Boolean} 切换静音状态,不传参则返回当前是否静音 player.mute(true)
volume(val) {int} 范围:0~1 [可选] 范围:0~1 设置音量,不传参则返回当前音量 player.volume(0.3)
playing() true,false {Boolean} 返回是否在播放中 player.playing()
duration() {int} 获取视频时长 
备注:只适用于点播
player.duration()
currentTime(time) {int} [可选] {int} 设置视频播放时间点,不传参则返回当前播放时间点 
备注:只适用于点播
player.currentTime()
fullscreen(enter) {Boolean} [可选] true,false {Boolean} 调用全屏接口(Fullscreen API),不支持全屏接口时使用伪全屏模式,不传参则返回值当前是不是全屏 
备注:移动端系统全屏没有提供api,也没法获取系统全屏状态
player.fullscreen(true)
buffered() 0~1 获取视频缓冲数据百分比 
备注:只适用于点播
player.buffered()

进阶攻略

这里介绍一些视频播放器SDK的进阶使用方法

开启优先H5播放模式

TcPlayer 是采用 H5 <video> 和 Flash 相结合的方式来进行视频播放的,在不一样的播放环境中,播放器会选择默认最合适的播放方案。

虽然目前浏览器厂商已经开始逐步放弃对 Flash 插件的支持,可是在国内仍有大量的浏览器不支持 MSE,在播放 FLV HLS(m3u8)时没法切换到H5 <video>的播放模式,而播放 RTMP 必须使用 Flash 模式才能够播放,
所以 TcPlayer 还是默认优先启用 Flash 播放模式,若是在检测到 Flash 插件不可用的状况下,将采用 H5 <video>进行播放。

默认 Flash 模式的缘由是 Flash 支持的视频格式最广,而H5 <video>默认只支持 MP4(h.264)(其余非腾讯云提供的视频格式这里就不列出了),在特定条件下才能支持HLS(m3u8)、FLV。

从2.2.0版本开始,提供了能够设置播放模式优先级的属性,若是想优先采用H5 <video>播放模式,须要把 flash 属性设置为 false ,这样在播放时默认将启用H5 <video>播放,若是H5 <video>不可用将采用 Flash 播放,若是没有检测到 Flash 插件将会提示“当前系统环境不支持播放该视频格式”

监听事件

TcPlayer 是采用 H5 <video> 和 Flash 相结合的方式来进行视频播放,因为两种方式播放视频时触发的事件不尽相同,因此咱们以 H5 <video> 的规范为准,对 Flash 的播放事件作了必定程度的转换,以实现播放事件命名的统一。TcPlayer 对这两种播放方式所触发的原生事件进行了捕获和透传。

H5事件参考列表
Flash事件参考列表

统一后的事件列表

error
timeupdate
load loadedmetadata loadeddata progress fullscreen play playing pause ended seeking seeked resize volumechange 

注意事项:

  • 若是经过系统控制栏进行全屏,将没法监听到 fullscreen 事件。

Flash模式下特有的事件

netStatus

备注:因为Flash的黑盒特性以及H5视频播放标准在各个平台终端的实现不一致性,事件的触发方式和结果会有差别,开发过程当中能够留意这些差别

在非自动播放的条件下,加载视频至待播放状态,移动端和PC Flash 触发的事件区别
移动端:
移动端
PC Flash:
PC Flash

备注:以上是两种平台的差别,然而在移动端的各类设备和 APP 之间一样存在差别。

应用案例:

经过事件监听,能够进行播放失败重连,在线例子连接

更新日志

TcPlayer在不断的更新以及完善中,为了方便你们了解版本状况,下面列出的是TcPlayer发布的主版本介绍,而一些历史bug修复,小功能版本没有列出。

日期 版本 更新内容
2016.12.28 2.0.0 首个版本
2017.3.4 2.1.0 至2017.6.30,经历数次的迭代开发逐步趋于稳定,目前文档的功能描述中,若是没有特殊说明,皆基于此版本。
2017.6.30 2.2.0 1. 增长控制播放环境判断的参数: flash、h5_flv、x5_player。
2.调整播放器初始化逻辑,优化错误提示效果。
3.增长flv.js支持,在符合条件的状况下能够采用flv.js播放 flv 
4.支持x5-video-orientation属性,
5.增长播放环境判断逻辑,可经过参数调整H5与Flash的优先级,以及是否启用TBS播放。
6.启用版本号发布方式,避免影响旧版本的使用者。
7.优化事件触发的时间戳,统一为标准时间。
8.bug修复

常见问题

    • TcPlayer支持哪些浏览器?

      TcPlayer 通过测试并支持的浏览器有,桌面端:IE10+、Edge、Chrome、Firefox、QQ浏览器,MAC Safari,移动端:Android4.4+,iOS8.0+,微信、手机QQ、QQ浏览器、Chrome、Safari。
      如需支持IE八、IE9浏览器须要在引入播放器脚本前,引入Polyfill脚本。以下所示:

      <!--[if lt IE 9]> <script src="//imgcache.qq.com/open/qcloud/video/vcplayer/libs/es5-shim.js" charset="utf-8"></script> <script src="//imgcache.qq.com/open/qcloud/video/vcplayer/libs/es5-sham.js" charset="utf-8"></script> <![endif]--> <script src="//imgcache.qq.com/open/qcloud/video/vcplayer/TcPlayer-2.2.0.js" charset="utf-8"></script>; 
    • 为何在移动端 TcPlayer 全屏后没法使视频全屏,仍然会显示浏览器的界面?

      首先要了解一些背景知识,TcPlayer 提供的全屏方案是 Fullscreen API + 伪全屏的方式,若是浏览器支持 Fullscreen API 那么进入全屏时,视频容器将会铺满屏幕,控制栏是 TcPlayer 提供的控制栏,如图所示

      (Android Chrome)

      若是浏览器不支持Fullscreen API 则会进入伪全屏模式,如图所示:

      (左:Android 微信,右:iOS 微信)

      这两种全屏模式显示的控制栏都是 TcPlayer 提供的控制栏,进入方式都是经过点击控制栏的全屏按钮,或者 TcPlayer 提供的全屏方法实现的。
      然而在移动端不必定能够显示 TcPlayer 提供的控制栏,大部分状况下移动端webview会劫持视频播放,并使用 webview 提供的控制栏,这样就没法显示 TcPlayer 的控制栏,也没法使用 TcPlayer 提供的全屏方案。如图所示:

      (左:Android 微信,TBS劫持视频播放,右:iOS QQ浏览器劫持视频播放)
      进入全屏后:

      (左:Android 微信,右:iOS QQ浏览器)
      能够看到控制栏与 TcPlayer 是不一样的,而这种全屏方式是没有接口提供给 JS 调用的,因此 TcPlayer 没法实现这样的全屏方式。
      (咱们一般会把视频区域铺满屏幕的全屏模式称为系统全屏,而视频区域铺满浏览器的页面可视区域称为伪全屏)
      综上所诉若是全屏后看到浏览器的界面则是进入了伪全屏,若是想在移动端全屏时必须进入系统全屏,只能使用系统提供的控制栏,选择控制栏类型能够经过 TcPlayer 的 controls 属性进行设置。

    • 为何H5播放视频拉伸变形了?

      H5并不具有拉伸视频的能力,请检查播放器的容器宽高是否设置正确。

    • 为何我本身的 div 没法在盖在视频上?

      不一样浏览器对于 <video> 标签的实现方案不一样,好比您的网页若是是从QQ或者微信里打开的(这里说的是Android系统下),那么极高的几率会使用QQ或微信捆绑的X5浏览器内核,也就是QQ浏览器内核,该团队考虑当时处于某些缘由的考虑,采用了“视频 <video> 标签必定要处于最上层”的实现方案(相关信息参考QQ浏览器文档说明),不过最近经过公司内部的各类协调,QQ浏览器团队正在逐步修改这个策略,您在看到这个文档时,可能最新版本的X5浏览器内核已经解决了这个问题。

    • 为何设置封面无效?

      这个问题的缘由和上一个问题“ div 没法在盖在视频上”是同样的,除非浏览器容许元素可以覆盖 <video> 标签,否则封面将会没法显示。

    • 为何在某些移动端浏览器视频会默认全屏播放?

      若是您的视频是在APP内实现内联播放(即您本身的App包装一个iOS的 webview 控件,用此控件显示网页,这种模式下您能够对 webview 进行一些细节定制,它的表现能够和标准 safari 浏览器有所不一样),能够经过在 HTML 中的 <video> 标签设置 webkit-playsinline 属性(若是在 iOS10 下,则设置为 playsinline 属性),同时 WebView 须要设置 allowsInlineMediaPlayback,这样页面在APP里打开时,视频就能以非全屏模式(即内联的方式)播放。

      若是您的页面是在Safari下打开的,目前iOS10如下版本的Safari是没法禁止视频自动全屏播放的,iOS10能够经过前面说的方法(为 <video> 标签设置 playsinline 属性)实现非全屏模式(即内联的方式)播放。咱们的播放器已经自动加上这个属性,只须要终端支持便可。

      若是是Android终端,众所周知Android系统有各类各样的定制版本,每一个版本对 <video> 标签的实现都有差异,并无一个完整的统一标准,因此在Android上播放视频所展示的一致性,相比iOS要差不少。按照现有通用的办法,播放器已经自动加上 webkit-playsinline playsinline 属性,只须要终端支持便可。

    • 为何在移动端浏览器视频没法自动播放?

      在移动端 WEB 自动播放视频只有两个办法,经过设置 <video> 标签 autoplay 属性 或者调用 <video> 标签提供的 play() 方法,然而现实是在移动端WEB中视频自动播放一直是被禁止的,目前通用的办法是经过用户手动触发播放(例如监听用户的点击事件并调用 play()方法)。除此以外不排除一些特殊定制的 webview 支持 <video> 标签 autoplay 属性或者经过其余特殊的函数调用实现自动播放,那么在这类 Webview 下打开页面就有可能自动播放。咱们的播放器已经在 autoplay 设置为 true 的状况下,为 <video> 标签加上 autoplay 属性,只要终端支持便可。

    • 为何在 PC Chrome 中Flash播放器会有两个播放按钮?

      从Chrome 42版本开始将再也不自动播放Flash(谷歌购买了WebRTC并进行开源并非没有想法的), 只对主要的Flash内容进行自动播放,其它的Flash内容将被暂停播放,除非用户决定去手动点开它。

    • 为何在 PC 浏览器中能够播放直播视频,移动端却不行?

      在移动端浏览器中播放直播视频,目前只支持hls(m3u8)协议,所以须要确认直播拉流地址是否有hls(m3u8)拉流url,若是您只给咱们的播放器一个flv或者rtmp的地址,是没有什么办法在手机上观看的。

相关文章
相关标签/搜索