产品经理:你能不能用div给我画条龙?

简介: 事情是这样的,前天上午产品经理说想要做一个心愿墙,问我能不能行我心想,这太容易了,但为了多摸一天鱼,我说还是有点挑战的结果下午,产品经理和设计师就给我发来了设计参考

拆解需求


遇到不靠谱的产品经理和设计师,前端工程师真是惨。我们顶着最后交付成品的巨锅,所有deadline感觉都只是用来压榨前端工程师的。


我们只能靠自己,因为


谁都不能阻止我摸鱼


  • 需求1:有鼠标交互效果(太简单)


  • 需求2:气泡要浮动(css动画,easy)


  • 需求3:气泡组成一条龙


此时我脑海里响起这首烂大街的歌


左边跟我一起画个龙,在你右边画一道彩虹~


诶,画个龙

用什么画,canvas

canvas能获得指定区域的像素点阵


卧槽,有招儿了


代码时间


先用图片搜索找一张龙的剪影


image.png


image.png


将图片绘制到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);
                }
    }
}


现在我们获得了这样一条龙的点阵信息


image.png


通过点阵信息生成气泡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);
                }
    }
}


image.png


开心摸鱼吧


本例里使用div绘制大量的dom,仅为阐述思路,没考虑性能。利用一些js游戏引擎,比如pixi等,可以很方便的全部交由canvas去绘制并添加交互。



相关文章
|
移动开发 JavaScript API
10件开发者和老板都要知道的HTML5的那些事
1. HTML5 标签没什么大不了的. 理解这句话你需要先了解HTML 5。它仅仅是一个html4.01的一个升级版本?或者是它是完全不同的新版本(无处不在的大肆宣传可能会让你有这种感觉)?答案是两种理解都有部分正确。
1194 0
|
9月前
|
JavaScript 前端开发
layui使用实践总结
layui使用实践总结
148 0
|
前端开发
前端工作总结167-对element-form的理解
前端工作总结167-对element-form的理解
102 0
前端工作总结167-对element-form的理解
|
Web App开发 移动开发 HTML5
告别div,可以代替div的几个标签
几个最常用的用来代替DIV的HTML5元素 虽说html5中大多数功能性的元素如等还得不到当前主流浏览器的支持(主要就是指IE浏览器了),但至少那些个与布局相关的元素同html5.js结合起来时我们是可以放心使用的,比如,,,,,,这几个最常用的元素。
1161 0
|
存储 JavaScript 算法
好程序员分享HTML5培训精品技术文章--前端岗位需求分析
  好程序员分享HTML5精品技术文章--前端岗位需求分析,各位小伙伴大家好,根据多年丰富的面试经历和岗位分析,对前端面试的技术栈,各大公司面试特点,进行简要的分析 ,随着我的秀发越来越少可以说我们积累的经验越来越多,在此给大家进行一个简要的分享。
2611 0
|
Web App开发 前端开发 JavaScript
猿创征文|我的前端——【HTML5】基础成长学习之路
网页是由页面元素组成的,这些元素是利用html标签描述出来的,然后通过浏览器解析来显示给用户的。是在英特网上根据一定的规则,使用html等制作的用于展示特定内容相关的网页集合。
140 0
猿创征文|我的前端——【HTML5】基础成长学习之路
|
前端开发
前端工作总结229-代码中漫花谷出现很多NBSP
前端工作总结229-代码中漫花谷出现很多NBSP
107 0
前端工作总结229-代码中漫花谷出现很多NBSP
|
JavaScript 前端开发 HTML5
那些帮助你成为优秀前端工程师的讲座——《CSS篇》
  这篇文章是《前端优秀讲座和讨论列表》系列连载第二篇,包含未来的前端开发趋势和 CSS 开发两部分内容。前端领域发展迅速,只有时刻掌握前端发展趋势和技术动态,学习前沿的开发思想和理念才能让自己跟上时代的步伐,保持自己的技术优势。
1210 0
|
9月前
|
存储 缓存 前端开发
【前端实习生备战秋招】—HTML 和 CSS面试题总结(三)
【前端实习生备战秋招】—HTML 和 CSS面试题总结(三)
|
9月前
|
存储 缓存 前端开发
【前端实习生备战秋招】—HTML 和 CSS面试题总结(一)
【前端实习生备战秋招】—HTML 和 CSS面试题总结(一)

热门文章

最新文章