教你如何给你的头像添加一个好看的国旗

近日朋友圈又火了,听说原因是 @腾讯官网 就能得到一个好看的国庆节头像,那么我们自己动手实现一个吧,教你如何给你的头像添加一个好看的国旗。

创新互联长期为数千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为庐江企业提供专业的成都网站建设、成都网站设计庐江网站改版等技术服务。拥有10年丰富建站经验和众多成功案例,为您定制开发。

由于代码比较简单就不一一介绍了。

 
 
 
  1. var cvs = document.getElementById("cvs"); 
  2. var ctx = cvs.getContext("2d"); 
  3. var exportImage = document.getElementById("export"); 
  4. var img = document.getElementById("img"); 
  5. var hat = "hat6"; 
  6. var canvasFabric; 
  7. var hatInstance; 
  8. var screenWidth = window.screen.width < 500 ? window.screen.width : 300; 
  9.  
  10. function viewer() { 
  11.     var file = document.getElementById("upload").files[0]; 
  12.     console.log(file); 
  13.     var reader = new FileReader; 
  14.     if (file) { 
  15.         reader.readAsDataURL(file); 
  16.         reader.onload = function(e) { 
  17.             img.src = reader.result; 
  18.             img.onload = function() { 
  19.                 img2Cvs(img) 
  20.             } 
  21.         } 
  22.     } else { 
  23.         img.src = "" 
  24.     } 
  25.  
  26. function img2Cvs(img) { 
  27.     cvs.width = img.width; 
  28.     cvs.height = img.height; 
  29.     cvs.style.display = "block"; 
  30.     canvasFabric = new fabric.Canvas("cvs", { 
  31.         width: screenWidth, 
  32.         height: screenWidth, 
  33.         backgroundImage: new fabric.Image(img, { 
  34.             scaleX: screenWidth / img.width, 
  35.             scaleY: screenWidth / img.height 
  36.         }) 
  37.     }); 
  38.     changeHat(); 
  39.     document.getElementById("uploadContainer").style.display = "none"; 
  40.     document.getElementById("uploadText").style.display = "none"; 
  41.     document.getElementById("upload").style.display = "none"; 
  42.     document.getElementById("change").style.display = "block"; 
  43.     document.getElementById("exportBtn").style.display = "block"; 
  44.     document.getElementById("tip").style.opacity = 1 
  45.  
  46. function changeHat() { 
  47.     document.getElementById(hat).style.display = "none"; 
  48.     var hats = document.getElementsByClassName("hide"); 
  49.     hat = "hat" + (+hat.replace("hat", "") + 1) % hats.length; 
  50.     var hatImage = document.getElementById(hat); 
  51.     hatImage.style.display = "block"; 
  52.     if (hatInstance) { 
  53.         canvasFabric.remove(hatInstance) 
  54.     } 
  55.     hatInstance = new fabric.Image(hatImage, { 
  56.         top: 40, 
  57.         left: screenWidth / 3, 
  58.         scaleX: 100 / hatImage.width, 
  59.         scaleY: 100 / hatImage.height, 
  60.         cornerColor: "#0b3a42", 
  61.         cornerStrokeColor: "#fff", 
  62.         cornerStyle: "circle", 
  63.         transparentCorners: false, 
  64.         rotatingPointOffset: 30 
  65.     }); 
  66.     hatInstance.setControlVisible("bl", false); 
  67.     hatInstance.setControlVisible("tr", false); 
  68.     hatInstance.setControlVisible("tl", false); 
  69.     hatInstance.setControlVisible("mr", false); 
  70.     hatInstance.setControlVisible("mt", false); 
  71.     canvasFabric.add(hatInstance) 
  72.  
  73. function exportFunc() { 
  74.     document.getElementsByClassName("canvas-container")[0].style.display = "none"; 
  75.     document.getElementById("exportBtn").style.display = "none"; 
  76.     document.getElementById("tip").innerHTML = "长按图片保存或分享"; 
  77.     document.getElementById("change").style.display = "none"; 
  78.     cvs.style.display = "none"; 
  79.     exportImage.style.display = "block"; 
  80.     exportImage.src = canvasFabric.toDataURL({ 
  81.         width: screenWidth, 
  82.         height: screenWidth 
  83.     }) 

效果

所有图片素材均来自腾讯官网

标题名称:教你如何给你的头像添加一个好看的国旗
网站URL:http://www.mswzjz.com/qtweb/news14/185764.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联