Convert and Save Canvas Elements to Images in Browsers: A Quick Guide
data:image/s3,"s3://crabby-images/73c25/73c25ffd19523e6af87bf9e8ce8900b734c7d08d" alt="Shivanshu Semwal"
1 min read
Use developer tools to locate the canvas you want to download. Get it's id
attribute, in my case it was pdfCanvas
. Now enter this function in developer tools console:
function downloadCanvasAsImage(name){
// id of canvas element
let canvasId= 'pdfCanvas'
// get the canvas element, you have to change this with the element you want
let canvasImage = document.getElementById(canvasId).toDataURL('image/png');
let xhr = new XMLHttpRequest();
xhr.responseType = 'blob';
xhr.onload = function () {
let a = document.createElement('a');
a.href = window.URL.createObjectURL(xhr.response);
a.download = name + '.png';
a.style.display = 'none';
document.body.appendChild(a);
a.click();
a.remove();
};
xhr.open('GET', canvasImage);
xhr.send();
}
Now use this function to download the image,
let image_name = 'image.png'
downloadCanvasAsImage(image_name)
Here is how it works:
- first
canvasImage
should point to the canvas element in DOM, you can usegetElementById
orgetElementByTags
and then usetoDataURL
to get the URL to download image. - after that it sends a
XMLHttpsRequest
to get the images - the image is then downloaded with name passed as function parameter.
0
Subscribe to my newsletter
Read articles from Shivanshu Semwal directly inside your inbox. Subscribe to the newsletter, and don't miss out.
Written by
data:image/s3,"s3://crabby-images/73c25/73c25ffd19523e6af87bf9e8ce8900b734c7d08d" alt="Shivanshu Semwal"
Shivanshu Semwal
Shivanshu Semwal
Software Developer. Interested in finding innovative solutions to problems.