5

我目前正在编写一个应用程序,使用户能够使用 peerJS 通过 webRTC 开始视频通话。现在我希望用户能够决定是否要添加音频,但无需重新启动通话。

正如我所看到的 - 根据这个答案- 无法使用浏览器控制麦克风。假设我在启用视频和音频的情况下开始通话,我可以将合作伙伴端的视频元素静音。我不想那样做。为什么?我想有人可以使用浏览器的开发者控制台并取消静音视频元素,从而在他或她不知情的情况下监视调用者。

所以现在看来​​我必须重新打电话给合作伙伴并激活视频和音频,现在如果用户只想要视频,我将不得不再次打电话。

我的问题:有更好的方法吗?另外,如果接听电话,是否有办法确定它是纯视频通话还是视频和音频通话?

4

2 回答 2

4

我偶然发现了 Mozilla 的这篇博文。有趣的部分从标题“静音音频和视频流”开始。在这里,您将找到以下代码行:

mediaStream.getVideoTracks()[0].enabled = !(mediaStream.getVideoTracks()[0].enabled);

这基本上意味着您可以禁用 Video-Track。事实证明,同样是可能的:

mediaStream.getAudioTracks()[0].enabled = false;

这将使音频流静音。如果这适用于 localStream 像这样:

Participant.prototype.startCall = function(){

     var participant = this;

     var target = participant.callees[0];

     navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;

     navigator.getUserMedia({
          audio: true,
          video: true
     },function(stream){
          console.log("called");
          //IMPORTANT LINE HERE
          stream.getAudioTracks()[0].enabled = false;
          participant.localStream = stream;
          participant.call = participant.peer.call(target, stream);
     },function(error){
          console.log(error);   
     });
};

它似乎禁用了音频流。如您所见,我将 localStream 存储为我的对象的属性,然后可以使用以下方法激活音频流

myObj.localStream.getAudioTracks()[0].enabled = true;

据我判断,您不能在 remoteStream 上执行相同的操作。但我将不得不通过进一步的测试来验证这一点。

于 2014-04-01T17:49:02.687 回答
3

您正在寻找的似乎是一种撤销对麦克风或网络摄像头的访问权限的方法,以便数据流停止,指示灯熄灭,如果重新激活摄像头,则会再次提示用户。

根据W3C WebRTC Spec,您应该能够做到这一点:

脚本可以通过MediaStreamTrack.stop()方法指示轨道不再需要其源。当使用一个源的所有轨道都已停止时,该源的给定权限被撤销并且该源被停止。如果数据是从实时源(例如,麦克风或摄像头)生成的,则用户代理应删除该源的任何活动“直播”指示符。

peerJS API 文档中没有提到 stop() 方法,但您应该能够在浏览器的 WebRTC 实现上调用它,使用传递给 peerJScall()函数的流,我将调用它stream

var s = function(t) {
    t.stop();
}
stream.getAudioTracks().map(s);

这应该会导致浏览器撤销音频访问。

但是,我不会太担心在用户浏览器中留下打开的 WebRTC 连接的安全性。如果有人能够侵入浏览器,他们已经可以访问用户的未加密密码,并且无论如何摄像头指示灯(如果可用)都会亮起。

祝你好运!

于 2014-04-01T16:34:00.990 回答