canvas 轮廓路径提取效果

前言

微信公众号:前端不只是切图

轮廓

对内容做border效果,可以先看下代码运行的效果

alt

内容是黑线构成的五角星,其轮廓就是红线的部分,本文主要介绍如何在canvas中实现这种效果

Marching Square

这里运用到的是marching square算法,直译过来就是行进的方格,这里的方格相当于canvas上的像素和他的上、左、上左的像素形成的区域,贴一张网上找到的图,很形象直观的表达了这个算法

alt
找到一个起始点

算法的整体过程为,首先我们要找到一个起始点,可以通过从左到右,从上到下遍历canvasimageData,找到第一个alpha不为0的像素作为起始点,然后开始行进

开始行进

所谓行进就是对(x,y)坐标+1-1操作,该如何行进,上图给出了16种状态,每种状态右下角的点就是当前准备行进的点,我们看上图的第一张像素图,红框中像素内容是白黑白黑对应第9种状态,所以要往下行进,则x不变,y+1,变成第二张像素图,然后继续判断,发现当前状态是白黑白白对应第5种状态向右行进,所以x+1y不变,之后不断往后,直到出现第16种状态即全是黑的或者当前行进的像素坐标和起始像素坐标一致,就说明边缘提取结束

优化

上面图其实就黑和白两种状态,代表是内容是否是完全透明的,可以通过二进制的方式优化状态比较的过程,比如第一个白白白白,对应0000,第二个黑黑白白对应1100,即当行进点获取四周的状态时可以通过左移的方式得到当前方格的二进制

绘制

我们可以把上面提取的点存到一个数组中,通过ctx.move()的方式将路径绘制到canvas

效果展示时间

为了让效果更加酷炫点,简单的用鼠标实现画笔功能,并且边框用虚线,点击绘制轮廓的同时把原内容隐藏,这里贴的是gif,加载可能比较慢可能要稍微等一下

alt

本文由 mdnice 多平台发布

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

hhzzcc_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值