欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java 教你如何給你的頭像添加一個(gè)好看的國(guó)旗

 更新時(shí)間:2019年09月25日 08:48:19   作者:alterem  
這篇文章主要介紹了java 教你如何給你的頭像添加一個(gè)好看的國(guó)旗,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

今天朋友圈又火了,聽說原因是 @騰訊官網(wǎng) 就能得到一頂綠色的帽子,啊呸,是一個(gè)好看的國(guó)慶節(jié)頭像,可是聽說沒一會(huì)就502了,那么我們自己動(dòng)手實(shí)現(xiàn)一個(gè)吧

由于代碼比較簡(jiǎn)單就不一一介紹了。

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 = "長(zhǎng)按圖片保存或分享";
  document.getElementById("change").style.display = "none";
  cvs.style.display = "none";
  exportImage.style.display = "block";
  exportImage.src = canvasFabric.toDataURL({
    width: screenWidth,
    height: screenWidth
  })
}

最后效果

拖動(dòng)圖片可見已經(jīng)拼合成一張完整圖片了

右鍵查看源代碼

所有圖片素材均來自騰訊官網(wǎng)

源碼地址:https://gitee.com/alterem/avatar

演示地址:http://alterem.gitee.io/avatar/

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring源碼解析 Bean屬性填充

    Spring源碼解析 Bean屬性填充

    這篇文章主要介紹了Spring源碼解析 Bean屬性填充,文章圍繞主題展開想詳細(xì)的內(nèi)容詳情,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • Redis集群與SSM整合使用方法

    Redis集群與SSM整合使用方法

    這篇文章主要介紹了Redis集群與SSM整合使用方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-12-12
  • 使用@Validated 和 BindingResult 遇到的坑及解決

    使用@Validated 和 BindingResult 遇到的坑及解決

    這篇文章主要介紹了使用@Validated 和 BindingResult 遇到的坑及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java鎖競(jìng)爭(zhēng)導(dǎo)致sql慢日志原因分析

    Java鎖競(jìng)爭(zhēng)導(dǎo)致sql慢日志原因分析

    這篇文章主要介紹了Java鎖競(jìng)爭(zhēng)導(dǎo)致sql慢的日志原因分析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-11-11
  • Java基本語法小白入門級(jí)

    Java基本語法小白入門級(jí)

    Java基本語法就是指java中的規(guī)則,也是一種語言規(guī)則,規(guī)范,同時(shí)也能讓您在后面的學(xué)習(xí)中避免不必要的一些錯(cuò)誤和麻煩,是您學(xué)好java必修的第一門課程
    2023-05-05
  • 淺談Java設(shè)置PPT幻燈片背景——純色、漸變、圖片背景

    淺談Java設(shè)置PPT幻燈片背景——純色、漸變、圖片背景

    這篇文章主要介紹了Java設(shè)置PPT幻燈片背景——純色、漸變、圖片背景,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • SpringMVC實(shí)現(xiàn)獲取請(qǐng)求參數(shù)方法詳解

    SpringMVC實(shí)現(xiàn)獲取請(qǐng)求參數(shù)方法詳解

    Spring MVC 是 Spring 提供的一個(gè)基于 MVC 設(shè)計(jì)模式的輕量級(jí) Web 開發(fā)框架,本質(zhì)上相當(dāng)于 Servlet,Spring MVC 角色劃分清晰,分工明細(xì),這篇文章主要介紹了SpringMVC實(shí)現(xiàn)獲取請(qǐng)求參數(shù)方法
    2022-09-09
  • 淺談Java并發(fā)中的內(nèi)存模型

    淺談Java并發(fā)中的內(nèi)存模型

    這篇文章主要介紹了Java并發(fā)中的內(nèi)存模型,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-05-05
  • SpringBoot配置Https入門實(shí)踐

    SpringBoot配置Https入門實(shí)踐

    本文主要介紹了SpringBoot配置Https入門實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • 一個(gè)Java配置文件加密解密工具類分享

    一個(gè)Java配置文件加密解密工具類分享

    在 JavaEE 配置文件中,例如 XML 或者 properties 文件,由于某些敏感信息不希望普通人員看見,則可以采用加密的方式存儲(chǔ),程序讀取后進(jìn)行解密
    2014-04-04

最新評(píng)論