洞察 video 超能力系列——玩转 mp4
用技术提升美好事物发生的概率。Technologically, for greater probability to be happy
前言
只要在 HTML5 中使用过视频播放的同学对 video 标签一定不会陌生,不过很多同学只使用了 video 的基础功能,实际上 video 拥有强大潜能的,只要姿势正确就能让其拥有超能力。不妨从下面几个场景来逐渐了解下video 未曾被发掘的神秘空间:
清晰度无缝切换节省视频流量清晰度无缝切换
点播领域里 mp4 是最普遍、兼容性最好的视频容器,不过 mp4 也有它的局限性,比如常见的清晰度切换,我们是无法像youtube那样做到无缝切换的。我们可以看下普通的mp4播放的网络请求和youtube视频播放的网络请求的区别。
图1.1 普通mp4的下载请求过程
图1.2 Youtube视频下载请求过程
这两张图不难看出,在默认情况下 mp4 使用一次 http 请求所有的视频数据,Youtube 则分次请求。当然这个描述很不专业,但确实形象。造成这种差异的是 video 不支持流式的视频数据,Youtube 采用的是流式的视频容器 webm,而 mp4 是非流式的。那如何解释清楚流式的视频数据呢,从专业的角度三言两语很难说清楚,但用大白话翻译过来就是流式的视频数据支持分段独立播放,非流式的不可以。换句话说一个10M的视频文件,流式的视频可以把0~1M的数据请求回来单独播放,但是非流式的不可以。
上面我们描述了视频格式的不同,接下来我们要说的是第一张图中的视频加载是浏览器来控制的,通过给 video 的 src 属性配置视频地址,触发播放之后浏览器就会开始下载了,JS干涉不了。而 Youtube 的视频加载是通过JS来控制的,各位可以再次看下第二张图的网络请求类型:xhr,足以证明这一点。
上面两点搞清楚之后我们就该说下清晰度切换的事情了。这个需求大家都不陌生,但是直接使用 mp4 格式做无缝清晰度切换,难度还挺大的。先解释下“无缝清晰度切换”的概念:从播放一个分辨率的视频到另一个分辨率且保证画面、声音不停顿的平滑切换过程。了解了这个概念,大家应该知道了用 video 无缝切换 mp4 有多难。一方面,video 是不支持流式的视频格式的,一方面,video 的加载是不受JS控制的。通过切换 video 的 src 属性,必然会导致画面中断、重新请求视频数据等。有的同学想到说利用两个 video 再结合 z-index 来搞,但是当你生成另一个video去加载视频的时候,无法保证两个画面是严格一致的,即使将原来的画面暂停到一个时刻,用另一个视频通过 currentTime 属性与之同步,切换仍然看到画面闪烁,基本无法和 Youtube 无缝切换的体验匹敌。而且还会造成更多流量的浪费,背后的原因大家可以研究下 mp4 容器和 webm 容器的异同,也可以看下视频解码相关的文章。
还有一种方法就是将 mp4 格式统统转码到流式的视频格式比如 hls、webm 等。不过这种看上去可行的方式实际上会带来很大的成本开销,如将大量视频做转码会消耗高昂的机器资源、双倍存储的费用、CDN的双倍费用等等。其实我们也是在这种背景下研究出来新的技术问题解决清晰度无缝切换的。
首先,我们改变对 mp4 视频的播放流程,不再直接使用 video 的 src 来播放,因为我们没有任何可以操作的空间。video不仅支持 src 属性还支持 Blob 对象,我们就是利用后者。播放的流程如下:
图1.3 mp4 视频新播放流程
来请求 mp4 视频数据,这样可以结合视频 Range 服务,做到精确加载。编写解析器将加载回来的部分 mp4 视频数据进行解复用将解复用的视频数据转成 fmp4 格式并传递给 MediaSource使用 video 进行解码完成播放然后在做清晰度切换的时候流程如下:
图1.4 mp4视频清晰度切换原理示意图
播放视频A,过程同上在某个时刻,用户切换到播放视频B,首先解析B的索引文件(moov),反向计算mp4的range区间加载B的视频区间数据解复用把数据转换成fmp4格式并传递给MediaSource删除A的部分Buffer在下一个关键帧自动完成画质的切换图1.5 mp4视频清晰度切换流程示意图
这个过程看上去比较繁琐,但是所有的操作都是在浏览器端完成,也就是说都是JS来实现的。这样之前说的所有成本问题都不存在,还能做到youtube相同体验的无缝切换。如果大家也想使用这个功能不需要自己再去实现一遍上述流程,可以使用如下代码:
如果对这段代码有什么疑惑,或者想深入了解下它背后是如何实现的,可以参考 Github:https://github.com/bytedance/xgplayer 或 阅读原文:https://techblog.toutiao.com/
节省视频流量
使用 video 的同学基本上都是这样用的,如下:
利用src属性2.利用source标签
这样就可以播放视频了,不过前面我们讲过这样使用 video ,视频的加载是受浏览器控制的,可以看下浏览器在视频刚开始播放的时候下载了多少数据:
图2.1 video默认下载截图
我随便找了个视频,大家看下视频总长度是 02:08,在播放到 00:05 的时候,浏览器已经下载到 01:30 了,如果用户终止观看,下载的视频就这样被浪费掉了。当然,如果不断的 seek 也会造成较多的流量浪费。按照我们之前的统计在短视频领域,用户 seek 的频率在 80%,所以这部分流量是可以节省掉的。具体原理如下:
图2.2 播放器加载视频原理
设置每次加载的数据包大小设置预加载时长开启加载队列,完成第一次数据包下载,判断缓冲时间和预加载时长是否满足,不满足请求下一个数据包具体实现代码如下:
这样就实现了视频在播放过程中永远只预加载10秒的数据,进而保证节省流量。
扩展链接,了解超能力西瓜视频是怎样炼成的。
手机突然有些视频无法播放是为什么,格式是mp4
1、首先是播放器的问题。重新安装播放器一般,安卓手机使用mxplayer、moboplayer,苹果手机使用aceplayer、avplayer等,都可以播放。
2、上述方法不行,也可能是MP4文件被破坏了。换一个MP4文件测试一下。
3、另外,可能是一些视频文件有错误的扩展名。比如一些mpg或其它格式的视频,下载回来后被误命名为mp4的扩展名。就会导致解码出错。
如果说播放不了要么是视屏本身有问题 要么播放程序有问题
如果说视屏有问题你可以试试用转码软件 MP4转MP4 如果不行 那大多是视屏已经顺坏
如果说是播放程序有问题 那就简单了 只要换一个程序就ok了
用 MP4/RM转换专家 转换格式、调整分辨率就行了!
它是国内最流行的应用于移动设备的转换软件。
这个软件能帮你将你的视频文件转换成你手机适用的MP4/3GP/3G2等等格式,还能手动设置视频文件的分辨率、比特率等等参数呢~
软件的操作界面简洁,轻松就能完成格式转换!
百度搜索 MP4/RM转换专家
生成序列帧功能的视频编辑软件,基本都是功能强大的视频编辑软件,如PR、ED等。 这些软件,都有汉化版。
相关问答
mp4 使用方法?1、常见的播放器的按键,播放、停止、快进、快退、方向等,图案的标志是一样的。2、MP4通常有菜单键,一般会标明菜单,或英文menu。3、有的MP4,常用的播放等...
为什么 mp4 格式的文件在 MP4播放器 上没法播放?-ZOL问答虽然是MP4格式,但是分辨率跟你的机子不符,所以你需要用你机子上自带的转换软件...首先看一下视频播放的清晰度是高清、标清还是普清,有时候平板电脑的分辨率不够...
ppt怎么用 mp4播放 ?ppt转换成mp4播放的方法与步骤:1、首先,需要将ppt转换成视频,先打开事先准备转换成视频的ppt。2、接着在幻灯片放映选项卡中,找到录制幻灯片演示,并选择从...
如何 播放mp4 文件?要播放MP4文件,可以按照以下几种常见方法进行操作:1.使用电脑自带的媒体播放器:Windows系统自带的WindowsMediaPlayer可以播放MP4文件。在MP4......
手机下的电影 MP4 格式为何看不了-ZOL问答这是因为MP4格式编码有很多种,以前的诺基亚手机播放器只支持部分格式的MP4格式。网上很多MP4是用的H264编码格式编码的,而手机只支持XVID格式编码的MP4文件...
手机怎 播放mp4 ?3、之后在该界面中,点击“本地...1、首先打开小米6手机,点击“小米视频”图标。2、然后在该界面中,点击右上角“文件夹”选项。3、之后在该界面中,点击“本...
mp4 格式用什么 播放器 - 懂得MP4是非常通行的视频封装格式。流行的播放器基本上都可以播放。但不同的平台,有不同的选择。1、PC平台:基本上所有的视频播放器都可以播放。推荐终...
u盘视频 mp4 格式无法 播放 ?U盘中的MP4视频无法播放可能由多种原因导致,包括MP4格式与播放器不兼容、视频文件已损坏、U盘本身存在问题、电脑USB接口故障等。以下是一些可能的解决方法:...
Mp4播放 器怎么用?MP4播放器是一种便携式数字媒体播放器,可以播放各种格式的音频和视频文件,如MP3、WMA、AVI、FLV、MP4等。以下是使用MP4播放器的基本步骤:1.按下MP4播放器的...
mp4 是什么,能玩游戏,看电视吗? - 懂得MP4,全称MPEG-4Part14,是一种使用MPEG-4的多媒体电脑档案格式,副档名为mp4,以储存数码音讯及数码视讯为主。另外,MP4又可理解为MP4播放器,MP4播放器...