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

IT科技2025-11-04 22:08:226713

 

本文转载自微信公众号「大帅老猿」,产品作者大帅搞全栈。经理转载本文请联系大帅老猿公众号。不能用

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

  我心想,经理这太容易了,不能用但为了多摸一天鱼,画条我说还是产品有点挑战的   结果下午,产品经理和设计师就给我发来了设计参考

image.png   他们说,经理心愿墙的不能用设计大致是这样的,每个用户的画条心愿都是一个气泡,而客户的产品品牌是”龙“,我们希望在前端页面里用气泡呈现一个龙形的b2b供应网经理设计,每个气泡都会浮动,不能用鼠标移上去变大,点击后展示心愿详情。   当时我的内心是这样的

  image.png  

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

谁都不能阻止我摸鱼

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

龙从哪里来?

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

image.png

我的刀呢?

互动问题

请在评论区留下你遇到过的最奇葩的需求

拆解需求

遇到不靠谱的产品经理和设计师,前端工程师真是惨。服务器租用我们顶着最后交付成品的巨锅,所有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
本文地址:http://www.bzuk.cn/news/117f32699556.html
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

全站热门

75寸电视最佳观看距离和尺寸的科学指南(如何选择适合的75寸电视?)

苹果修复旧版 iPhone 上的 WebKit 零日漏洞

PostgreSQL的几种分布式架构对比

MySQL 的 MRR 到底是什么?

中柏平板电脑装系统教程(一步步教你如何在中柏平板电脑上安装系统)

老大让我整理下公司内部MySQL使用规范,分享给大家

分布式系统安全之分布式系统协调资源聚类

把MySQL中的各种锁及其原理都画出来

友情链接

滇ICP备2023006006号-33