首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对媒体和数据都可以使用相同的RTCPeerConnection吗?

对媒体和数据都可以使用相同的RTCPeerConnection吗?
EN

Stack Overflow用户
提问于 2016-06-27 18:05:50
回答 1查看 374关注 0票数 0

我是webrtc的新手,我不太清楚我是否可以使用RTCPeerConnection对象(我用它正确地传输媒体)来创建数据通道,或者我必须为数据传输做一个单独的信令。

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-27 23:14:28

是(在Chrome中使用https小提琴 ):

代码语言:javascript
复制
var pc1 = new RTCPeerConnection(), pc2 = new RTCPeerConnection();

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

var dc1, dc2;
pc2.ondatachannel = e => {
  dc2 = e.channel;
  dc2.onopen = () => log("Chat!");
  dc2.onmessage = e => log("> " + e.data);
};

var start = () => navigator.mediaDevices.getUserMedia({ video: true })
  .then(stream => {
    pc1.addStream(video1.srcObject = stream);
    dc1 = pc1.createDataChannel("chat");
    dc1.onopen = () => (chat.disabled = false, chat.select());
    return pc1.createOffer();
  })
  .then(offer => pc1.setLocalDescription(offer))
  .then(() => pc2.setRemoteDescription(pc1.localDescription))
  .then(() => pc2.createAnswer())
  .then(answer => pc2.setLocalDescription(answer))
  .then(() => pc1.setRemoteDescription(pc2.localDescription))
  .catch(log);

chat.onkeypress = e => {
  if (e.keyCode != 13) return;
  dc1.send(chat.value);
  chat.value = "";
};

var log = msg => div.innerHTML += "<br>" + msg;
代码语言:javascript
复制
<video id="video1" height="120" width="160" autoplay muted></video>
<video id="video2" height="120" width="160" autoplay></video><br>
<button onclick="start()">Start!</button>
Chat: <input id="chat" disabled></input><br><div id="div"></div>
<script src="https://webrtc.github.io/adapter/adapter-latest.js"></script>

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/38060427

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档