我已经使用Mp4Box创建了长MP4视频的固定长度段. Mp4Box创建一个元信息文件mv_init.mp4和片段,如mv_1.m4s,mv_2.m4s,…我使用 HTML5 Media Source Extensions流式传输视频,流媒体正常工作.

问题是我无法利用HTML5播放器的时间寻找功能.当用户使用seekbar寻找另一个时间点时,我需要为该currentTime获取正确的段文件(mv_ {number} .m4s).

例如:

>视频持续时间:2小时
>段大小:10秒
>用户寻求时间:25分钟

25分钟= 25×60秒= 1500秒.每个段都是10秒,我需要段号1500/10 = 150.所需的段文件是mv_150.m4s.

这个计算显然是正确的,但是HTML5播放器然后在mv_150.m4之后下载更多的文件,然后继续流式传输.

如何正确计算段文件号码,以便在寻求之后,流媒体流畅运行,无需下载任何额外的文件?

要创建MP4视频的片段,我使用以下命令:

MP4Box -dash 10000 -out video.mpd -dash-profile live -segment-name mv_ -rap video.mp4

解决方法

我已经研究了这件事,发现了事实.加载段的校正是正确的.问题是视频文件中的关键帧间隔.关键帧是视频中的帧,从该点开始,视频可以随后加载并运行.所以在我的情况下,我需要在每个段的开头插入关键帧.因此,当我们在不同的时间位置查看视频时,下一个被加载的片段在其开始处包含一个关键帧.

视频文件中的关键帧可以使用FFMPEG进行设置.因此,例如,如果我们有一段5秒的视频,那么我们必须使用ffmpeg以5秒的间隔创建关键帧.设置关键帧的另一个重点是查看视频的帧率.视频必须具有固定的帧速率,因此我们可以精确计算关键帧的位置.

例:

Video File: gladiator.mp4

Segment Size: 5 seconds

没有我们使用FFMPEG设置帧速率和关键帧间隔

ffmpeg -i gladiator.mp4 -x264-params
keyint=120:min-keyint=120:no-scenecut=1 -r 24 gladiator-output.mp4

keyint=120 i.e; 24 fps * 5 seconds = 120

现在我们使用Mp4Box创建段文件

MP4Box -dash 5000 -frag 5000 -out gladiator.mpd -dash-profile
on-demand -segment-name mv_ gladiator-output.mp4

因此,它将在每个段文件的开始创建具有关键帧的片段,如mv_1,mv_2,…等等.

Seekable Dash Streaming Example

视频流 – 当用户寻找另一个时间时,在HTML5视频流中计算.m4s段文件后缀的更多相关文章

  1. 使用HTML5做的导航条详细步骤

    这篇文章主要介绍了用HTML5做的导航条详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  2. 详解HTML5中的picture元素响应式处理图片

    这篇文章主要介绍了详解HTML5中的picture元素响应式处理图片,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  3. html5利用canvas实现颜色容差抠图功能

    这篇文章主要介绍了html5利用canvas实现颜色容差抠图功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  4. HTML5拖拽功能实现的拼图游戏

    本文通过实例代码给大家介绍了HTML5拖拽功能实现的拼图游戏,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧

  5. HTML5实现直播间评论滚动效果的代码

    这篇文章主要介绍了HTML5实现直播间评论滚动效果的代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. 使用Html5多媒体实现微信语音功能

    这篇文章主要介绍了使用Html5多媒体实现微信语音功能,需要的朋友可以参考下

  7. HTML5 播放 RTSP 视频的实例代码

    目前大多数网络摄像头都是通过 RTSP 协议传输视频流的,但是 HTML 并不标准支持 RTSP 流。本文重点给大家介绍HTML5 播放 RTSP 视频的实例代码,需要的朋友参考下吧

  8. html5 拖拽及用 js 实现拖拽功能的示例代码

    这篇文章主要介绍了html5 拖拽及用 js 实现拖拽,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  9. HTML5自定义视频播放器源码

    这篇文章主要介绍了HTML5自定义视频播放器源码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  10. HTML5新增form控件和表单属性实例代码详解

    这篇文章主要介绍了HTML5新增form控件和表单属性实例代码详解,需要的朋友可以参考下

随机推荐

  1. 微信小程序canvas实现水平、垂直居中效果

    这篇文章主要介绍了小程序中canvas实现水平、垂直居中效果,本文图文实例代码相结合给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

  2. 使用HTML5做的导航条详细步骤

    这篇文章主要介绍了用HTML5做的导航条详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. H5最强接口之canvas实现动态图形功能

    这篇文章主要介绍了H5最强接口之canvas实现动态图形功能,需要的朋友可以参考下

  4. Canvas高级路径操作之拖拽对象的实现

    这篇文章主要介绍了Canvas高级路径操作之拖拽对象的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  5. html5视频自动横过来自适应页面且点击播放功能的实现

    这篇文章主要介绍了h5视频自动横过来自适应页面且点击播放,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. 详解HTML5中的picture元素响应式处理图片

    这篇文章主要介绍了详解HTML5中的picture元素响应式处理图片,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. canvas像素点操作之视频绿幕抠图

    这篇文章主要介绍了canvas像素点操作之视频绿幕抠图的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  8. html5利用canvas实现颜色容差抠图功能

    这篇文章主要介绍了html5利用canvas实现颜色容差抠图功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  9. canvas绘制视频封面的方法

    这篇文章主要介绍了canvas绘制视频封面的方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. HTML5拖拽功能实现的拼图游戏

    本文通过实例代码给大家介绍了HTML5拖拽功能实现的拼图游戏,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧

返回
顶部