博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HTML5 video视频字幕的使用和制作
阅读量:6253 次
发布时间:2019-06-22

本文共 2097 字,大约阅读时间需要 6 分钟。

首先先看一下原生HTML5 video对字幕的支持显示情况:

webvtt.jpg

<track>元素

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

track的属性介绍:
  • kind被赋予一个值subtitles,表示文件包含的内容的类型
  • label被赋予一个值,指示该字幕集所用的语言 - 例如English或Deutsch- 这些标签将出现在用户界面中,以允许用户容易地选择他们想要看到的字幕语言。
  • src 在每种情况下都会分配一个指向相关WebVTT字幕文件的有效URL。
  • srclang 指示每个字幕文件的内容所在的语言。
  • 该default属性在英语<track>元素上设置,向浏览器表明这是默认的字幕文件定义,当字幕打开并且用户没有做出特定选择时使用。

WebVTT 字幕文件

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

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

文件格式规范:

文件的后缀名为 .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以我血躯333300:00:09.001 --> 00:00:12.000奉为牺牲444400: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标签,还有rubylang标签等。

//设置字幕的样式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上的属性,<track>而是尝试将浏览器的语言与字幕的语言相匹配

参考资料

如果觉得还不错,还请给我一个赞鼓励一下!

转载地址:http://jkfsa.baihongyu.com/

你可能感兴趣的文章
[AI开发]视频多目标跟踪高级版(离自动驾驶又‘近’了一点点)
查看>>
springmvc中controller内方法跳转forward?redirect?
查看>>
论坛程序推荐,区别
查看>>
spring mvc redirect 重定向 跳转并传递参数
查看>>
《止学》 [隋]文中子(王通)
查看>>
微信小程序之底部弹框预约插件
查看>>
基础知识 - Golang 中的正则表达式
查看>>
分享一个shell脚本的坑:grep匹配+wc取值 在脚本执行后的结果与手动执行结果不一致...
查看>>
【Clojure 基本知识】 关于函数参数的各种高级用法
查看>>
Python系列文章
查看>>
顺序图【6】--☆☆
查看>>
5日均线MACD
查看>>
Docker 版本
查看>>
【ABP杂烩】面向切面编程(AOP)知识总结
查看>>
java 如何使用多线程调用类的静态方法?
查看>>
数据挖掘基本概念讲解
查看>>
(原創) C语言果然是不会死的语言 (C/C++) (C) (IC Design) (DE2) (Nios II)
查看>>
不能运行VS2005的DSL Tool例子
查看>>
OSI/RM参考模型和TCP/IP协议的关系
查看>>
Android Intent用法汇总
查看>>