另一方面,對於開發者而言,這樣的外掛程式在開發、除錯與維護的難度會比一般的程式還要高,相較於一般的網頁應用程式而言,通常會需要引入許多額外的技術才能達成這樣的需求。
WebRTC 元件是藉由 JavaScript APIs 來進行對等通訊。
實作功能主要區分為三大項:
- MediaStream API(即 getUserMedia)(代表音訊或視訊資料的流串):負責從攝影機與麥克風取得影像與聲音的串流。
- PeerConnection API(可以讓兩個或多個使用者進行網頁對網頁間的通訊):負責連線的建立、資料加密與頻寬管理等。
- DataChannel API(可以做即時遊戲、文字聊天和檔案傳輸等等):負責傳送一般性的資料。
- MediaStream API(即 getUserMedia):
- constraints:各種參數設定的物件。
- successCallback:執行成功的回呼函數(callback function)。
- errorCallback:執行失敗的回呼函數。
此程式透過 constraints 設定只擷取影像(video: true),而不要擷取聲音(audio: false)。其餘兩個Callback函數中則定義了執行成功與失敗時要執行哪些動作,當擷取串流失敗時就會呼叫 errorCallback(),輸出一行錯誤訊息至 console 中,而如果成功了,就會呼叫 successCallback()。successCallback() 函數所傳入的 stream 參數是一個MediaStream,當取得了 MediaStream 這個多媒體串流之後,就直接把它指定給video,這樣就可以讓影像的串流直接顯示在瀏覽器上了。
- 應用:
- Webcam Toy:使用 WebGL 對影像做一些特效處理。
- FaceKat:以人臉位置來操控的小遊戲。
- ASCII Camera:由影像產生 ASCII 影像。
基本上,MediaStream 基本上只有單純的多媒體串流擷取功能,如果要想將串流透過網路傳送出去,跟遠端的電腦進行視訊,就要配合另外一個RTCPeerConnection API 才行。