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


Posted in HTML / CSS onAugust 22, 2018

简介

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实现音频和视频嵌入的方法

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

HTML / CSS 相关文章推荐
纯CSS3实现图片无间断轮播效果
Aug 25 HTML / CSS
纯CSS实现右侧底部悬浮效果(悬浮QQ、微信、微博、邮箱等联系方式)
Apr 24 HTML / CSS
CSS3实现银灰色动画效果的导航菜单代码
Sep 01 HTML / CSS
HTML5+CSS3 诱人的实例:3D立方体旋转动画实例
Dec 30 HTML / CSS
CSS3 创建网页动画实现弹跳球动效果
Oct 30 HTML / CSS
CSS3 Flex 弹性布局实例代码详解
Nov 01 HTML / CSS
HTML5应用之文件上传
Dec 30 HTML / CSS
html5中地理位置定位api接口开发应用小结
Jan 04 HTML / CSS
html5实现微信打飞机游戏
Mar 27 HTML / CSS
利用HTML5的新特点实现图片文件异步上传
May 29 HTML / CSS
Html5 Geolocation获取地理位置信息实例
Dec 09 HTML / CSS
html5手机端页面可以向右滑动导致样式受影响的问题
Jun 20 HTML / CSS
canvas学习和滤镜实现代码
Aug 22 #HTML / CSS
详解html5 postMessage解决跨域通信的问题
Aug 17 #HTML / CSS
HTML5 manifest离线缓存的示例代码
Aug 08 #HTML / CSS
移动端Html5页面生成图片解决方案
Aug 07 #HTML / CSS
详解WebSocket跨域问题解决
Aug 06 #HTML / CSS
canvas实现二维码和图片合成的示例代码
Aug 01 #HTML / CSS
HTML5拖拽功能实现的拼图游戏
Jul 31 #HTML / CSS
You might like
php escape URL编码
2008/12/10 PHP
JavaScript 动态改变图片大小
2009/06/11 Javascript
jquery如何扑捉回车键触发的事件
2014/04/24 Javascript
js换图片效果可进行定时操作
2014/06/09 Javascript
jQuery提示效果代码分享
2014/11/20 Javascript
js实现可兼容IE、FF、Chrome、Opera及Safari的音乐播放器
2015/02/11 Javascript
AngularJS使用ngMessages进行表单验证
2015/12/27 Javascript
jQuery给指定的table动态添加删除行的操作方法
2016/10/12 Javascript
JS禁止查看网页源代码的实现方法
2016/10/12 Javascript
一个极为简单的requirejs实现方法
2016/10/20 Javascript
JS实现获取来自百度,Google,soso,sogou关键词的方法
2016/12/21 Javascript
Angular2使用Angular-CLI快速搭建工程(二)
2017/05/21 Javascript
vue实现全选、反选功能
2020/11/17 Javascript
angular2 ng build部署后base文件路径问题详细解答
2017/07/15 Javascript
解决angular双向绑定无效果,ng-model不能正常显示的问题
2018/10/02 Javascript
在 Angular-cli 中使用 simple-mock 实现前端开发 API Mock 接口数据模拟功能的方法
2018/11/28 Javascript
Vue 动态路由的实现及 Springsecurity 按钮级别的权限控制
2019/09/05 Javascript
three.js利用射线Raycaster进行碰撞检测
2020/03/12 Javascript
详谈vue中router-link和传统a链接的区别
2020/07/22 Javascript
springboot+vue+对接支付宝接口+二维码扫描支付功能(沙箱环境)
2020/10/15 Javascript
python中列表和元组的区别
2017/12/18 Python
Python3实现爬取指定百度贴吧页面并保存页面数据生成本地文档的方法
2018/04/22 Python
Python urllib.request对象案例解析
2020/05/11 Python
python实现经纬度采样的示例代码
2020/12/10 Python
CSS3弹性盒模型开发笔记(三)
2016/04/26 HTML / CSS
HTML+CSS3模拟心的跳动实例代码
2017/09/05 HTML / CSS
three.js模拟实现太阳系行星体系功能
2019/09/03 HTML / CSS
Timberland澳大利亚官网:全球领先的户外品牌
2019/12/10 全球购物
瑞典香水、须后水和美容产品购物网站:Parfym-Klick.se
2019/12/29 全球购物
汇科协同Java笔试题
2012/03/31 面试题
领导的自我鉴定
2013/12/28 职场文书
工程技术员岗位职责
2014/03/02 职场文书
市场开发与营销专业求职信范文
2014/05/01 职场文书
员工三分钟演讲稿
2014/08/19 职场文书
敬老院义诊活动总结
2015/05/07 职场文书
张丽莉观后感
2015/06/16 职场文书