WebRTC

WebRTC是“網(wǎng)絡(luò)實(shí)時(shí)通信”(Web Real Time Communication)的縮寫察净,它主要用來(lái)讓瀏覽器實(shí)時(shí)獲取和交換視頻揖曾、音頻和數(shù)據(jù)军俊。

WebRTC共分三個(gè)API多矮。

MediaStream(又稱getUserMedia)

RTCPeerConnection

RTCDataChannel

getUserMedia主要用于獲取視頻和音頻信息氯析,后兩個(gè)API用于瀏覽器之間的數(shù)據(jù)交換缎岗。

首先静尼,檢查瀏覽器是否支持getUserMedia方法。

navigator.getUserMedia ||(navigator.getUserMedia= navigator.mozGetUserMedia ||? navigator.webkitGetUserMedia ||navigator.msGetUserMedia);

if(navigator.getUserMedia) {

//do something

}else{

console.log('your browser not support getUserMedia');

}

Chrome21、Opera 18和Firefox 17支持該方法鼠渺,目前IE還不支持鸭巴,上面代碼中的msGetUserMedia只是為了確保將來(lái)的兼容。

getUserMedia方法接受三個(gè)參數(shù)拦盹。

getUserMedia(streams, success, error);

含義如下:

streams:表示包括哪些多媒體設(shè)備的對(duì)象

success:回調(diào)函數(shù)鹃祖,獲取多媒體設(shè)備成功時(shí)調(diào)用

error:回調(diào)函數(shù),獲取多媒體設(shè)備失敗時(shí)調(diào)用

用法如下:

navigator.getUserMedia({

video:true,

audio:true}, onSuccess, onError);

上面的代碼用來(lái)獲取攝像頭和麥克風(fēng)的實(shí)時(shí)信息普舆。

如果網(wǎng)頁(yè)使用了getUserMedia恬口,瀏覽器就會(huì)詢問(wèn)用戶,是否許可提供信息沼侣。如果用戶拒絕祖能,就調(diào)用回調(diào)函數(shù)onError。

發(fā)生錯(cuò)誤時(shí)蛾洛,回調(diào)函數(shù)的參數(shù)是一個(gè)Error對(duì)象养铸,它有一個(gè)code參數(shù),取值如下:

PERMISSION_DENIED:用戶拒絕提供信息轧膘。

NOT_SUPPORTED_ERROR:瀏覽器不支持指定的媒體類型钞螟。

MANDATORY_UNSATISHIED_ERROR:指定的媒體類型未收到媒體流。

2 展示攝像頭圖像

將用戶的攝像頭拍攝的圖像展示在網(wǎng)頁(yè)上扶供,需要先在網(wǎng)頁(yè)上放置一個(gè)video元素筛圆。圖像就展示在這個(gè)元素中。

<video? ? id="webcam">? </video>

然后椿浓,用代碼獲取這個(gè)元素太援。

functiononSuccess(stream) {

var? video = document.getElementById('webcam');//more code

}

最后,將這個(gè)元素的src屬性綁定數(shù)據(jù)流扳碍,攝像頭拍攝的圖像就可以顯示了提岔。

functiononSuccess(stream) {

var?? video = document.getElementById('webcam');

if(window.URL) {

video.src=window.URL.createObjectURL(stream);

}else{

video.src=stream;

}

video.autoplay=true;???? //or video.play();

}

它的主要用途是讓用戶使用攝像頭為自己拍照。

3笋敞、實(shí)時(shí)數(shù)據(jù)交換

WebRTC的另外兩個(gè)API碱蒙,RTCPeerConnection用于瀏覽器之間點(diǎn)對(duì)點(diǎn)的連接,RTCDataChannel用于點(diǎn)對(duì)點(diǎn)的數(shù)據(jù)通信夯巷。

RTCPeerConnection帶有瀏覽器前綴赛惩,Chrome瀏覽器中為webkitRTCPeerConnection,F(xiàn)irefox瀏覽器中為mozRTCPeerConnection趁餐。Google維護(hù)一個(gè)函數(shù)庫(kù)adapter.js喷兼,用來(lái)抽像掉瀏覽器之間的差異。

var? dataChannelOptions ={

ordered:false,//do not guarantee order

maxRetransmitTime: 3000,//in milliseconds

};

var? peerConnection =newRTCPeerConnection();

//Establish your peer connection using your signaling channel here

var?? dataChannel =peerConnection.createDataChannel("myLabel", dataChannelOptions);

dataChannel.onerror=function(error) {

console.log("Data Channel Error:", error);

};

dataChannel.onmessage=function(event) {

console.log("Got Data Channel Message:", event.data);

};

dataChannel.onopen=function() {

dataChannel.send("Hello World!");

};

dataChannel.onclose=function() {

console.log("The Data Channel is Closed");

};


原網(wǎng)址:http://www.cnblogs.com/jscode/p/3601648.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末后雷,一起剝皮案震驚了整個(gè)濱河市季惯,隨后出現(xiàn)的幾起案子吠各,更是在濱河造成了極大的恐慌,老刑警劉巖勉抓,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贾漏,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡藕筋,警方通過(guò)查閱死者的電腦和手機(jī)纵散,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)念逞,“玉大人困食,你說(shuō)我怎么就攤上這事◆岢校” “怎么了硕盹?”我有些...
    開封第一講書人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)叨咖。 經(jīng)常有香客問(wèn)我瘩例,道長(zhǎng),這世上最難降的妖魔是什么甸各? 我笑而不...
    開封第一講書人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任垛贤,我火速辦了婚禮,結(jié)果婚禮上趣倾,老公的妹妹穿的比我還像新娘聘惦。我一直安慰自己,他們只是感情好儒恋,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開白布善绎。 她就那樣靜靜地躺著,像睡著了一般诫尽。 火紅的嫁衣襯著肌膚如雪禀酱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,441評(píng)論 1 310
  • 那天牧嫉,我揣著相機(jī)與錄音剂跟,去河邊找鬼。 笑死酣藻,一個(gè)胖子當(dāng)著我的面吹牛曹洽,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播辽剧,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼衣洁,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了抖仅?” 一聲冷哼從身側(cè)響起坊夫,我...
    開封第一講書人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎撤卢,沒(méi)想到半個(gè)月后环凿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡放吩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年智听,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片渡紫。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡到推,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出惕澎,到底是詐尸還是另有隱情莉测,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布唧喉,位于F島的核電站捣卤,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏八孝。R本人自食惡果不足惜董朝,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望干跛。 院中可真熱鬧子姜,春花似錦、人聲如沸楼入。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)浅辙。三九已至扭弧,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間记舆,已是汗流浹背鸽捻。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留泽腮,地道東北人御蒲。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像诊赊,于是被迫代替她去往敵國(guó)和親厚满。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容