2016-04-24 3 views
5

私は現在、WebRTCを使用してVoIPに取り組んでいます。これはJavaScriptで書かれたUWPアプリケーションになります。RTCPeerConnectionはMicrosoft Edgeで動作しますか?

ここでは、Microsoft Edgeのhttps://webrtc.github.io/samplesのサンプルをテストすることで動作するかどうかを確認しようとしています。

RTCPeerConnectionを除いて正常に動作することがわかります。

たとえば、Edgeでhttps://webrtc.github.io/samples/src/content/peerconnection/audioを開いたときに、コールボタンをクリックしたときにgetUserMedia() error: NotFoundErrorと表示されました。 Chromeではうまく動作します。私はhttps://apprtc.appspot.comをしようとしたとき

別の例は、それがどのように私はそれを修正する必要があり、だから、私に

Messages: 
Error getting user media: null 
getUserMedia error: Failed to get access to local media. Error name was NotFoundError. Continuing without sending a stream. 
Create PeerConnection exception: InvalidAccessError 

Version:  
gitHash: c135495bc71e5da61344f098a8209a255f64985f 
branch:  master 
time:  Fri Apr 8 13:33:05 2016 +0200 

を与えていますか? Adapter.jsとも呼ばれます。私はそれが必要なすべてを許可します。

また、このプロジェクトではWebRTCを使用しないでください。もしそうなら、私は何を使うべきですか?

乾杯!

+0

あなたのカム/マイクの問題のようです。 navigator.mediaDevices.enumerateDevicesの出力を確認します。 [このデモ](https://webrtc.github.io/samples/src/content/devices/input-output/)を使用して、 –

答えて

9

Microsoft Edgeは、より包括的なRTCPeerConnectionオブジェクトを持たないWebRTCのより低レベルの分散型の従兄弟であるORTCを実装しています。

しかし、おめでとうのは公式のWebRTCポリフィルであるadapter.jsがEdge上でRTCPeerConnectionをシムしていることです.WebRTCをすべてのブラウザで同じ方法で使用できるはずです。

たとえば、このデモはEdge、Firefox、Chromeで動作します。

var pc1 = new RTCPeerConnection(), pc2 = new RTCPeerConnection(); 
 

 
navigator.mediaDevices.getUserMedia({ video: true, audio: true }) 
 
    .then(stream => pc1.addStream(video1.srcObject = stream)) 
 
    .catch(log); 
 

 
var add = (pc, can) => can && pc.addIceCandidate(can).catch(log); 
 
pc1.onicecandidate = e => add(pc2, e.candidate); 
 
pc2.onicecandidate = e => add(pc1, e.candidate); 
 

 
pc2.onaddstream = e => video2.srcObject = e.stream; 
 
pc1.oniceconnectionstatechange = e => log(pc1.iceConnectionState); 
 
pc1.onnegotiationneeded = e => 
 
    pc1.createOffer().then(d => pc1.setLocalDescription(d)) 
 
    .then(() => pc2.setRemoteDescription(pc1.localDescription)) 
 
    .then(() => pc2.createAnswer()).then(d => pc2.setLocalDescription(d)) 
 
    .then(() => pc1.setRemoteDescription(pc2.localDescription)) 
 
    .catch(log); 
 

 
var log = msg => div.innerHTML += "<br>" + msg;
<video id="video1" width="160" height="120" autoplay muted></video> 
 
<video id="video2" width="160" height="120" autoplay></video><br> 
 
<div id="div"></div> 
 
<script src="https://webrtc.github.io/adapter/adapter-latest.js"></script>

関連する問題