鼠标交互与区域生长

本文介绍了区域生长算法,通过计算像素间欧式距离并设定阈值来连接相似点。算法首先从用户指定的种子点开始,然后在四邻域内进行像素比较,将满足条件的相邻点加入生长点序列,直至序列为空。最后,该算法应用于图像'peppa.jpg',进行图像分割。
摘要由CSDN通过智能技术生成

在这里插入图片描述

在这里插入图片描述

计算两个点间的欧式距离
def getGrayDiff(img,currentPoint,tmpPoint):
return abs(int(img[currentPoint.x,currentPoint.y]) - int(img[tmpPoint.x,tmpPoint.y]))
def selectConnects§:
if p == 8:
connects = [Point(-1, -1), Point(0, -1), Point(1, -1), Point(1, 0), Point(1, 1),
Point(0, 1), Point(-1, 1), Point(-1, 0)]#八邻域
else:
connects = [ Point(0, -1), Point(1, 0),Point(0, 1), Point(-1, 0)]#四邻
return connects
def regionGrow(img,seeds,thresh):
#读取图像的宽高,并建立一个和原图大小相同的seedMark
height, width = img.shape
seedMark = np.zeros(img.shape)
#将定义的种子点放入种子点序列seedList
seedList = []
for seed in seeds:
seedList.append(seed)
label = 1
#选择邻域
#c

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值