HTML5 video视频字幕的使用和制作方法


Posted in HTML / CSS onMay 03, 2018

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

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

总结

以上所述是小编给大家介绍的HTML5 video视频字幕的使用和制作方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

HTML / CSS 相关文章推荐
css3 响应式媒体查询的示例代码
Sep 25 HTML / CSS
css3中新增的样式使用示例附效果图
Aug 19 HTML / CSS
非常震撼的纯CSS3人物行走动画
Feb 24 HTML / CSS
深入理解css属性的选择对动画性能的影响
Apr 20 HTML / CSS
纯CSS3单页切换导航菜单界面设计的简单实现
Aug 16 HTML / CSS
如何使用html5与css3完成google涂鸦动画
Dec 16 HTML / CSS
html5 canvas-1.canvas介绍(hello canvas)
Jan 07 HTML / CSS
使用HTML5技术开发一个属于自己的超酷颜色选择器
Sep 22 HTML / CSS
HTML5中的autofocus(自动聚焦)属性介绍
Apr 23 HTML / CSS
html5绘制时钟动画
Dec 15 HTML / CSS
HTML5实现多张图片上传功能
Mar 11 HTML / CSS
HTML文本属性&amp;颜色控制属性的实现
Dec 17 HTML / CSS
html5调用摄像头功能的实现代码
May 07 #HTML / CSS
探究 canvas 绘图中撤销(undo)功能的实现方式详解
May 17 #HTML / CSS
详解canvas在圆弧周围绘制文本的两种写法
May 22 #HTML / CSS
HTML5 device access 设备访问详解
May 24 #HTML / CSS
html5-canvas中使用clip抠出一个区域的示例代码
May 25 #HTML / CSS
基于 HTML5 的 WebGL 3D 版俄罗斯方块的示例代码
May 28 #HTML / CSS
HTML5探秘:用requestAnimationFrame优化Web动画
Jun 03 #HTML / CSS
You might like
150kHz到30Mhz完全冲浪手册
2020/03/20 无线电
实用函数10
2007/11/08 PHP
javascript 延迟加载技术(lazyload)简单实现
2011/01/17 Javascript
javascript的数组和常用函数详解
2014/05/09 Javascript
js使用for循环查询数组中是否存在某个值
2014/08/12 Javascript
Prototype框架详解
2015/11/25 Javascript
JavaScript类型检测之typeof 和 instanceof 的缺陷与优化
2016/01/13 Javascript
在其他地方你学不到的jQuery小贴士和技巧(欢迎收藏)
2016/01/20 Javascript
原生js实现class的添加和删除简单代码
2016/07/12 Javascript
Angular实现的自定义模糊查询、排序及三角箭头标注功能示例
2017/12/28 Javascript
vue小白入门教程
2018/04/02 Javascript
vue 列表页跳转详情页获取id以及详情页通过id获取数据
2019/03/27 Javascript
一些手写JavaScript常用的函数汇总
2019/04/16 Javascript
js实现图片上传到服务器和回显
2020/01/19 Javascript
node.JS路径解析之PATH模块使用方法详解
2020/02/06 Javascript
[02:30]DOTA2英雄基础教程 暗影恶魔
2013/12/17 DOTA
[56:42]VP vs RNG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
编写Python脚本来实现最简单的FTP下载的教程
2015/05/04 Python
Python 闭包的使用方法
2017/09/07 Python
用TensorFlow实现戴明回归算法的示例
2018/05/02 Python
Python实现求一个集合所有子集的示例
2018/05/04 Python
python中dict字典的查询键值对 遍历 排序 创建 访问 更新 删除基础操作方法
2018/09/13 Python
对numpy中向量式三目运算符详解
2018/10/31 Python
python DataFrame 取差集实例
2019/01/30 Python
python基于opencv检测程序运行效率
2019/12/28 Python
python numpy实现rolling滚动案例
2020/06/08 Python
捷克鲜花配送:Florea.cz
2018/10/29 全球购物
图库照片、免版税图片、矢量艺术、视频片段:Depositphotos
2019/08/02 全球购物
外贸业务员求职自荐信分享
2013/09/21 职场文书
机关领导查摆四风思想汇报
2014/09/13 职场文书
大学生在校表现评语
2014/12/31 职场文书
个人简历自我评价怎么写
2015/03/10 职场文书
公司优秀员工推荐信
2015/03/24 职场文书
汉语拼音教学反思
2016/02/22 职场文书
IDEA2021.2配置docker如何将springboot项目打成镜像一键发布部署
2021/09/25 Java/Android
动漫APP软件排行榜前十名,半次元上榜,第一款由腾讯公司推出
2022/03/18 杂记