如何用Div畫條龍

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

創(chuàng)新互聯(lián)建站專業(yè)為企業(yè)提供寧陵網(wǎng)站建設(shè)、寧陵做網(wǎng)站、寧陵網(wǎng)站設(shè)計(jì)、寧陵網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、寧陵企業(yè)網(wǎng)站模板建站服務(wù),十年寧陵做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。

 拆解需求

遇到不靠譜的產(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)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

本文標(biāo)題:如何用Div畫條龍
文章分享:http://bm7419.com/article42/jcieec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗(yàn)手機(jī)網(wǎng)站建設(shè)、網(wǎng)站營銷網(wǎng)站內(nèi)鏈、面包屑導(dǎo)航定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)