HTML5实现音频和视频嵌入,HTML5实现音频和视频嵌入的方法

简介

html5未出来之前,在线的音频和视频都是借助flash或者第三方工具实现的,现在html5也支持了这方面的功能。在一个支持html5的浏览器中,不需要安装任何插件就能播放音频和视频。原生的支持音频和视频,为html5注入了巨大的发展潜力。

html实现音频嵌入(传统方式):这种方式虽然可以实现,但是要浏览器支持flash而且并不能实现控制,所以要实现起来很麻烦。

那么也就是说html5存在一个很大的问题就是兼容性。音频

html5支持的音频格式:

f7826ee7812fc07775e25cfe16359aec.png

视频

视频格式:

123a5dac74cae22580525e0d6bc420b8.png

由上可知,html5貌似支持的格式有点少哈,所以当你发现用html5放置音频和视频不显示时,应该就是格式不支持的问题。注: mp4有3种编码,mpg4(xdiv),,mpg4(xvid),avc(h264), 只有h264才是公认的mp4标准编码(在这也是被坑了,其他格式的只有声音没有图像。)遇到这种问题,就用视频格式转换器,转换一下格式就ok啦。

音频实现起来很简单:这里工具条使用了浏览器默认的工具条。

你的浏览器不支持video元素

e575cc20bdf00f3b6a9fc011a8d134cb.png

视频虽然也可以使用浏览器默认的,但无法实现私人订制,所以从学技术的角度讲,还是要学习一下自己做工具实现功能(audio也可参照此方法)。

audiovideo.html

网页放置视频

你的浏览器不支持video元素

你的浏览器不支持audio元素

1fps

播放

快进

慢进

后退

前进

静音

显示(html)与功能实现(js)分离,由外部导入

controlbar.js

//使用脚本检测浏览器的标签支持情况

var support = !!document.createelement("audio").canplaytype;

if (!support) {

alert("你的浏览器不支持本视频播放");

}

// 定义全局的视频对象

var e1 = null;

window.addeventlistener("load", function() {

e1 = document.getelementbyid("myplayer");

});

/*前进:一分钟 */

function next() {

e1.currenttime+=10; //设置属性currenttime,快进10s

}

/*后退:一分钟 */

function prev() {

e1.currenttime-=10; //设置属性currenttime,后退10s

}

/*播放/暂停*/

function play(e) {

if(e1.paused){

e1.play();

document.getelementbyid("btn1").innerhtml="暂停"

}else{

e1.pause();

document.getelementbyid("btn1").innerhtml="播放"

}

}

/*慢进:小于等于1时,每次都只减慢0.2的速率;大于1时,每次减1 */

function slow(){

if(e1.playbackrate<=1){

e1.playbackrate-=0.2;

}else{

e1.playbackrate-=1;

}

document.getelementbyid("rate").innerhtml=fps2fps(e1.playbackrate);

}

/*慢进:小于等于1时,每次都只减慢0.2的速率;大于1时,每次减1 */

function fast(){

if(e1.playbackrate<1){

e1.playbackrate+=0.2;

}else{

e1.playbackrate+=1;

}

document.getelementbyid("rate").innerhtml=fps2fps(e1.playbackrate);

}

function fps2fps(fps){

if(fps<1){

return fps.tofixed(1);

}else{

return fps;

}

}

/*静音*/

function muted(e){

if(e1.muted){

e1.muted=false;

e.innerhrml="x";

document.getelementbyid("volume").value=e1.volume;

}else{

e1.muted=true;

e.innerhrml="x";

document.getelementbyid("volume").value=0;

}

}

/*调整音量*/

function volume(e){

if(e1.muted==true){

e1.muted=false;

}

e1.volume=e.value;

}

/* 进度信息:控制进度条,并显示进度时间*/

function progress(){

var p1=document.getelementbyid("progress");

p1.style.width=(e1.currenttime/e1.duration)*720+"px";

document.getelementbyid("info").innerhtml=s2time(e1.currenttime)+"/"+s2time(e1.duration);

}

function s2time(s){

var m=parsefloat(s/60).tofixed(0);

s=parsefloat(s%60).tofixed(0);

return (m<10? "0"+m:m)+":"+(s<10?"0"+s:s);

}

/* 网页加载完毕后,把进度处理函数添加至视频对象的timeupdate事件中*/

window.addeventlistener("load",function(){

e1.addeventlistener("timeupdate",progress);

});

/*给window.onload事件添加进度处理函数*/

window.addeventlistener("load",progress);

实现的功能:播放,暂停,快进,慢进,前进,后退,音量控制,进度条和时间显示。由此可见通过audio或video的属性和方法可以实现更复杂的功能。

a6d8a240fde8a2d84fcdd79c63ac5a12.png

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持萬仟网。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值