首先先看一下原生HTML5 video对字幕的支持显示状况:css
HTML5容许咱们使用
<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的属性介绍:html5
kind被赋予一个值subtitles,表示文件包含的内容的类型git
label被赋予一个值,指示该字幕集所用的语言 - 例如English或Deutsch- 这些标签将出如今用户界面中,以容许用户容易地选择他们想要看到的字幕语言。github
src 在每种状况下都会分配一个指向相关WebVTT字幕文件的有效URL。web
srclang 指示每一个字幕文件的内容所在的语言。浏览器
该default属性在英语
包含实际字幕数据的文件是遵循指定格式的简单文本文件,在这种状况下是Web视频文本轨道(WebVTT)格式。该WebVTT插入规范仍在开发中,但它的主要部分是稳定的,因此咱们今天可使用它。bash
视频提供商(如Blender Foundation)以其视频的文本格式提供字幕和副标题,但一般采用SubRip Text(SRT)格式。可使用在线转换器(如srt2vtt)将这些转换为WebVTT。ide
文件格式规范:
文件的后缀名为 .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
复制代码
这个文件规范很简单,能够本身手写,也可使用张鑫旭老师开发的webvtt.vtt文件生成器生成
字幕css样式设置
::cue伪元件是用于在VTT轨道的媒体中使用字幕和其余线索。只有少数CSS属性能够应用于文本提示:
注意::: cue的线索样式目前适用于Chrome,Opera和Safari,但还没有在Firefox上使用。
WebVTT还支持一些HTML标签进行样式控制,常见的有声音 v 标签,颜色 c 标签,加粗b标签,倾斜i标签,下划线u标签,还有ruby和lang标签等。
//设置字幕的样式
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);
}
复制代码
浏览器兼容
默认状况下,Internet Explorer 10+字幕是启用的,而且默认控件包含一个按钮和一个菜单,该菜单提供与咱们刚刚构建的菜单相同的功能。该default属性也受支持。
注意:除非您定义MIME类型,不然IE将彻底忽略WebVTT文件。这能够经过将.htaccess文件添加到包含的相应目录轻松完成AddType text/vtt .vtt
Safari 6.1+对Internet Explorer 10+具备相似支持,显示带有不一样可用选项的菜单,并增长了一个“自动”选项,容许浏览器进行选择。
这些浏览器也有相似的实现:默认状况下,字幕是启用的,默认控制集包含一个'cc'按钮,能够打开和关闭字幕。Chrome和Opera忽略元素default上的属性,
若是以为还不错,还请给我一个赞鼓励一下!