python-opencv获取轮廓内部所有点

python-opencv获取轮廓内部所有点


前言

做项目途中发现opencv没有一个内置函数可以获取到自己的轮廓数据的内部点的函数,所以自己查了点资料整理了下


一、contours

opencv库有findContours获取contours轮廓数据,然后用drawContours

def drawContours(image, contours, contourIdx, color, thickness=None,
 lineType=None, hierarchy=None, maxLevel=None, offset=None)

第一个参数image表示绘制的目标图像
第二个参数contours表示输入的轮廓组
第三个参数contourIdx指明画第几个轮廓****,如果该参数为负值,则画全部轮廓,
第四个参数color为轮廓的颜色,
第五个参数thickness为轮廓的线宽,如果为负值表示填充轮廓内部

只要查找绘制后image的特定值,就可以找到相对应的point

def contours_in(contours):
	p = np.zeros(shape=(2000,2000))
	cv2.drawContours(p, contours, -1, 255, -1)
	a = np.where(p==255)[0].reshape(-1,1)
	b = np.where(p==255)[1].reshape(-1,1)
	coordinate = np.concatenate([a,b], axis=1).tolist()
	inside = [tuple(x) for x in coordinate]
	return inside

该函数返回一个list[tuple]类型的轮廓内部所有点

二、用自己的数据

项目过程中用的是自己额外的数据,不是用的findContours,但是原理都一样,将自己的数据类型转化成contours类型的,也即list[ndarray(n,1,2),…],其中有list个轮廓,n为一个轮廓的n个点。
在这里插入图片描述

将自己的数据转np(实例):

np.array(data).reshape(-1,1,2)#根据自己的数据而定
my_contours.append(data)
in_pixel = contours_in(my_contours)

总结

自己写的小东西,共享是程序员的精神殿堂

  • 15
    点赞
  • 72
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
获取眼白和嘴巴内部的图像,可以使用OpenCV库中的一些图像处理函数。以下是一个示例代码,可以实现从图像中提取眼白和嘴巴内部的图像: ```python import cv2 # 加载图像 img = cv2.imread('image.jpg') # 灰度化 gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) # 阈值分割 thresh = cv2.threshold(gray, 127, 255, cv2.THRESH_BINARY)[1] # 获取轮廓 contours, hierarchy = cv2.findContours(thresh, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE) # 遍历每个轮廓 for contour in contours: # 计算轮廓面积 area = cv2.contourArea(contour) # 如果轮廓面积大于一定值,则认为是眼球或嘴巴 if area > 1000: # 获取轮廓的外接矩形 x, y, w, h = cv2.boundingRect(contour) # 获取眼白或嘴巴的区域 roi = img[y:y+h, x:x+w] # 显示眼白或嘴巴的区域 cv2.imshow('ROI', roi) # 显示图像 cv2.imshow('image', img) cv2.waitKey(0) cv2.destroyAllWindows() ``` 这段代码中,首先加载了图像,并将其转换为灰度图像。然后,对灰度图像进行了阈值分割处理,得到二值图像。接下来,使用findContours函数获取图像中的轮廓。然后,遍历每个轮廓,计算轮廓面积,如果面积大于一定值,则认为是眼球或嘴巴。获取轮廓的外接矩形,然后获取眼白或嘴巴的区域。最后,使用OpenCV库显示眼白或嘴巴的区域,并显示图像。 需要注意的是,这种方法的准确度受到多种因素的影响,例如光照、姿势、表情等。因此,在实际应用中,需要进行大量的样本训练和测试,以提高准确度和稳定性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值