佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > HTML5實(shí)現(xiàn)音頻和視頻嵌入的方法

HTML5實(shí)現(xiàn)音頻和視頻嵌入的方法

熱門標(biāo)簽:百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 阿里云 美圖手機(jī) 硅谷的囚徒呼叫中心 使用U盤裝系統(tǒng) 智能手機(jī) 網(wǎng)站建設(shè) 檢查注冊(cè)表項(xiàng)

簡(jiǎn)介

HTML5未出來(lái)之前,在線的音頻和視頻都是借助Flash或者第三方工具實(shí)現(xiàn)的,現(xiàn)在HTML5也支持了這方面的功能。在一個(gè)支持HTML5的瀏覽器中,不需要安裝任何插件就能播放音頻和視頻。原生的支持音頻和視頻,為HTML5注入了巨大的發(fā)展?jié)摿Α?/p>

html實(shí)現(xiàn)音頻嵌入(傳統(tǒng)方式):這種方式雖然可以實(shí)現(xiàn),但是要瀏覽器支持Flash而且并不能實(shí)現(xiàn)控制,所以要實(shí)現(xiàn)起來(lái)很麻煩。

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

那么也就是說(shuō)HTML5存在一個(gè)很大的問(wèn)題就是兼容性。音頻

HTML5支持的音頻格式:

視頻

視頻格式:

由上可知,HTML5貌似支持的格式有點(diǎn)少哈,所以當(dāng)你發(fā)現(xiàn)用HTML5放置音頻和視頻不顯示時(shí),應(yīng)該就是格式不支持的問(wèn)題。注: MP4有3種編碼,mpg4(xdiv),,mpg4(xvid),avc(h264), 只有h264才是公認(rèn)的MP4標(biāo)準(zhǔn)編碼(在這也是被坑了,其他格式的只有聲音沒(méi)有圖像。)遇到這種問(wèn)題,就用視頻格式轉(zhuǎn)換器,轉(zhuǎn)換一下格式就OK啦。

音頻實(shí)現(xiàn)起來(lái)很簡(jiǎn)單:這里工具條使用了瀏覽器默認(rèn)的工具條。

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


 

視頻雖然也可以使用瀏覽器默認(rèn)的,但無(wú)法實(shí)現(xiàn)私人訂制,所以從學(xué)技術(shù)的角度講,還是要學(xué)習(xí)一下自己做工具實(shí)現(xiàn)功能(audio也可參照此方法)。

audioVideo.html

<!DOCTYPE html>
	<html>
	<head>
		<meta charset="UTF-8">
		<title>網(wǎng)頁(yè)放置視頻</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才是公認(rèn)的MP4標(biāo)準(zhǔn)編碼 -->
		</video>
		<div id="progress"></div>
		<!-- 音量控制 -->
		<input id="volume" type="range" min="0" max="1" step="0.1" onchange="Volume(this)">
		<!-- 速率和時(shí)間進(jìn)度的信息 -->
		<span id="rate">1</span>fps <span id="info"></span>
		<button onclick="Play(this)" id="btn1">播放</button>
		<button onclick="Fast()">快進(jìn)</button>
		<button onclick="Slow()">慢進(jìn)</button>
		<button onclick="Prev()">后退</button>
		<button onclick="Next()">前進(jìn)</button>
		<button onclick="Muted(this)">靜音</button>
	</body>
</html>

顯示(html)與功能實(shí)現(xiàn)(js)分離,由外部導(dǎo)入

ControlBar.js

//使用腳本檢測(cè)瀏覽器的標(biāo)簽支持情況
var support = !!document.createElement("audio").canPlayType;
if (!support) {
	alert("你的瀏覽器不支持本視頻播放");
}
// 定義全局的視頻對(duì)象
var e1 = null;
window.addEventListener("load", function() {
	e1 = document.getElementById("myPlayer");
});
/*前進(jìn):一分鐘 */
function Next() {
	e1.currentTime+=10; //設(shè)置屬性currentTime,快進(jìn)10s
}
/*后退:一分鐘 */
function Prev() {
	e1.currentTime-=10; //設(shè)置屬性currentTime,后退10s
}
/*播放/暫停*/
function Play(e) {
	if(e1.paused){
		e1.play();
		document.getElementById("btn1").innerHTML="暫停"
	}else{
		e1.pause();
		document.getElementById("btn1").innerHTML="播放"
	}
}
/*慢進(jìn):小于等于1時(shí),每次都只減慢0.2的速率;大于1時(shí),每次減1 */
function Slow(){
	if(e1.playbackRate<=1){
		e1.playbackRate-=0.2;
	}else{
		e1.playbackRate-=1;
	}
	document.getElementById("rate").innerHTML=fps2fps(e1.playbackRate);
}
/*慢進(jìn):小于等于1時(shí),每次都只減慢0.2的速率;大于1時(shí),每次減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;
	}
}
/*調(diào)整音量*/
function Volume(e){
	if(e1.muted==true){
		e1.muted=false;
	}
	e1.volume=e.value;
}
/* 進(jìn)度信息:控制進(jìn)度條,并顯示進(jìn)度時(shí)間*/
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);
}
/* 網(wǎng)頁(yè)加載完畢后,把進(jìn)度處理函數(shù)添加至視頻對(duì)象的timeupdate事件中*/
window.addEventListener("load",function(){
	e1.addEventListener("timeupdate",Progress);
});
/*給window.onload事件添加進(jìn)度處理函數(shù)*/
window.addEventListener("load",Progress);

實(shí)現(xiàn)的功能:播放,暫停,快進(jìn),慢進(jìn),前進(jìn),后退,音量控制,進(jìn)度條和時(shí)間顯示。由此可見通過(guò)Audio或Video的屬性和方法可以實(shí)現(xiàn)更復(fù)雜的功能。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:湖北 煙臺(tái) 黃山 山南 通遼 賀州 懷化 湘潭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5實(shí)現(xiàn)音頻和視頻嵌入的方法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    德清县| 抚顺县| 安宁市| 拜泉县| 台东县| 浮山县| 定结县| 黄冈市| 曲沃县| 云南省| 和田县| 安福县| 江北区| 错那县| 泰兴市| 丰城市| 平度市| 宜宾市| 安顺市| 禄丰县| 河池市| 吉安市| 庆元县| 桐城市| 长兴县| 清苑县| 青河县| 牟定县| 德安县| 梅河口市| 丰原市| 固始县| 龙井市| 治多县| 洛阳市| 凤城市| 彰化县| 宁夏| 昌图县| 含山县| 都昌县|