保存文件夹上本地计算机上的摄像头捕获的图像

时间:2016-01-29 14:45:08

标签: javascript jquery html5 camera

我正在使用HTML5输入从相机拍摄照片,

<input id="cameraInput" type="file" accept="image/*;capture=camera"></input>

并在blob中使用图像:,使用以下javascript,

var mobileCameraImage = function() {
    var that = this
        ;
      $("#cameraInput").on("change", that.sendMobileImage);
      if (!("url" in window) && ("webkitURL" in window)) {
        window.URL = window.webkitURL;
      }
});

var sendMobileImage = function( event ) {
    var that = this;
      if (event.target.files.length == 1 && event.target.files[0].type.indexOf("image/") == 0) {
          var capturedImage = URL.createObjectURL(event.target.files[0])
              ;

          alert( capturedImage );
      }
});

在这里,我正在获取正确的图像网址,但我面临的问题是将此图像网址发送到服务器,在阅读博客后,我发现由于其本地实例,我无法将Blob:url发送到服务器。有没有人可以帮助将本地计算机上的点击图像保存在文件夹或任何位置,或者帮助我将这个图像URL发送到服务器。

提前致谢。

1 个答案:

答案 0 :(得分:0)

您可能需要每次都通过Ajax提交表单,或者您可以手动上传图片数据。为此,您可以将图像绘制到画布上,然后获取画布数据。

// create an image to receive the data
var img = $('<img>');

// create a canvas to receive the image URL
var canvas = $('<canvas>');
var ctx = canvas[0].getContext("2d");

$("#cameraInput").on("change", function () {
  var capturedImage = URL.createObjectURL(this.files[0]);

  img.attr('src', capturedImage);
  ctx.drawImage(img);

  var imageData = canvas[0].toDataURL("image/png");

  // do something with the image data    
});

或使用FileReader

// only need to create this once
var reader = new FileReader();
reader.onload = function () {
  var imageData = reader.result;

  // do something with the image data
};

$("#cameraInput").on("change", function () {
  reader.readAsDataURL(this.files[0]);
});

然后您可以将该数据上传到服务器。