我想使用WebRTC来构建一个Web应用程序,当某些事件触发时需要暂停/恢复视频/音频流。我尝试过getTracks()[0].stop()
,但我不知道如何恢复该流。WebRTC暂停和恢复流
5
A
回答
10
getTracks()[0].stop()
是永久性看一看。
改为使用getTracks()[0].enabled = false
。要取消暂停getTracks()[0].enabled = true
。
这会将您的视频替换为黑色,并将您的音频替换为静音。
试用(使用https fiddle为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 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基本上停留在这个静音状态发送数据包,因此它是高效率的。
1
你应该通过重新谈判,我认为差异仍然存在,它是如何在Chrome和Firefox进行:
在Chrome中,你只需要调用
addStream
或removeStream
的PeerConnection
对象上添加/删除流,然后创建并交换sdp
。在Firefox中,没有直接
removeStream
,你需要使用RTCRtpSender和addTrack
和removeTrack
方法,你可以在this question
相关问题
- 1. 暂停和恢复流
- 2. 暂停和恢复BackgroundWorker
- 3. 暂停和恢复AsyncTasks? (Android)
- 4. 暂停和恢复SKScene
- 5. 暂停和恢复ASINetworkQueue
- 6. 暂停和恢复功能
- 7. Django芹菜工作流暂停/恢复
- 8. Node.js的暂停与恢复的setTimeout流()
- 9. 暂停/恢复jquery .animate()?
- 10. Cocos2d引擎 - 暂停,恢复
- 11. 暂停/恢复线程?
- 12. 暂停/恢复任务
- 13. Android应用暂停恢复
- 14. Android暂停/恢复服务
- 15. lftp暂停和恢复下载
- 16. 安全地暂停和恢复线程
- 17. 如何暂停和恢复Jenkins构建
- 18. 音频录制|暂停和恢复
- 19. 如何暂停和恢复GameLoop?
- 20. “暂停”和“恢复”一个ng-repeat
- 21. 暂停和恢复Foreach循环
- 22. VB.Net暂停和恢复对下一个
- 23. 如何暂停和恢复JavaScript?
- 24. 如何暂停和恢复线程
- 25. 如何暂停和恢复音频
- 26. 倒数计时暂停和恢复
- 27. 暂停和恢复AnimatorSet Api <19
- 28. 如何暂停和恢复UIView动画?
- 29. Android暂停和恢复教程
- 30. Twilio录制:暂停和恢复
最后一句不清楚。 “黑色视频”和“静音”仍然会使用与之前禁用的类似资源(解码/渲染,数据传输等)吗? – JSON
@JSON我已经更新了答案,以澄清它几乎不使用任何资源。我在[这个小提琴](https://jsfiddle.net/ec9ossmu/)中使用统计资料证实了它(需要火狐for spec-stats atm)。感谢抓住,它不清楚。 – jib