-2

I want to draw an image on the canvas. it should start with lines and it becomes an image. something like the below image (Right to left transformation example)

enter image description here

Beginning it should be a plane canvas. it should start from lines and eventually, it should become full image with colors. there was a jQuery plugin (which I can't find it now)

Using JS/JQuery is better. If anyone knows which plugin is that, it may also help.

or if we can do this with JS/JQuery is fine.

rakcode
  • 2,256
  • 4
  • 19
  • 44

1 Answers1

2

For this you will need 2 images: the photo and the sketch. I'm working with 2 canvases, one of which can be hidden or not attached to the DOM. But in the next example - for clarity - I have both canvases visibles. Please read the comments in the code.

window.onload = function() {
let ctx = canvas.getContext("2d");
let ctx1 = canvas1.getContext("2d");
let cw = canvas.width  = canvas1.width = 225;
let ch = canvas.height = canvas1.height = 225;

// you draw the photo
ctx.drawImage(box,0,0);
//you "mask" the photo using globalCompositeOperation and a rect filled with a gradient
ctx.globalCompositeOperation = "destination-in";

let grd = ctx.createLinearGradient(cw, 0,0, 0);
     grd.addColorStop(0,"rgba(0,0,0,1)");
     grd.addColorStop(.75,"rgba(0,0,0,0)");

ctx.fillStyle = grd;
ctx.beginPath()
ctx.fillRect(0,0,cw,ch)


////////////The second canvas//////////////

//you draw the sketch
ctx1.drawImage(lines,0,0);
//you "mask" the sketch using globalCompositeOperation and a rect filled with a gradient in the opposite direction
ctx1.globalCompositeOperation = "destination-in";

let grd1 = ctx1.createLinearGradient(0, 0, cw, 0);
     grd1.addColorStop(0,"rgba(0,0,0,1)");
     grd1.addColorStop(.75,"rgba(0,0,0,0)");

ctx1.fillStyle = grd1;
ctx1.beginPath()
ctx1.fillRect(0,0,cw,ch);
//you reset the canvas
ctx1.globalCompositeOperation = "source-over";
//you draw the first canvas over the masked sketch
ctx1.drawImage(canvas,0,0);
}
canvas{border:1px solid}
<canvas id="canvas">
  <img src="" id="box"  />
  
</canvas>
<canvas id="canvas1">  
  
  <img id="lines" src="" />
</canvas>
enxaneta
  • 31,608
  • 5
  • 29
  • 42