【摘要】

本文介绍在图像处理领域中较为常用的一种图像区域(Blob)提取的方法——连通性分析法(连通区域标记法)。

文中介绍了两种常见的连通性分析的算法:1)Two-pass;2)Seed-Filling种子填充,并给出了两个算法的基于OpenCV的C++实现代码。

【注释】

1、这里的扫描指的是按行或按列访问以便图像的所有像素,算法中采用的是按行扫描方式;

2、图像记为B,为二值图像:前景像素(pixel value = 1),背景像素(pixel value = 0);

3、label从2开始计数;

4、像素相邻关系有两种:4-领域、8-领域,本文算法采用4-邻域;

              图1(像素相邻关系图)

一、Two-pass算法

1、第一次扫描(Frist Pass)

  判断B(x,y)像素是否为前景像素(即B(x,y)==1),

   如果B(x,y)==1,判断B(x,y)的邻域像素点像素值是否为B(Neighbors)==0(注意这里指的是像素点的值,不是像素点的lable值),

    如果都为B(Neighbors)==0,那么B(x,y)==lable;lable加1;

    如果B(Neighbors)存在不为0的像素值(即邻域Neighbors中存在lable值),那么B(x,y)等于邻域中最小的lable值,(B(x,y)== min{Neighbors} ;),

    记录lable值产生变化的点(相等关系),并将变化lable值保存到某一列表中。(相等关系:如图1中所示,B(2,1)和B(1,1)、B(0,2)相邻,但是B(2,1)的lable==1,B(1,1)的lable==3,所以将lable值为1,3的像素视为相等。即连通)

                图2(相等关系演示图)

2、第二次扫描(Second Pass)

  访问当前像素B(x,y),如果B(x,y) > 1:

  找到与label = B(x,y)同属相等关系的一个最小label值,赋予给B(x,y);

  完成扫描后,图像中具有相同label值的像素就组成了同一个连通区域。

                     图3(Two-pass算法动态演示图)

Seed Filling(种子填充法)

  1、扫描图像,如果像素点B(x,y) == 1:

  那么将B(x,y)作为种子(像素位置),并赋予其一个label,然后将该种子相邻的所有前景像素都压入栈中(队列中);

  然后获取栈中的第一个像素,赋予其相同的label,然后再将与该像素相邻的所有前景像素都压入栈中;

  重复b步骤,直到栈为空;

   2、重复第(1)步,直到扫描结束;扫描结束后,就可以得到图像B中所有的连通区域;

            图4  Seed Filling(种子填充法)动态图演示

参考文章:

http://blog.csdn.net/cooelf/article/details/26581539

http://blog.csdn.net/icvpr/article/details/10259577

Opencv图像连通域的更多相关文章

  1. OpenCV: 图像连通域检测的递归算法

    序言:清除链接边缘,可以使用数组进行递归运算; 连通域检测的递归算法是定义级别的检测算法,且是无优化和无语义失误的. 同样可用于寻找连通域 void ClearEdge(CvMat* MM,CvPoi ...

  2. OpenCV图像金字塔:高斯金字塔、拉普拉斯金字塔与图片尺寸缩放

    这篇已经写得很好,真心给作者点个赞.题目都是直接转过来的,直接去看吧. Reference Link : http://blog.csdn.net/poem_qianmo/article/detail ...

  3. 【OpenCV新手教程之十三】OpenCV图像金字塔:高斯金字塔、拉普拉斯金字塔与图片尺寸缩放

    本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/26157633 作者:毛星云(浅墨) ...

  4. Opencv 图像叠加 添加水印

    Opencv 图像叠加 添加水印 C++: void Mat::copyTo(OutputArray m) const C++: void Mat::copyTo(OutputArray m, Inp ...

  5. opencv图像读取-imread

    前言 图像的读取和保存一定要注意imread函数的各个参数及其意义,尽量不要使用默认参数,否则就像数据格式出现错误(here)一样,很难查找错误原因的: re: 1.opencv图像的读取与保存; 完

  6. 学习 opencv---(12)OpenCV 图像金字塔:高斯金字塔,拉普拉斯金字塔与图片尺寸缩放

    在这篇文章里,我们一起学习下 图像金字塔 的一些基本概念,如何使用OpenCV函数pyrUp和pyrDown 对图像进行向上和向下采样,以及了解专门用于缩放图像尺寸的resize函数的用法.此博文一共 ...

  7. [OpenCV Qt教程] 在Qt图形界面中显示OpenCV图像的OpenGL Widget(第二部分)

    本文译自:http://www.robot-home.it/blog/en/software/tutorial-opencv-qt-opengl-widget-per-visualizzare-imm ...

  8. [OpenCV Qt教程] 在Qt图形界面中显示OpenCV图像的OpenGL Widget (第一部分)

    本文译自:http://www.robot-home.it/blog/en/software/tutorial-opencv-qt-opengl-widget-per-visualizzare-imm ...

  9. 关于OpenCV图像操作的默认参数问题

    本系列文章由 @yhl_leo 出品,转载请注明出处. 文章链接: http://blog.csdn.net/yhl_leo/article/details/51559490 在使用OpenCV以及其 ...

随机推荐

  1. paramiko分开执行多条命令 不像之前一样使用\n

    #!/usr/bin/env python#-*- encoding -*- import paramiko transport = paramiko.Transport(('192.168.11.1 ...

  2. ORA-00904: 标识符无效——解决方案

    转自:https://blog.csdn.net/jajavaja/article/details/49122639 建表时列名用双引号引着(用Navicat工具建表默认是加上双引号的),java连接 ...

  3. oracle常用函数总结(一)

    最近在读数据库存储过程,或者在xml里写sql时用到数据库函数,笔者觉得有必要总结一下,当然有的函数笔者也很懵逼,不过可以问度娘啊!好了!开始正题. )s from dual;--1 若nvl第一个参 ...

  4. cygwin选择安装包选项搭建NDK开发环境/配置cygwin的root权限

    9.Search是可以输入你要下载的包的名称,能够快速筛选出你要下载的包.那四个单选按钮是选择下边树的样式,默认就行,不用动.View默认是Category,建议改成full显示全部包再查,省的一些包 ...

  5. appium如何连接模拟器代码实例

    from appium import webdriver def connect(self): self.desired_caps = {} self.desired_caps['platformNa ...

  6. ztree 树的模糊搜索

    (转载),有个坑记录下: (原文)实现类似下面这种: /** * 展开树 * @param treeId */ function expand_ztree(treeId) { var treeObj ...

  7. __tostring和__invoke 方法

    首先放上代码: <?php class MagicTest{ //__tostring会在把对象转换为string的时候自动调用 public function __tostring() { r ...

  8. 36-图像有用区(dfs, bfs)

    http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=92 图像有用区域 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   ...

  9. c++ 拷贝构造函数 继承

    拷贝构造函数要求把所有变量都需要做拷贝.在有继承关系情况先,子类的拷贝构造函数,需要调用父类拷贝构造函数.示例代码如下: class Base{ public: virtual ~Base(); Ba ...

  10. CLRInjection - 通用托管注入(超级灰色按钮克星升级版)

    通用托管注入 - CLRInjection CLR软件系列第二发: 通用托管注入 - CLRInjection 软件简介:这款软件可以将任意托管DLL用插件的形式,注入到正在运行中的.net托管程序集 ...