成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

開(kāi)發(fā) 后端
近日朋友圈又火了,聽(tīng)說(shuō)原因是 @騰訊官網(wǎng) 就能得到一個(gè)好看的國(guó)慶節(jié)頭像,那么我們自己動(dòng)手實(shí)現(xiàn)一個(gè)吧,教你如何給你的頭像添加一個(gè)好看的國(guó)旗。

近日朋友圈又火了,聽(tīng)說(shuō)原因是 @騰訊官網(wǎng) 就能得到一個(gè)好看的國(guó)慶節(jié)頭像,那么我們自己動(dòng)手實(shí)現(xiàn)一個(gè)吧,教你如何給你的頭像添加一個(gè)好看的國(guó)旗。

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

  1. var cvs = document.getElementById("cvs"); 
  2. var ctx = cvs.getContext("2d"); 
  3. var exportImage = document.getElementById("export"); 
  4. var img = document.getElementById("img"); 
  5. var hat = "hat6"
  6. var canvasFabric; 
  7. var hatInstance; 
  8. var screenWidth = window.screen.width < 500 ? window.screen.width : 300; 
  9.  
  10. function viewer() { 
  11.     var file = document.getElementById("upload").files[0]; 
  12.     console.log(file); 
  13.     var reader = new FileReader; 
  14.     if (file) { 
  15.         reader.readAsDataURL(file); 
  16.         reader.onload = function(e) { 
  17.             img.src = reader.result; 
  18.             img.onload = function() { 
  19.                 img2Cvs(img) 
  20.             } 
  21.         } 
  22.     } else { 
  23.         img.src = "" 
  24.     } 
  25.  
  26. function img2Cvs(img) { 
  27.     cvs.width = img.width; 
  28.     cvs.height = img.height; 
  29.     cvs.style.display = "block"
  30.     canvasFabric = new fabric.Canvas("cvs", { 
  31.         width: screenWidth, 
  32.         height: screenWidth, 
  33.         backgroundImage: new fabric.Image(img, { 
  34.             scaleX: screenWidth / img.width, 
  35.             scaleY: screenWidth / img.height 
  36.         }) 
  37.     }); 
  38.     changeHat(); 
  39.     document.getElementById("uploadContainer").style.display = "none"
  40.     document.getElementById("uploadText").style.display = "none"
  41.     document.getElementById("upload").style.display = "none"
  42.     document.getElementById("change").style.display = "block"
  43.     document.getElementById("exportBtn").style.display = "block"
  44.     document.getElementById("tip").style.opacity = 1 
  45.  
  46. function changeHat() { 
  47.     document.getElementById(hat).style.display = "none"
  48.     var hats = document.getElementsByClassName("hide"); 
  49.     hat = "hat" + (+hat.replace("hat""") + 1) % hats.length; 
  50.     var hatImage = document.getElementById(hat); 
  51.     hatImage.style.display = "block"
  52.     if (hatInstance) { 
  53.         canvasFabric.remove(hatInstance) 
  54.     } 
  55.     hatInstance = new fabric.Image(hatImage, { 
  56.         top: 40, 
  57.         left: screenWidth / 3, 
  58.         scaleX: 100 / hatImage.width, 
  59.         scaleY: 100 / hatImage.height, 
  60.         cornerColor: "#0b3a42"
  61.         cornerStrokeColor: "#fff"
  62.         cornerStyle: "circle"
  63.         transparentCorners: false
  64.         rotatingPointOffset: 30 
  65.     }); 
  66.     hatInstance.setControlVisible("bl"false); 
  67.     hatInstance.setControlVisible("tr"false); 
  68.     hatInstance.setControlVisible("tl"false); 
  69.     hatInstance.setControlVisible("mr"false); 
  70.     hatInstance.setControlVisible("mt"false); 
  71.     canvasFabric.add(hatInstance) 
  72.  
  73. function exportFunc() { 
  74.     document.getElementsByClassName("canvas-container")[0].style.display = "none"
  75.     document.getElementById("exportBtn").style.display = "none"
  76.     document.getElementById("tip").innerHTML = "長(zhǎng)按圖片保存或分享"
  77.     document.getElementById("change").style.display = "none"
  78.     cvs.style.display = "none"
  79.     exportImage.style.display = "block"
  80.     exportImage.src = canvasFabric.toDataURL({ 
  81.         width: screenWidth, 
  82.         height: screenWidth 
  83.     }) 

效果

[[278273]]

image-20190924171817825

image-20190924171842699

image-20190924171947774

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

 

責(zé)任編輯:龐桂玉 來(lái)源: segmentfault
相關(guān)推薦

2020-09-06 22:59:35

Linux文件命令

2020-09-15 13:56:08

公眾號(hào)機(jī)器人圖靈機(jī)器人

2021-08-04 17:55:38

keysRedis數(shù)據(jù)庫(kù)

2023-09-29 11:32:07

2023-01-30 16:21:24

Linux外觀

2018-08-26 05:38:44

路由器調(diào)制解調(diào)器網(wǎng)絡(luò)設(shè)備

2021-06-08 07:48:26

iOS 15 Linux 操作系統(tǒng)

2018-08-29 14:50:15

文件加密

2018-07-03 15:20:36

Promise函數(shù)借錢

2012-03-05 19:43:00

lumia

2018-10-11 21:00:18

2019-05-21 21:36:42

Python編程語(yǔ)言游戲

2022-12-22 08:22:17

Python圖像圖像處理

2015-11-05 15:54:03

馬化騰項(xiàng)目合作

2014-11-19 13:06:59

2022-07-26 08:14:16

注冊(cè)中心ProviderConsumer

2019-05-21 13:55:22

Python編程語(yǔ)言游戲

2022-02-28 08:07:17

Java開(kāi)發(fā)

2025-06-26 02:23:00

2024-01-08 13:40:00

并發(fā)安全? 數(shù)量
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 精品国产一区三区 | 日韩第一区 | 国产精品永久免费观看 | 我爱操| 成人免费看片网 | 国产成人免费视频网站高清观看视频 | 亚洲精品在线看 | av中文字幕在线观看 | 日韩一区中文字幕 | 亚洲国产精品久久久久 | 激情综合五月 | 国产成人精品一区二 | 在线国产一区 | 久久精品国产亚洲一区二区 | 欧美日韩综合一区 | 国产福利91精品 | 亚洲网站在线观看 | www成年人视频 | 美女精品一区 | 欧美一级毛片在线播放 | 亚洲视频一区在线观看 | 精品一二区 | 日韩网站在线观看 | 日韩久久久久久久久久久 | 成人午夜视频在线观看 | 久久精品视频一区二区三区 | 亚洲欧洲精品一区 | 亚洲欧洲精品在线 | 最新免费av网站 | 国产精品成人久久久久a级 久久蜜桃av一区二区天堂 | 国产人成精品一区二区三 | 精品欧美乱码久久久久久 | 亚洲天堂久久 | 精品免费国产一区二区三区四区 | 日本超碰| 永久看片 | 国产精品视频网 | 国产一区亚洲 | 精品久久久久久久久久久 | 在线国产一区二区 | 九九伊人sl水蜜桃色推荐 |