最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 产品经理:你能不能用div给我画条龙?

    正文概述 掘金(大帅老猿)   2021-05-18   468

    事情是这样的,前天上午产品经理说想要做一个心愿墙,问我能不能行

    我心想,这太容易了,但为了多摸一天鱼,我说还是有点挑战

    结果下午,产品经理和设计师就给我发来了设计参考

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

    他们说,心愿墙的设计大致是这样的,每个用户的心愿都是一个气泡,而客户的品牌是”龙“,我们希望在前端页面里用气泡呈现一个龙形的设计,每个气泡都会浮动,鼠标移上去变大,点击后展示心愿详情。

    当时我的内心是这样的

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

    我摸鱼的一天要泡汤了吗?

    谁都不能阻止我摸鱼

    但首先要解决最核心的问题

    龙从哪里来?

    设计师说了,他可以给我一条由气泡组成的龙的设计稿,我说那等你设计稿给我,我再研究把。结果他说,已经有了,你就用这个吧

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

    我的刀呢?

    互动问题

    拆解需求

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

    我们只能靠自己,因为

    谁都不能阻止我摸鱼

    • 需求1:有鼠标交互效果(太简单)
    • 需求2:气泡要浮动(css动画,easy)
    • 需求3:气泡组成一条龙

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

    诶,画个龙

    用什么画,canvas

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

    卧槽,有招儿了

    代码时间

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

    产品经理:你能不能用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);
    }
    

    获取并裁剪画布的点阵信息

    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);
                    }
        }
    }
    

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

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

    通过点阵信息生成气泡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给我画条龙?

    开心摸鱼吧

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


    本故事纯属虚构,参考案例来自本人2011年底为客户开发的春节活动网站。

    源码

    微信搜索并关注“大帅老猿”,回复泡泡龙获得源码


    起源地下载网 » 产品经理:你能不能用div给我画条龙?

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元