Java teaches you how to add a nice flag to your avatar
•
Java
Today, the circle of friends is hot again. I heard that the reason is that @ Tencent's official website can get a green hat. Ah bah, it's a nice National Day avatar, but it's said that it's 502 in a short time. Let's do it ourselves
Because the code is relatively simple, I won't introduce it one by one.
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
})
}
Final effect
Drag the picture to see that it has been assembled into a complete picture
Right click to view the source code
The above is the whole content of this article. I hope it will help you in your study, and I hope you will support us a lot.
The content of this article comes from the network collection of netizens. It is used as a learning reference. The copyright belongs to the original author.
THE END
二维码
