WebRTC 暂停和恢复流
WebRTC pause and resume stream
我正在尝试使用 WebRTC 构建一个 Web 应用程序,该应用程序需要在某些事件触发时 pause/resume video/audio 流。我试过 getTracks()[0].stop()
但我不确定如何恢复流。有什么建议吗?谢谢
您应该尝试使用重新协商,我相信差异仍然存在 chrome 和 firefox:
在chrome中,你只需在PeerConnection
对象上调用addStream
或removeStream
来添加/删除流,然后创建和交换sdp
。
在firefox中,没有直接的removeStream
,需要使用RTCRtpSender and addTrack
and removeTrack
methods, you can take a look at
getTracks()[0].stop()
是永久的。
改用getTracks()[0].enabled = false
。取消暂停 getTracks()[0].enabled = true
.
这会将您的视频替换为黑色,将您的音频替换为静音。
试一试(Chrome 使用 https fiddle):
var pc1 = new RTCPeerConnection(), pc2 = new RTCPeerConnection();
navigator.mediaDevices.getUserMedia({ video: true, audio: true })
.then(stream => pc1.addStream(video1.srcObject = stream))
.catch(log);
var mute = () => video1.srcObject.getTracks().forEach(t => t.enabled = !t.enabled);
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.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" height="120" width="160" autoplay muted></video>
<video id="video2" height="120" width="160" autoplay></video><br>
<input type="checkbox" onclick="mute()">mute</input><div id="div"></div>
<script src="https://webrtc.github.io/adapter/adapter-latest.js"></script>
PeerConnections 在此静音状态下基本停止发送数据包,因此效率很高。
我正在尝试使用 WebRTC 构建一个 Web 应用程序,该应用程序需要在某些事件触发时 pause/resume video/audio 流。我试过 getTracks()[0].stop()
但我不确定如何恢复流。有什么建议吗?谢谢
您应该尝试使用重新协商,我相信差异仍然存在 chrome 和 firefox:
在chrome中,你只需在
PeerConnection
对象上调用addStream
或removeStream
来添加/删除流,然后创建和交换sdp
。在firefox中,没有直接的
removeStream
,需要使用RTCRtpSender andaddTrack
andremoveTrack
methods, you can take a look at
getTracks()[0].stop()
是永久的。
改用getTracks()[0].enabled = false
。取消暂停 getTracks()[0].enabled = true
.
这会将您的视频替换为黑色,将您的音频替换为静音。
试一试(Chrome 使用 https fiddle):
var pc1 = new RTCPeerConnection(), pc2 = new RTCPeerConnection();
navigator.mediaDevices.getUserMedia({ video: true, audio: true })
.then(stream => pc1.addStream(video1.srcObject = stream))
.catch(log);
var mute = () => video1.srcObject.getTracks().forEach(t => t.enabled = !t.enabled);
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.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" height="120" width="160" autoplay muted></video>
<video id="video2" height="120" width="160" autoplay></video><br>
<input type="checkbox" onclick="mute()">mute</input><div id="div"></div>
<script src="https://webrtc.github.io/adapter/adapter-latest.js"></script>
PeerConnections 在此静音状态下基本停止发送数据包,因此效率很高。