摘要:首先先看一下原生对字幕的支持显示情况元素允许我们使用元素为视频指定字幕。和忽略元素上的属性,而是尝试将浏览器的语言与字幕的语言相匹配案例展示参考资料张鑫旭文件生成器如果觉得还不错,还请给我一个赞鼓励一下
首先先看一下原生HTML5 video对字幕的支持显示情况:
HTML5允许我们使用
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类名九幽阴灵1111 00:00:03.001 --> 00:00:06.000诸天神魔2222 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伪元件的关键是靶向个别文本轨道线索用于定型的,因为它的任何限定球杆匹配。只有少数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标签等。
//设置字幕的样式 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上的属性,
案例展示:demo 参考资料MDN
张鑫旭
webvtt文件生成器
如果觉得还不错,还请给我一个赞鼓励一下!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/11086.html
摘要:首先先看一下原生对字幕的支持显示情况元素允许我们使用元素为视频指定字幕。和忽略元素上的属性,而是尝试将浏览器的语言与字幕的语言相匹配案例展示参考资料张鑫旭文件生成器如果觉得还不错,还请给我一个赞鼓励一下 首先先看一下原生HTML5 video对字幕的支持显示情况: showImg(https://segmentfault.com/img/bV80HD?w=429&h=248); 元素 ...
摘要:还有一个值得关注的是加密媒体扩展标准其支持用原生和开发播放加密视频。专业流媒体发布商将无法依靠微软的技术在和安卓设备上的火狐来加密自己的内容。因此,不同的系统组合,如用于和安卓的,用于和的,还有用于的。 英文原文:HTML5 Media Source Extensions: Bringing Production Video To The Web 在过去的十几年,像Flash和Silv...
阅读 1939·2021-11-24 09:39
阅读 3281·2021-09-22 14:58
阅读 1164·2019-08-30 15:54
阅读 3318·2019-08-29 11:33
阅读 1788·2019-08-26 13:54
阅读 1599·2019-08-26 13:35
阅读 2469·2019-08-23 18:14
阅读 767·2019-08-23 17:04