html中canvas怎么把div保存高清图


本文小编为大家详细介绍“html中canvas怎么把div保存高清图”,内容详细,步骤清晰,细节处理妥当,希望这篇“html中canvas怎么把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文件名
  */
  var免费云主机域名saveFile=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;
  }
  })

读到这里,这篇“html中canvas怎么把div保存高清图”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注百云主机行业资讯频道。

相关推荐: Python进制转换和ASCLL转换的方法

这篇文章主要介绍“Python进制转换和ASCLL转换的方法”的相关知识,小编通过免费云主机域名实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python进制转换和ASCLL转换的方法”文章能帮助大家解决问题。进制之间的转换主要是利用十进制…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 10/01 17:38
下一篇 10/01 17:38

相关推荐