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


元素

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的属性介绍:

  • 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

这个文件规范很简单,可以自己手写,也可以使用张鑫旭老师开发的webvtt.vtt文件生成器生成

字幕css样式设置

::cue伪元件是用于在VTT轨道的媒体中使用字幕和其他线索。只有少数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上的属性,而是尝试将浏览器的语言与字幕的语言相匹配

案例展示:demo

参考资料

  • MDN
  • 张鑫旭
  • webvtt文件生成器

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

HTML5 video视频字幕的使用和制作相关推荐

  1. html五编写视屏_HTML5 video视频字幕的使用和制作

    一.video支持视频格式: 以下是三种最常用的格式 1. ogg格式:带有Theora视频编码(免费)+Vorbis音频编码的Ogg文件(免费) 支持的浏览器:firefox.chrome.oper ...

  2. HTML5 video视频制作,控制按钮

    HTML5 video视频制作,控制按钮 运用html5 vedio标签,结合JavaScript完成对播放,暂停,静音,全屏,加速,减速,快进,后退,音量控制,时长控制功能的实现 以下为所写代码 & ...

  3. HTML5 Video 添加字幕,操作简单,不需要剪辑

    HTML5 Video视频支持外挂字幕,文件后缀名是.vtt,称为WebVTT格式,专门的web字幕格式. 使用很简单,用一个<track>元素即可,例如: 官方文档:https://w3 ...

  4. HTML5 Video(视频),HTML 音频(Audio)

    HTML5 Video(视频), 很多站点都会使用到视频. HTML5 提供了展示视频的标准. 检测您的浏览器是否支持 HTML5 视频: 检测 Web站点上的视频 直到现在,仍然不存在一项旨在网页上 ...

  5. html video各种控制命令,HTML5 Video(视频)

    HTML5 Video(视频) 很多站点都会使用到视频. HTML5 提供了展示视频的标准. 检测您的浏览器是否支持 HTML5 视频: 检测 Web站点上的视频 直到现在,仍然不存在一项旨在网页上显 ...

  6. jTemplates异步加载实现与HTML5 video视频开发

    最近做有关Web App有关的项目,为了动态加载相应速度更快,采用了以下几个策略: 1.PHP后台提交自动生成静态列表页面. 2.PHP后台提交自动生成列表页资源/文章的json数据文件,javasc ...

  7. html5 video视频资源保护,HTML5 视频播放 video

    HTML5 中的视频播放 ===================================================================== -------不需要下载任何额外的 ...

  8. iOS wkWebview播放HTML5 video视频 自动全屏问题解决

    HTML5使用video播放视频,限制视频的尺寸,但在ios中出现的全屏问题 使用html5 的video标签播放视频的时候,限制视频的尺寸,在android上是没有问题的,但是在ios上发现,视频没 ...

  9. html5 video视频资源保护,HTML 5 视频(video)

    video 元素支持三种视频格式 IE Firefox Opera Chrome Safari 带有 Theora 视频编码和 Vorbis 音频编码的 Ogg 文件 No 3.5+ 10.5+ 5. ...

最新文章

  1. BGP local-preference MED属性实验
  2. 图解 SQL,这也太形象了吧!
  3. JAVA card 应用开发(二) 在项目添加APPLET
  4. 数据库-数据存储引擎
  5. UVA 1645 - Count(简单DP)
  6. 数据解读京东上最受欢迎的面包
  7. 清新BLOG-CMS博客主题源码
  8. centos6.5安装Chrome
  9. origin如何绘制双y轴曲线_Origin对曲线进行多峰拟合
  10. 入门指南_Spring Boot2: 快速入门指南
  11. Rari Capital于路印L2启动三池流动性挖矿
  12. sql复制表结构和数据_SQL复制表
  13. Mac 不能进入睡眠模式,如何修复?
  14. C实现utf8与gbk互转
  15. swift 中使用 Alamofire+Moya+ObjectMapper,并做了一些功能封装
  16. 从删库到跑路,DBA 如何防止被淘汰?
  17. react 日期怎么格式化_react日期格式化组件
  18. 数据迁移:电脑更换硬盘怎么迁移数据?
  19. 深入浅出TVS瞬态抑态二极管
  20. 一位游戏大厂测试的一些知识分享

热门文章

  1. 初学者需要注意的undefine和null的区别
  2. Maven------打包
  3. winform程序一启动抛出异常--调用目标发生异常
  4. 我们是这样设计对外安全接口的
  5. 微信小程序与传统APP十大优劣对比
  6. Java8中map与flatMap用法
  7. psnr,ssim解读
  8. 初入Python-提升PV数(提升浏览量)
  9. 在这里给大家安利一个好的免费的虚拟主机云服务器使用地址
  10. linux串口返回条件,c – Linux – 串口读取返回EAGAIN