H5的video如何实现以及操作弹幕


本文摘自PHP中文网,作者php中世界最好的语言,侵删。

这次给大家带来H5的video如何实现以及操作弹幕,H5的video实现与操作弹幕注意事项有哪些,下面就是实战案例,一起来看一下。

HTML5允许我们使用 元素为视频指定字幕。这个元素的各种属性允许我们指定这样的东西,比如我们添加的内容的类型,它所在的语言,当然还有对包含实际字幕信息的文本文件的引用。

1

2

3

4

5

6

<video id="video"  controls>

    <source src="./step.mp4" type="video/mp4">

    <track label="中文字幕" kind="subtitles" chapters metadata srclang="zh" src="./caption.vtt" default>

    <track label="ABC" kind="subtitles" srclang="de" src="./caption1.vtt">

    <track label="Number" kind="subtitles" srclang="es" src="./caption2.vtt">

 </video>

track的属性介绍:

  • kind被赋予一个值subtitles,表示文件包含的内容的类型

  • label被赋予一个值,指示该字幕集所用的语言 - 例如English或Deutsch- 这些标签将出现在用户界面中,以允许用户容易地选择他们想要看到的字幕语言。

  • src 在每种情况下都会分配一个指向相关WebVTT字幕文件的有效URL。

  • srclang 指示每个字幕文件的内容所在的语言。

  • 该default属性在英语 元素上设置,向浏览器表明这是默认的字幕文件定义,当字幕打开并且用户没有做出特定选择时使用。

WebVTT 字幕文件

包含实际字幕数据的文件是遵循指定格式的简单文本文件,在这种情况下是Web视频文本轨道(WebVTT)格式。该==WebVTT插入规范仍在开发中==,但它的==主要部分是稳定的==,所以我们今天可以使用它。

视频提供商(如Blender Foundation)以其视频的文本格式提供字幕和副标题,但通常采用SubRip Text(SRT)格式。可以使用在线转换器(如srt2vtt)将这些转换为WebVTT。

文件格式规范:

文件的后缀名为 ==.vtt==

==.vtt==文件的MIME type是text/vtt

在Chrome和Firefox浏览器下,.vtt字幕是可以无障碍加载显示的,但是对于IE10+浏览器,虽然也支持.vtt字幕,但是却需要定义MIME type,否则会无视WebVTT格式。比较简单方式就是在字幕所在文件夹下面添加个.htaccess文件,里面写上AddType text/vtt .vtt。

//文件开头下必须先声明 ==WEBVTT==
WEBVTT
// 起始时间 --> 结束时间,单位为毫秒
00:00:00.001 --> 00:00:03.000
// 对应上面的时间显示字幕,可以单独设置样式,aa类似class类名
<v aa>九幽阴灵1111</v>
00:00:03.001 --> 00:00:06.000
<v bb>诸天神魔2222</v>
00:00:06.001 --> 00:00:09.000
以我血躯3333
00:00:09.001 --> 00:00:12.000
奉为牺牲4444
00:00:12.001 --> 00:00:15.000
三生七世5555

字幕css样式设置

::cue伪元件的关键是靶向个别文本轨道线索用于定型的,因为它的任何限定球杆匹配。只有少数CSS属性可以应用于文本提示:

  • color

  • opacity

  • visibility

  • text-decoration

  • text-shadow

  • background 速记性能

  • outline 速记性能

  • font 速记属性

  • line-height

  • white-space

==注意::: cue的线索样式目前适用于Chrome,Opera和Safari,但尚未在Firefox上使用。==

WebVTT还支持一些HTML标签进行样式控制,常见的有声音 ==v== 标签,颜色 ==c== 标签,加粗==b==标签,倾斜==i==标签,下划线==u==标签,还有==ruby==和==lang==标签等。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

//设置字幕的样式

video::cue{

    background-color:transparent;

    color:white;

    font-size:20px;

    line-height: 100px;

}

// 设置单行字幕的样式

video::cue(v[voice=aa]){

    color:green;

}

video::cue(v[voice=bb]){

    color:rgb(0, 26, 128);

}

浏览器兼容

IE

默认情况下,Internet Explorer 10+字幕是启用的,并且默认控件包含一个按钮和一个菜单,该菜单提供与我们刚刚构建的菜单相同的功能。该default属性也受支持。

==注意:除非您定义MIME类型,否则IE将完全忽略WebVTT文件。这可以通过将.htaccess文件添加到包含的相应目录轻松完成AddType text/vtt .vtt==

苹果浏览器

Safari 6.1+对Internet Explorer 10+具有类似支持,显示带有不同可用选项的菜单,并增加了一个“自动”选项,允许浏览器进行选择。

Chrome和Opera

这些浏览器也有类似的实现:默认情况下,字幕是启用的,默认控制集包含一个'cc'按钮,可以打开和关闭字幕。Chrome和Opera忽略元素default上的属性, 而是尝试将浏览器的语言与字幕的语言相匹配

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

Vue.js开发mpvue框架步骤详解

jquery fullpage插件添加头部与尾部版权相关

以上就是H5的video如何实现以及操作弹幕的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

html5 实现访问本地文件的方法

react高阶组件(装饰器)的介绍(代码示例)

微信端h5页面如何调用分享页面的接口

h5的移动端适配怎样实现

关于h5的pushstate和replacestate的用法分析

html5规定在拖动被拖动数据时是否进行复制移动或链接的属性dropzone

移动端html5模拟长按删除事件(附代码)

html5返回一个mediaerror对象的属性error

详细介绍基于html5 的webgl技术构建3d场景的图文代码(一)

微信的h5页面调用第三方位置导航

更多相关阅读请进入《video》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...