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

 更新时间:2019年09月25日 08:48:19   作者:alterem  
这篇文章主要介绍了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;
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/

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • java中的DateTime的具体使用

    java中的DateTime的具体使用

    本文主要介绍了java中的DateTime的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Spring Boot深入学习数据访问之Spring Data JPA与Hibernate的应用

    Spring Boot深入学习数据访问之Spring Data JPA与Hibernate的应用

    Spring Data JPA是Spring Data的子项目,在使用Spring Data JPA之前,先了解一下Hibernate,因为Spring Data JPA是由Hibernate默认实现的
    2022-10-10
  • SpringBoot集成ECDH密钥交换的方法

    SpringBoot集成ECDH密钥交换的方法

    ECDH密钥交换算法通过椭圆曲线和Diffie-Hellman方法生成共享密钥,用于前端和后端之间的AES加密通信,前端使用elliptic.js生成密钥对,后端使用crypto-js.min.js进行AES加密,本文给大家介绍SpringBoot集成ECDH密钥交换的相关知识,感兴趣的朋友一起看看吧
    2025-01-01
  • java double类型相加精度问题的解决

    java double类型相加精度问题的解决

    这篇文章主要介绍了java double类型相加精度问题的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • 分享Spring Cloud OpenFeign 的五个优化技巧

    分享Spring Cloud OpenFeign 的五个优化技巧

    这篇文章主要分享的是Spring Cloud OpenFeign 的五个优化技巧,OpenFeign 是 Spring 官方推出的一种声明式服务调用和负载均衡组件,更多相关内容需要的小伙伴可以参考一下
    2022-05-05
  • Springmvc RequestMapping请求实现方法解析

    Springmvc RequestMapping请求实现方法解析

    这篇文章主要介绍了Springmvc RequestMapping请求实现方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Spring Boot高级教程之Spring Boot连接MySql数据库

    Spring Boot高级教程之Spring Boot连接MySql数据库

    这篇文章主要为大家详细介绍了Spring Boot高级教程之Spring Boot连接MySql数据库,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10
  • SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

    SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

    本文介绍了如何在SpringBoot项目中使用MDC(Mapped Diagnostic Context)为日志增加唯一标识,以便于日志追踪,通过创建日志拦截器、配置拦截器以及修改日志配置文件,可以实现这一功能,文章还提供了源码地址,方便读者学习和参考,感兴趣的朋友一起看看吧
    2025-03-03
  • Java Scanner类用法及nextLine()产生的换行符问题实例分析

    Java Scanner类用法及nextLine()产生的换行符问题实例分析

    这篇文章主要介绍了Java Scanner类用法及nextLine()产生的换行符问题,结合实例形式分析了Scanner类功能、hasNextInt()和nextInt()方法使用及nextLine()产生的换行符问题解决方法,需要的朋友可以参考下
    2019-03-03
  • String中intern方法的使用场景详解

    String中intern方法的使用场景详解

    这篇文章主要给大家介绍了关于String中intern方法的使用场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09

最新评论