这篇文章将为大家详细讲解有关html2canvas如何实现将div保存图片高清图,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
本文介绍了html2canvas把div保存图片高清图的方法示例,分享给大家,具体如下:

1.选择html2canvas版本(这个版本可以放大倍数保证图片清晰)
默认生成的 canvas 图片在 retina 设备上显示很模糊,处理成 2 倍图能解决这个问题:
varw=$("#code").width();
varh=$("#code").height();
//要将canvas的宽高设置成容器宽高的2倍
varcanvas=document.createElement("canvas");
canvas.width=w*2;
canvas.height=h*2;
canvas.style.width=w+"px";
canvas.style.height=h+"px";
varcontext=canvas.getContext("2d");
//然后将画布缩放,将图像放大两倍画到画布上
context.scale(2,2);
html2canvas(document.querySelector("#code"),{
canvas:canvas,
onrendered:function(canvas){
...
}
});
下载方法:
.on('click','.download',function(){
$('#mycanvas').remove();
var_height=$('.skinReport').height();
//滚到顶部
$('html,body').animate({scrollTop:0});
if(confirm('是否下载肌肤检测报告?'))
{
setTimeout(function(){
varcanvas=document.createElement("canvas"),
w=$('#skinReport').width(),
h=$('#skinReport').height();
canvas.width=w*2;
canvas.height=h*2;
canvas.style.width=w+"px";
canvas.style.height=h+"px";
varcontext=canvas.getContext("2d");
//然后将画布缩放,将图像放大两倍画到画布上
context.scale(2,2);
html2canvas(document.getElementById('skinReport'),{
allowTaint:false,
taintTest:true,
canvas:canvas,
onrendered:function(canvas){
canvas.id="mycanvas";
canvas.style.display='none';
document.body.appendChild(canvas);
//生成base64图片数据
imgData=canvas.toDataURL(type);
//varnewImg=document.createElement("img");
//newImg.src=dataUrl;
//document.body.appendChild(newImg);
//console.log(imgData);
var_fixType=function(type){
type=type.toLowerCase().replace(/jpg/i,'jpeg');
varr=type.match(/png|jpeg|bmp|gif/)[0];
return'image/'+r;
};
//加工imagedata,替换mimetype
imgData=imgData.replace(_fixType(type),'image/octet-stream');
/**
*在本地进行文件保存
*@param{String}data要保存到本地的图片数据
*@param{String}filename文件名
*/
varsaveFile=function(data,filename){
varsave_link=document.createElementNS('http://www.w3.org/1999/xhtml','a');
save_link.href=data;
save_link.download=filename;
varevent=document.createEvent('MouseEvents');
event.initMouseEvent('click',true,false,window,0,0,0,0,0,false,false,false,false,0,null);
save_link.dispatchEvent(event);
};
//下载后的问题名
varfilename=aname+'肌肤检测报告'+(newDate()).getTime()+'.'+type;
//download
saveFile(imgData,filename);
},
width:1512,
height:15000
})
},2500)
}
else
{
return;
}
})
关于“html2canvas如何实现将div保存图片高清图”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。