如何使用 JavaScript 检查 Chrome 中正在使用网络摄像头

r n*_* ne 3 html javascript webcam getusermedia

如果在 Chrome 中使用网络摄像头,则该页面的选项卡上会出现一个红点。如果其他页面尝试访问网络摄像头,视频将变黑。我的问题是,它是否能够使用 JavaScript 检查正在使用网络摄像头?如何?

通过使用 navigator.getUserMedia,我尝试了以下代码:

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

navigator.getUserMedia({ audio: true, video: true }, function (stream) {
    var mediaStreamTrack = stream.getVideoTracks()[0];
    if (typeof mediaStreamTrack != "undefined") {
        mediaStreamTrack.onended = function () {alert('Your webcam is busy!')}
    } else errorMessage('Permission denied!');
}, function (e) {alert("Error: " + e.name);});
Run Code Online (Sandbox Code Playgroud)

当页面正在流式传输视频时将代码粘贴到控制台中,我没有收到任何响应。

有任何想法吗?谢谢!

Ale*_*sky 5

尝试使用对象enabledreadyState属性。然后,您可以使用 JavaScript 数组函数,例如遍历轨道并检查是否有任何设置为 true 并且 &&等于字符串“live”:MediaStreamTrack some()enabledreadyState

navigator.getUserMedia = (navigator.getUserMedia ||
  navigator.webkitGetUserMedia ||
  navigator.mozGetUserMedia ||
  navigator.msGetUserMedia);

if (navigator.getUserMedia) {
  navigator.getUserMedia({
      audio: true,
      video: true
    },
    function(stream) {
      // returns true if any tracks have active state of true
      var result = stream.getVideoTracks().some(function(track) {
        return track.enabled && track.readyState === 'live';
      });

      if (result) {
        alert('Your webcam is busy!');
      } else {
        alert('Not busy');
      }
    },
    function(e) {
      alert("Error: " + e.name);
    });
}
Run Code Online (Sandbox Code Playgroud)

希望这有帮助!

  • 看起来这应该有效。但是,即使摄像头尚未使用,它仍会返回“您的网络摄像头正忙!”。 (2认同)