事情是這樣的,前天上午產品經理說想要作一個心願牆,問我能不能行javascript
我心想,這太容易了,但爲了多摸一天魚,我說仍是有點挑戰的css
結果下午,產品經理和設計師就給我發來了設計參考前端
他們說,心願牆的設計大體是這樣的,每一個用戶的心願都是一個氣泡,而客戶的品牌是」龍「,咱們但願在前端頁面裏用氣泡呈現一個龍形的設計,每一個氣泡都會浮動,鼠標移上去變大,點擊後展現心願詳情。java
當時個人心裏是這樣的canvas
我摸魚的一天要泡湯了嗎?微信
誰都不能阻止我摸魚markdown
但首先要解決最核心的問題前端工程師
設計師說了,他能夠給我一條由氣泡組成的龍的設計稿,我說那等你設計稿給我,我再研究把。結果他說,已經有了,你就用這個吧app
個人刀呢?dom
請在評論區留下你遇到過的最奇葩的需求
遇到不靠譜的產品經理和設計師,前端工程師真是慘。咱們頂着最後交付成品的巨鍋
,全部deadline
感受都只是用來壓榨前端工程師的。
咱們只能靠本身,由於
誰都不能阻止我摸魚
此時我腦海裏響起這首爛大街的歌
左邊跟我一塊兒畫個龍,在你右邊畫一道彩虹~
誒,畫個龍
用什麼畫,canvas
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);
}
複製代碼
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);
}
}
}
複製代碼
如今咱們得到了這樣一條龍的點陣信息
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繪製大量的dom,僅爲闡述思路,沒考慮性能。利用一些js遊戲引擎,好比pixi等,能夠很方便的所有交由canvas去繪製並添加交互。
本故事純屬虛構,參考案例來自本人2011年末爲客戶開發的春節活動網站。
微信搜索並關注「大帥老猿
」,回覆泡泡龍
得到源碼