溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何用Div畫條龍

發(fā)布時(shí)間:2021-09-14 15:45:11 來源:億速云 閱讀:187 作者:柒染 欄目:web開發(fā)

本篇文章為大家展示了如何用Div畫條龍,內(nèi)容簡明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

 拆解需求

遇到不靠譜的產(chǎn)品經(jīng)理和設(shè)計(jì)師,前端工程師真是慘。我們頂著最后交付成品的巨鍋,所有deadline感覺都只是用來壓榨前端工程師的。

誒,畫個(gè)龍

用什么畫,canvas

canvas能獲得指定區(qū)域的像素點(diǎn)陣

臥槽,有招兒了

代碼時(shí)間

先用圖片搜索找一張龍的剪影

如何用Div畫條龍

如何用Div畫條龍

將圖片繪制到canvas中

var canvas = document.getElementById("canvas"); var ctx = canvas.getContext("2d");  var image = new Image(); image.src = "dragon.jpg"; image.onload = function(){         canvas.width = image.width;         canvas.height = image.height;          ctx.drawImage(image,0,0); }

獲取并裁剪畫布的點(diǎn)陣信息

var imageData = ctx.getImageData(0,0,image.width,image.height).data; ctx.fillStyle = "#ffffff"; ctx.fillRect(0,0,image.width,image.height);  var gap = 6;  for (var h = 0; h < image.height; h+=gap) {     for(var w = 0; w < image.width; w+=gap){             var position = (image.width * h + w) * 4;             var r = imageData[position], g = imageData[position + 1], b = imageData[position + 2];              if(r+g+b==0){                     ctx.fillStyle = "#000";                     ctx.fillRect(w,h,4,4);                 }     } }

現(xiàn)在我們獲得了這樣一條龍的點(diǎn)陣信息

如何用Div畫條龍

通過點(diǎn)陣信息生成氣泡dom

var dragonContainer = document.getElementById("container"); var dragonScale = 2;  for (var h = 0; h < image.height; h+=gap) {     for(var w = 0; w < image.width; w+=gap){             var position = (image.width * h + w) * 4;             var r = imageData[position], g = imageData[position + 1], b = imageData[position + 2];              if(r+g+b==0){                     var bubble = document.createElement("img");                     bubble.src = "bubble.png";                     bubble.setAttribute("class","bubble");                      var bubbleSize = Math.random()*10+20;                     bubble.style.left = (w*dragonScale-bubbleSize/2) + "px";                     bubble.style.top = (h*dragonScale-bubbleSize/2) + "px";                     bubble.style.width = bubble.style.height = bubbleSize+"px";                     bubble.style.animationDuration = Math.random()*6+4 + "s";                      dragonContainer.appendChild(bubble);                 }     } }

如何用Div畫條龍

上述內(nèi)容就是如何用Div畫條龍,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI