如何使用JavaScript中的坐标保存图像的一部分

时间:2018-06-25 16:15:06

标签: javascript jquery html image

我有一个表格,里面有这样的图像:

<body>
  <form action="" method="POST" id="canvas">
    <img src="/foo/bar.jpg" width="350" height="350" id="imageId"/>
    <input type="submit" name="submit" value="Label" id='input'>
  </form>
</body>

使用JavaScript,我希望能够使用坐标保存图像的一部分,我正在寻找类似的东西:

Save_Image(x, y, x2, y2, name_of_new_cropped_image_to_be_saved);

是否存在类似的东西?

1 个答案:

答案 0 :(得分:0)

您可以尝试使用画布:

function cropImage(src, x, y, w, h) {
  var canvas = document.createElement("canvas");
  //document.body.appendChild(canvas); // for testing
  var ctx = canvas.getContext("2d");
  canvas.width = w;
  canvas.height = h;
  ctx.fillRect(0, 0, w, h);
  ctx.drawImage(src, -x, -y);
  return {
    save: function(filename) {
      var a = document.createElement("a");
      canvas.toBlob(function(blob) {
        a.href = window.URL.createObjectUrl(blob);
        a.download = filename;
        a.click();
      });
      //console.log(a);
    }
  }
}

var img = document.querySelector("img");
document.getElementById("save").onclick = function () {
  cropImage(img, 50, 20, 100, 80).save("test");
}
body {
  background: black;
  overflow: auto;
}
<img src="">
<!-- need to encode image because of CORS -->
<button id="save">save cropped - 50, 20, 100, 80</button>

不幸的是,Edge不支持HTMLCanvasElement.toBlob()(我使用Edge):(。您可以使用polyfill from MDN。如果我的代码不起作用,请发表评论。toBlob应该可以在带有前缀的IE 10中使用。最低Chrome为50