博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
audio和video元素
阅读量:6007 次
发布时间:2019-06-20

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

前面的话

  HTML5新增了两个与媒体相关的标签,让开发人员不必依赖任何插件就能在网页中嵌入跨浏览器的音频和视频内容,这两个标签是<audio>和<video>,且不被IE8-浏览器支持

    以视频文件举例,它包含了音频轨道、视频轨道和其他一些元数据(封面、标题、子标题、字幕等)

HTML元素

  使用这两个元素至少要在标签中包含src属性。位于开始和结束标签之间的任何内容都将作为后备内容,在浏览器不支持这两个媒体元素的情况下显示

<audio>

autoplay         自动播放controls         显示控件loop             循环播放preload          音频在页面加载时进行加载,并预备播放(若使用autoplay,则忽略该属性)src              要播放的音频的URL

  [注意]<audio>元素不支持播放wma格式的文件

  <演示框>点击下列相应属性值可进行演示

 

<video>

autoplay            自动播放controls            显示控件height            播放器高度width             播放器宽度loop                循环播放preload             视频在页面加载时进行加载,并预备播放(若使用autoplay,则忽略该属性)preload="none"     //当页面加载后不载入视频preload="auto"     //当页面加载后载入整个视频preload="meta"     //当页面加载后只载入元数据src                 要播放的视频的URLposter            规定视频下载时显示的图像,或者在用户点击播放按钮前显示的图像

  <演示框>点击下列相应属性值可进行演示

 

<source>

  为<video>和<audio>提供媒介资源

media     规定媒体资源的类型(没有浏览器支持)src      规定媒体文件的URLtype      规定媒体资源的MIME类型

  常用类型

    视频 [1]video/ogg [2]video/mp4 [3]video/webm

    音频 [1]audio/ogg [2]audio/mpeg

  使用<audio>和<video>至少要在标签中包含src属性。位于开始和结束标签之间的任何内容都将作为后备内容,在浏览器不支持这两个媒体元素的情况下显示

  因为并非所有浏览器都支持所有媒体格式,所以可以指定多个不同的媒体来源。为此,不用在标签中指定src属性,而是使用一个或多个<source>元素

   因为并非所有浏览器都支持<audio>和<video>标签,所以更好的解决办法是有备选内容

 

<track>

  <track>元素被当作媒体元素—<audio><video>的子元素来使用。它允许指定计时字幕(或者基于事件的数据),例如自动处理字幕

  track 给媒体元素添加的数据的类型在kind属性中设置,属性值可以是 subtitlescaptionsdescriptionschapters 或 metadata。该元素指向当用户请求额外的数据时浏览器公开的包含定时文本的源文件。一个media元素的任意两个track子元素不能有相同的 kind、srclang和 label属性

【default】

  default属性规定该轨道是默认的,假如没有选择任何轨道

【kind】

  kind属性表示轨道属于什么文本类型

captions     该轨道定义将在播放器中显示的简短说明chapters      该轨道定义章节,用于导航媒介资源descriptions   该轨道定义描述,用于通过音频描述媒介的内容,假如内容不可播放或不可见metadata      该轨道定义脚本使用的内容subtitles     该轨道定义字幕,用于在视频中显示字幕

【label】

  label属性表示轨道的标签或标题

【url】

  URL属性表示字幕文件的URL

【srclang】

  srclang属性表示轨道的语言,若 kind 属性值是 "subtitles",则该属性必需的。中文为"zh",英文为"en"

  字幕文件书写格式如下所示,注意,毫秒位的3个0不能省略

WEBVTT100:00:01.000 --> 00:00:08.000欢迎来到小火柴的个人网站

API

  HTML5 DOM为<audio>和<video>元素提供了方法、属性和事件

方法

1、canPlayType()

  检测浏览器是否能播放指定的音频或视频类型,返回值为下列之一:

'probable':浏览器最可能支持该类型'maybe':浏览器也许支持该类型'':浏览器不支持该类型
//常用值video/oggvideo/mp4video/webmaudio/mpegaudio/oggaudio/mp4video/ogg;codecs="theora,vorbis"video/mp4;codecs="avc1.4D401E,mp4a.40.2"video/webm;codecs="vp8.0,vorbis"audio/ogg;codecs="vorbis"audio/mp4;codecs="mp4a.40.5"

2、load()

  重新加载音频或视频元素,用于在更改src来源或其他设置后对音频或视频元素进行更新

3、play()

  开始播放音频或视频

4、pause()

  暂停当前播放的音频或视频

  <演示框>点击下列相应属性值可进行演示

 

属性

  [注意]所有属性中,只有videoWidth和videoHeight是立即可用的,在音视频的元数据加载后,其他属性才可用

【只读】

1、buffered

buffered.length//获取已缓冲范围的数量buffered.start(index)//获取某个已缓冲范围的开始位置buffered.end(index)//获取某个已缓冲范围的结束位置buffered.end(0)//获取当前已缓冲的秒数

2、currentSrc

  返回当前音频或视频的URL

3、ended

  返回音频或视频是否已结束

4、duration

  返回当前音频或视频的长度(以秒计),如果未设置则返回NaN

5、networkState

  返回音频或视频当前网络状态

networkState:0(尚未初始化)networkState:1(已选取资源,但并未使用网络)networkState:2(正在下载数据)networkState:3(未找到资源来源)

6、paused

  返回音频或视频是否已暂停

paused:true;(已暂停)paused:false;(未暂停)

7、played

  已播范围是指音频或视频的时间范围。如果用户在音频或视频中跳跃,会获得多个播放范围

played.length(获得音频或视频已播放范围的数量)played.start(index)(获得某个已播范围的开始位置)played.end(index)(获得某个已播范围的结束位置)

  [注意]首段已播范围的下标是0

8、readyState

  返回音频或视频的当前就绪状态

readyState:0(没有关于音频或视频是否就绪的信息)readyState:1(关于音频或视频就绪的元数据)readyState:2(关于当前播放位置的数据是可用的,但没有足够的数据来播放下一帧)readyState:3(当前及至少下一帧的数据是可用的)readyState:4(可用数据足以开始播放)

9、seekable

  返回可寻址范围,可寻址范围是指用户在视频或音频中可寻址(移动播放位置)的时间范围。对于流视频,通常可以寻址到视频中的任何位置,即使其尚未完成缓冲

seekable.length(获得音频或视频中可寻址范围的数量)seekable.start(index)(获得可寻址范围的开始位置)seekable.end(index)(获得可寻址范围的结束位置)

10、seeking

seeking:true(用户正在寻址)seeking:false(用户没有在寻址)

可读写】

1、autoplay

autoplay:false(默认,不自动播放)autoplay:true(自动播放)

2、controls

controls:false(默认,不显示控件)controls:true(显示控件)

3、crossOrigin

  设置或返回CORS设置

4、currentTime

  设置或返回音频或视频的当前位置(以秒计)

5、defaultMuted(只有chrome支持)

defaultMuted:true(初始静音)defaultMuted:false(默认,初始不静音)
audio.defaultMuted = true;

6、muted

muted:true(静音)muted:false(不静音)

7、defaultPlaybackRate

defaultPlaybackRate:1(正常速度)defaultPlaybackRate:0.5(半速)defaultPlaybackRate:2(倍速)defaultPlaybackRate:-1(向后正常速度)defaultPlaybackRate:-0.5(向后半速)
var audio = document.getElementById('audio');setTimeout(function(){    audio.defaultPlaybackRate = 0.5;    audio.load();    },1000);

8、playbackRate

playbackRate:1(正常速度)playbackRate:0.5(半速)playbackRate:2(倍速)playbackRate:-1(向后正常速度)playbackRate:-0.5(向后半速)

9、loop

loop:true(循环播放)loop:false(默认,不循环播放)

10、preload

  设置或返回是否在页面加载后立即加载音频或视频

preload:auto;(一旦页面加载,则开始加载音频或视频)preload:metadata;(当页面加载后仅加载音频或视频的元数据)preload:none;(页面加载后不加载音频或视频)

  [注意]当设置autoplay时,该属性无效

11、src

  设置或返回音频或视频的当前来源

12、volume

  设置或返回音频或视频的当前音量

volume(取得为0-1,0为静音,1为最大,默认为1)

 

事件

  当音频或视频正在加载过程中,会依次发生以下事件:

loadstart:提示浏览器开始寻找指定的音频或视频progress:提示浏览器正在下载指定的音频或视频durationchange:提示音频或视频的时长已改变loadedmetadata:提示音频或视频的元数据已加载loadeddata:提示音频或视频的当前帧已加载,但没有足够数据播放下一帧canplay:提示浏览器能够开始播放指定的音频或视频canplaythrough:提示音频或视频能够不停顿地一直播放progress:提示浏览器正在下载指定的音频或视频

  影响音频或视频数据加载的事件有以下几个:

abort:在音频或视频终止加载时触发error:在音频或视频加载发生错误时触发stalled:在浏览器尝试获取媒体数据,但数据不可用时触发suspend:在音频或视频数据被阻止加载时触发(可以是完成加载后触发,或者因为被暂停) empted:在发生故障并且文件突然不可用时触发

  音频或视频控制按钮发生改变时触发以下事件:

play:音频或视频文件已经就绪可以开始播放时触发playing:音频或视频已开始播放时触发ended:音频或视频文件播放完毕后触发pause:音频或视频文件暂停时触发ratechange:播放速度改变进触发seeked:指示定位已结束时触发seeking:正在进行指示定位时触发timeupdate:播放位置改变时触发[注意:播放和调整指示定位时都会触发]volumechange:音量改变时触发waiting:需要缓冲下一帧而停止时触发

 

audio专有

  <audio>元素在一个原生的javascript构造函数Audio,可以在任何时候播放音频。Audio和Image很像,但Audio不用像Image那样必须插入到文档中,只要创建一个新实例,并传入音频源文件即可

var audio = new Audio('test.mp3');

  特别注意的是,IOS不能直接使用oncanplaythrough事件,需要添加audio.load()方法,否则该事件不生效

 

转载于:https://www.cnblogs.com/xiaohuochai/p/5064854.html

你可能感兴趣的文章
Spring.Net+NHibenate+Asp.Net mvc +ExtJs 系列 5 ----asp.net MVC+Extjs
查看>>
VS技巧 使用Visual Studio Icon Patcher将2010的图片注入到2012中
查看>>
[浪子学编程][MS Enterprise Library]ObjectBuilder之创建策略祥解(二)
查看>>
PowerDesigner中NAME和COMMENT的互相转换,需要执行语句
查看>>
如何用CRegKey类来操作注册表
查看>>
图片裁剪 PhotoCropper
查看>>
通过修改 LayoutInflater,全局替换字体!!!
查看>>
UML类图
查看>>
在手机上玩魔兽争霸2
查看>>
Node.js 向一个文件添加内容
查看>>
sphinx是支持结果聚类的——WHERE、ORDER BY和GROUP BY
查看>>
ASP.NET 中设置路径的三种方式
查看>>
EBS使用 Distributed AD在多个节点并行adpatch
查看>>
windows添加和删除服务
查看>>
多年前写的一个ASP.NET网站管理系统,到现在有些公司在用
查看>>
关于云栖,有点无语的几个地方,管理能不能管?
查看>>
Windows线程的同步与互斥
查看>>
iOS:百度长语音识别具体的封装:识别、播放、进度刷新
查看>>
内核随记(三)--同步(1)【转】
查看>>
C#进阶系列——MEF实现设计上的“松耦合”(四):构造函数注入
查看>>