将base64图像拆分为多个部分

Ива*_*иев 5 javascript jquery split image

我试图用javascript或jquery将图像文件分成四个相等的部分.是否可以将像280px x 60px这样的图像分成四个相等的部分,并将它们用base64编码保存为四个变量?

Rok*_*jan 5

假设我们有一个Base64图像,如:

切片使用canvas,HTML5将图像分割成部分

我们去看看那4张照片吧!

使用Canvas,Javascript从整个图像中获取图像部分


  1. 创建一个内存中的canvas元素并准备它的上下文:

var canvas = document.createElement('canvas');
var ctx    = canvas.getContext("2d");
Run Code Online (Sandbox Code Playgroud)

  1. 让我们准备一个空数组以便以后存储我们的base64字符串:

var parts = [];
Run Code Online (Sandbox Code Playgroud)

  1. 现在我们需要创建一个新的 Image,分配一个onload函数并设置它的src:

var img = new Image();
img.onload = split_4;
img.src = ".......................etc"
Run Code Online (Sandbox Code Playgroud)

  1. split_4 功能:

如果我们需要切片的图像是260×80意味着我们需要将canvas元素设置为1/4那个大小:

var w2 = img.width  / 2,  // 130
    h2 = img.height / 2;  // 40

canvas.width  = w2;
canvas.height = h2;   
Run Code Online (Sandbox Code Playgroud)

  1. 每次将我们的图像移动到新的XY位置时,将我们的画布绘制4次:

//      0   0    1.iteration
//   -130   0    2.iteration
//      0 -40    3.iteration
//   -130 -40    4.iteration
Run Code Online (Sandbox Code Playgroud)

在每次循环迭代中,我们只需将检索到的Canvas数据推送到我们的parts数组中:

for(var i=0; i<4; i++){

  var x = (-w2*i) % (w2*2),              // New X position
      y = (h2*i)<=h2? 0 : -h2 ;          // New Y position

  ctx.drawImage(this, x, y, w2*2, h2*2); // imgObject, X, Y, width, height
  parts.push( canvas.toDataURL() );      // ("image/jpeg") for jpeg

}
Run Code Online (Sandbox Code Playgroud)

现在总是在onload函数内部,您可以从数组中检索所有图像部分:

console.log( parts ); //  ["...z9d/oBHAAAAAElFTkSuQmCC",
                      //   "...yVhNNW1AAAAAElFTkSuQmCC", 
                      //   "...Q2FoAAAAABJRU5ErkJggg==", 
                      //   "...RQXgXQAAAAASUVORK5CYII="]
Run Code Online (Sandbox Code Playgroud)

仅获取(即)第一个图像使用: parts[0];


例:

var canvas = document.createElement('canvas'), // In memory canvas
    ctx = canvas.getContext("2d"),
    parts = [], // to push into oud base64 strings
    img = new Image();

function split_4() {

  var w2 = img.width  / 2,
      h2 = img.height / 2;

  for (var i = 0; i < 4; i++) {

    var x = (-w2 * i) % (w2 * 2),
      y = (h2 * i) <= h2 ? 0 : -h2;

    canvas.width = w2;
    canvas.height = h2;

    ctx.drawImage(this, x, y, w2 * 2, h2 * 2); // img, x, y, w, h
    parts.push(canvas.toDataURL()); // ("image/jpeg") for jpeg

    //>> JUST FOR DEMO
    var slicedImage = document.createElement("img")
    slicedImage.src = parts[i];
    var div = document.getElementById("test");
    div.appendChild(slicedImage);
    //<< JUST FOR DEMO
  }
  console.log(parts);
};

img.onload = split_4;
img.src = "";
Run Code Online (Sandbox Code Playgroud)
img {
  margin: 10px;
}
Run Code Online (Sandbox Code Playgroud)
<div id="test"></div>
Run Code Online (Sandbox Code Playgroud)