Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

split base64 image into parts

I am trying to split an image file with javascript or jquery into four equal parts. Is it possible to split image like 280px x 60px into four equal parts, and save them encoded with base64 into four variables?

like image 622
Иван Захариев Avatar asked Aug 23 '14 15:08

Иван Захариев


1 Answers

Let's say we have a Base64 image like:

slice split cut image into parts using canvas, HTML5

Let's go get those 4 images!

get image parts from whole image using Canvas, Javascript


  1. Create an in-memory canvas element and prepare it's context:

var canvas = document.createElement('canvas');
var ctx    = canvas.getContext("2d");

  1. Than let's prepare an empty Array to later store our base64 strings:

var parts = [];

  1. Now we need to create a new Image, assign an onload function and set it's src:

var img = new Image();
img.onload = split_4;
img.src = ".......................etc"

  1. The split_4 function:

If the image we need to slice is 260×80 means that we need to set our canvas element to 1/4 that size:

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

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

  1. Paint our canvas 4 times, each time moving our image to new XY positions:

//      0   0    1.iteration
//   -130   0    2.iteration
//      0 -40    3.iteration
//   -130 -40    4.iteration

and on each loop iteration we simply push the retrieved Canvas data into our parts Array:

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

}

Now always inside the onload function you can retrieve all your image parts from array:

console.log( parts ); //  ["...z9d/oBHAAAAAElFTkSuQmCC",
                      //   "...yVhNNW1AAAAAElFTkSuQmCC", 
                      //   "...Q2FoAAAAABJRU5ErkJggg==", 
                      //   "...RQXgXQAAAAASUVORK5CYII="]

To get only (i.e.) the first image use: parts[0];


Example:

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 = "";
img {
  margin: 10px;
}
<div id="test"></div>
like image 82
Roko C. Buljan Avatar answered Oct 19 '22 20:10

Roko C. Buljan