欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-09 13:30:06
这篇文章主要介绍了HTML5实现音频和视频嵌入的方法的相关资料,原生的支持音频和视频,为HTML5注入了巨大的发展潜力,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随... 18-08-22...

简介

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

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

<object height="200" width="200" data="2_1.swf" >
</object>
<embed src="2_1.mp4" type="">

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

html5支持的音频格式:

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

视频

视频格式:

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

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

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

<audio src="htmls/1.mp3"  controls="controls" loop="loop" preload="auto" >
你的浏览器不支持video元素
</audio>

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

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

audiovideo.html

<!doctype html>
	<html>
	<head>
		<meta charset="utf-8">
		<title>网页放置视频</title>
		<style type="text/css">
		</style>
		<script type="text/javascript" src="js/controlbar.js"></script>
	</head>
	<body>
		<audio src="htmls/1.mp3"  controls="controls" loop="loop" preload="auto" >
			你的浏览器不支持video元素
		</audio>
		<video id="myplayer" width="600" height="400" src="htmls/2_1.mp4" controls="controls" loop="loop" poster="3.jpg">
			你的浏览器不支持audio元素
			<!-- mp4有3种编码,mpg4(xdiv),,mpg4(xvid),avc(h264),
                  只有h264才是公认的mp4标准编码 -->
		</video>
		<div id="progress"></div>
		<!-- 音量控制 -->
		<input id="volume" type="range" min="0" max="1" step="0.1" onchange="volume(this)">
		<!-- 速率和时间进度的信息 -->
		<span id="rate">1</span>fps <span id="info"></span>
		<button onclick="play(this)" id="btn1">播放</button>
		<button onclick="fast()">快进</button>
		<button onclick="slow()">慢进</button>
		<button onclick="prev()">后退</button>
		<button onclick="next()">前进</button>
		<button onclick="muted(this)">静音</button>
	</body>
</html>

显示(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的属性和方法可以实现更复杂的功能。

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

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