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

网友投稿 207 2023-06-13

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

今天朋友圈又火了,听说原因是 @腾讯官网 就能得到一顶绿色的帽子,啊呸,是一个好看的国庆节头像,可是听说没一会就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;

varhttp:// 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",

cornerStylehttp://: "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/

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java 数组差集实例代码
下一篇:ThreadPoolExecutor线程池的使用方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~