javascript - 无法使用我的代码 (html/js/css) 初始化网络摄像头

标签 javascript html css webcam

我试图通过我的 html 使 ebcam 工作,但它不起作用。框架在那里。但我无法让它发挥作用。网络摄像头打不开,甚至没有弹出窗口询问我是否要允许我的 wbcam 打开....

我错过了什么吗? 像一个插件让它工作? o 还是我的代码有错误?

这是 html:

<!doctype html>

<head>
</head>
<body>
<link href="css.css" rel="stylesheet" />
<script src="js.js"></script>

<video id="video"></video>
<button id="startbutton">Take photo</button>
<canvas id="canvas"></canvas>
<img src="http://placekitten.com/g/200/150" id="photo" alt="photo">

</body>

这是CSS:

html {
    background: #111111;
    height: 100%;
    background: linear-gradient( #333, #000);
}
canvas {
    display: none;
}
video, img, #startbutton {
    display: block;
    float: left;
    border: 10px solid #fff;
    border-radius: 10px;
}
#startbutton {
    background: green;
    border: none;
    color: #fff;
    margin: 100px 20px 20px 20px;
    padding: 10px 20px;
    font-size: 20px;
}
#container {
    overflow: hidden;
    width: 880px;
    margin: 20px auto;
}/

这是js:

// JavaScript Document
(function() {

  var streaming = false,
      video        = document.querySelector('#video'),
      cover        = document.querySelector('#cover'),
      canvas       = document.querySelector('#canvas'),
      photo        = document.querySelector('#photo'),
      startbutton  = document.querySelector('#startbutton'),
      width = 200,
      height = 0;

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

  navigator.getMedia(
    { 
      video: true, 
      audio: false 
    },
    function(stream) {
      if (navigator.mozGetUserMedia) { 
        video.mozSrcObject = stream;
      } else {
        var vendorURL = window.URL || window.webkitURL;
        video.src = vendorURL ? vendorURL.createObjectURL(stream) : stream;
      }
      video.play();
    },
    function(err) {
      console.log("An error occured! " + err);
    }
  );

  video.addEventListener('canplay', function(ev){
    if (!streaming) {
      height = video.videoHeight / (video.videoWidth/width);
      video.setAttribute('width', width);
      video.setAttribute('height', height);
      canvas.setAttribute('width', width);
      canvas.setAttribute('height', height);
      streaming = true;
    }
  }, false);

  function takepicture() {
    canvas.width = width;
    canvas.height = height;
    canvas.getContext('2d').drawImage(video, 0, 0, width, height);
    var data = canvas.toDataURL('image/png');
    photo.setAttribute('src', data);
  }

  startbutton.addEventListener('click', function(ev){
      takepicture();
    ev.preventDefault();
  }, false);

})();

最佳答案

它确实要求访问并显示我的网络摄像头: http://fiddle.jshell.net/e4Hf9/

不知道这里发生了什么,也许你有缓存问题。尝试隐身/隐私浏览到您的问题页面

关于javascript - 无法使用我的代码 (html/js/css) 初始化网络摄像头,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20385015/

相关文章:

javascript - vue.js、vue-router 和参数/属性

html - 当我突破 767px 宽度时,Bootstrap 3 会删除填充/边距

javascript - 如何在自身内部渲染 React 组件

javascript - 如何离线保存html表单的状态并允许加载

html - <table> 中的自定义单元格/边框间距

asp.net - 如何确保在单击 sun-menu 时顶级菜单项的 CSS 类已选中?

CSS - 类型标签的选择器?

html - Dropbox 如何使他们的透明 PNG + 不透明度在 IE 上工作?

javascript - 从 PHP 页面获取值到另一个页面问题中的 Javascript

javascript - 带有ajax错误消息的表单提交