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
二维码