今天朋友圈又火了,听说原因是 @腾讯官网 就能得到一顶绿色的帽子,啊呸,是一个好看的国庆节头像,可是听说没一会就502了,那么我们自己动手实现一个吧
由于代码比较简单就不一一介绍了。
var cvs = document.getElementById("cvs"); var ctx = cvs.getContext("2d"); var exportImage = document.getElementById("export"); var img = document.getElementById("img"); var hat = "hat6"; var canvasFabric; var hatInstance; var screenWidth = window.screen.width < 500 ? window.screen.width : 300; function viewer() { var file = document.getElementById("upload").files[0]; console.log(file); var reader = new FileReader; if (file) { reader.readAsDataURL(file); reader.onload = function(e) { img.src = reader.result; img.onload = function() { img2Cvs(img) } } } else { img.src = "" } } function img2Cvs(img) { cvs.width = img.width; cvs.height = img.height; cvs.style.display = "block"; canvasFabric = new fabric.Canvas("cvs", { width: screenWidth, height: screenWidth, backgroundImage: new fabric.Image(img, { scaleX: screenWidth / img.width, scaleY: screenWidth / img.height }) }); changeHat(); document.getElementById("uploadContainer").style.display = "none"; document.getElementById("uploadText").style.display = "none"; document.getElementById("upload").style.display = "none"; document.getElementById("change").style.display = "block"; document.getElementById("exportBtn").style.display = "block"; document.getElementById("tip").style.opacity = 1 } function changeHat() { document.getElementById(hat).style.display = "none"; var hats = document.getElementsByClassName("hide"); hat = "hat" + (+hat.replace("hat", "") + 1) % hats.length; var hatImage = document.getElementById(hat); hatImage.style.display = "block"; if (hatInstance) { canvasFabric.remove(hatInstance) } hatInstance = new fabric.Image(hatImage, { top: 40, left: screenWidth / 3, scaleX: 100 / hatImage.width, scaleY: 100 / hatImage.height, cornerColor: "#0b3a42", cornerStrokeColor: "#fff", cornerStyle: "circle", transparentCorners: false, rotatingPointOffset: 30 }); hatInstance.setControlVisible("bl", false); hatInstance.setControlVisible("tr", false); hatInstance.setControlVisible("tl", false); hatInstance.setControlVisible("mr", false); hatInstance.setControlVisible("mt", false); canvasFabric.add(hatInstance) } function exportFunc() { document.getElementsByClassName("canvas-container")[0].style.display = "none"; document.getElementById("exportBtn").style.display = "none"; document.getElementById("tip").innerHTML = "长按图片保存或分享"; document.getElementById("change").style.display = "none"; cvs.style.display = "none"; exportImage.style.display = "block"; exportImage.src = canvasFabric.toDataURL({ width: screenWidth, height: screenWidth }) }
最后效果
拖动图片可见已经拼合成一张完整图片了
右键查看源代码
所有图片素材均来自腾讯官网源码地址:https://gitee.com/alterem/avatar
演示地址:http://alterem.gitee.io/avatar/
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍聊一聊你如何看待加班的呢?相关面试题,主要包含被问及聊一聊你如何看待加班的呢?时的应答技巧和注意事项,需要的朋友参考一下 加班有两个方面:一方面可能自己确实工作效率太低,如果是这样,我会努力提高工作效率,减少不必要的加班;另一方面,可能确实这个项目确实有点急,为了公司效益会选择加班,但如果平时非特殊时间段也要求加班,需要给予加班费。
本文向大家介绍请讲讲,你如何看待加班?相关面试题,主要包含被问及请讲讲,你如何看待加班?时的应答技巧和注意事项,需要的朋友参考一下
本文向大家介绍教你如何看懂SQL Server查询计划,包括了教你如何看懂SQL Server查询计划的使用技巧和注意事项,需要的朋友参考一下 对于SQL Server的优化来说,优化查询可能是很常见的事情。由于数据库的优化,本身也是一个涉及面比较的广的话题,因此本文只谈优化查询时如何看懂SQL Server查询计划。毕竟我对SQL Server的认识有限,如有错误,也恳请您在发现后及时批评指正。
本文向大家介绍你觉得如何才能取出一个好的标题?相关面试题,主要包含被问及你觉得如何才能取出一个好的标题?时的应答技巧和注意事项,需要的朋友参考一下 同样是标题的问题,也可以从不同方向来答,标题套路再多但遵循原则却只有5个。 符合各平台运营规则(百家、头条、大于等都有相关标题运营规则) 不背离文章内容本身(标题是对文案内容精髓的提炼,而不是夸大其词) 贴近用户(普罗大众更喜欢看通俗易懂的词汇,而知识
本文向大家介绍教你构建第一个Java Applet程序,包括了教你构建第一个Java Applet程序的使用技巧和注意事项,需要的朋友参考一下 介绍 Note: 在你开始本教程之前,你必须下载downloaded 并安装installed Java SE Development Kit。 Java applets像Java应用程序一样,它们的建立都是遵循相同的三个步骤—编写,编译及运行。不同 的是
本文向大家介绍如果给你500w做海外直播创业,请你谈一下,你会选择哪个国家?为什么?相关面试题,主要包含被问及如果给你500w做海外直播创业,请你谈一下,你会选择哪个国家?为什么?时的应答技巧和注意事项,需要的朋友参考一下 我会选择非洲某些国家,不处于战乱,我国企业重点投资的区域。 一是虽然非洲国家经济欠发达,基础设施相对不够,但是我国近年在非洲大量进行基建,在基础设施建设上有了一定的保障,也让非