您现在的位置是:亿华云 > IT科技类资讯
产品经理:你能不能用Div给我画条龙?
亿华云2025-10-03 20:09:08【IT科技类资讯】7人已围观
简介本文转载自微信公众号「大帅老猿」,作者大帅搞全栈。转载本文请联系大帅老猿公众号。事情是这样的,前天上午产品经理说想要做一个心愿墙,问我能不能行 我心想,这太容易了,但为了多摸一天鱼,我说
本文转载自微信公众号「大帅老猿」,产品作者大帅搞全栈。经理转载本文请联系大帅老猿公众号。不能用
事情是画条这样的,前天上午产品经理说想要做一个心愿墙,产品问我能不能行
我心想,经理这太容易了,不能用但为了多摸一天鱼,画条我说还是产品有点挑战的 结果下午,产品经理和设计师就给我发来了设计参考我摸鱼的一天要泡汤了吗?
谁都不能阻止我摸鱼
但首先要解决最核心的问题
龙从哪里来?
设计师说了,他可以给我一条由气泡组成的龙的设计稿,我说那等你设计稿给我,我再研究把。结果他说,已经有了,你就用这个吧
image.png
我的刀呢?
互动问题
请在评论区留下你遇到过的最奇葩的需求
拆解需求
遇到不靠谱的产品经理和设计师,前端工程师真是惨。云南idc服务商我们顶着最后交付成品的巨锅,所有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去绘制并添加交互。香港云服务器
原文链接:https://mp.weixin.qq.com/s/iE1vK6hA4IUYsNPpreTKew很赞哦!(5)
上一篇: 全球大型数据中心数量已经接近900个
下一篇: 量子数据中心可能是未来的发展方向