python opencv轮廓提取_Python + Opencv2 实现轮廓提取、颜色标记,区域面积计算

Python + Opencv2 实现轮廓提取,轮廓区域面积计算;

对图像处理时,会遇到这样一个场景:找到图像主体轮廓,这是其一,可能为了凸显轮廓,需要用指定的颜色进行标记;轮廓标记完可能任务还没有结束,还需对轮廓所勾勒的像素面积区域统计计算。

本篇文章的主要内容就是要解决上面场景遇到的三个问问题找到图像主题轮廓;

用指定颜色对源图像进行轮廓标记;

计算轮廓中的主体;

实验环境配置为 Python + Opencv 3.4, 处理的图像如下:

第一步,提取轮廓,Opencv 中的 findContours() 函数 可以直接提取轮廓,但对输入图像有一定要求一,输入的图像必须是单通道,三通道不允许;

二,输入的图像数据类型需是 8UC1;否则程序会报错的,报错信息如下:

error: (-210) [start]FindContours supports only CV_8UC1 images when mode != CV_RETR_FLOODFILL otherwise supports CV_32SC1 images only in function cvStartFindContours_Impl

解决方法,在读取时加入下面这行代码进行数据格式转换,同时解决上面两个问题:

mat_img2 = cv2.imread(img_path,cv2.CV_8UC1)三、输入的图像背景需是黑色的,否则轮廓提取失败,就以本次

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值