开发者社区> season雅宁> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

OpenCV空洞填充算法

简介: 讨论帖: http://bbs.csdn.net/topics/391542633   在Matlab下,使用imfill可以很容易的完成孔洞填充操作,感觉这是一个极为常用的方法,然而不知道为什么Opencv里面却没有集成这个函数。
+关注继续查看


讨论帖:

  在Matlab下,使用imfill可以很容易的完成孔洞填充操作,感觉这是一个极为常用的方法,然而不知道为什么Opencv里面却没有集成这个函数。在网上查了好多关于Opencv下的孔洞填充方法,大部分使用轮廓查找方法去做的,但对于这种方法,总感觉不是特别好。之前了解过冈萨雷斯那本书上的孔洞填充算法,所以想着手重新写一个。这里借鉴了冈萨雷斯书上的集合运算方法(并不完全一样)

    大致思路如下:

    0, 设原图像为 A。

    1, 首先A向外延展一到两个像素,并将值填充为背景色(0),标记为B。

    2, 使用floodFill函数将B的大背景填充,填充值为前景色(255),种子点为(0,0)即可(步骤一可以确保(0,0)点位于大背景),标记为C。

    3, 将填充好的图像裁剪为原图像大小(去掉延展区域),标记为D。

    4, 将D取反与A相加即得填充的图像,E=A|(~D)。


// fillhole.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

 
#include <opencv2/core/core.hpp>    
#include <opencv2/highgui/highgui.hpp>  
#include "opencv2/imgproc/imgproc.hpp"
	 

	#pragma comment(lib,"opencv_core2410d.lib")                  
	#pragma comment(lib,"opencv_highgui2410d.lib")                  
	#pragma comment(lib,"opencv_imgproc2410d.lib")     
	  
using namespace std;  
using namespace cv;  




void fillHole(const Mat srcBw, Mat &dstBw)
{
	Size m_Size = srcBw.size();
	Mat Temp=Mat::zeros(m_Size.height+2,m_Size.width+2,srcBw.type());//延展图像
	srcBw.copyTo(Temp(Range(1, m_Size.height + 1), Range(1, m_Size.width + 1)));

	cv::floodFill(Temp, Point(0, 0), Scalar(255));

	Mat cutImg;//裁剪延展的图像
	Temp(Range(1, m_Size.height + 1), Range(1, m_Size.width + 1)).copyTo(cutImg);

	dstBw = srcBw | (~cutImg);
}

int main()
{
Mat img=cv::imread("23.jpg");

Mat gray;
cv::cvtColor(img, gray, CV_RGB2GRAY);

Mat bw;
cv::threshold(gray, bw, 0, 255, CV_THRESH_BINARY | CV_THRESH_OTSU);

Mat bwFill;
fillHole(bw, bwFill);

imshow("填充前", gray);
imshow("填充后", bwFill);
waitKey();
return 0;
}




我调试好的工程:点击打开链接

http://download.csdn.net/detail/wangyaninglm/9389329





版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
OpenCV 边缘检测之Canny算法(代码应用)
OpenCV 边缘检测之Canny算法(代码应用)
0 0
项目实战:Qt+OpenCV图像处理与识别算法平台(持续更新,当前v1.7.0)
项目实战:Qt+OpenCV图像处理与识别算法平台(持续更新,当前v1.7.0)
0 0
图像插值算法和OpenCV框架
图像插值算法和OpenCV框架
0 0
Python 机器视觉 - 基于opencv图像模板匹配实现的简单人脸匹配实例演示,matchTemplate的6大模板匹配算法
Python 机器视觉 - 基于opencv图像模板匹配实现的简单人脸匹配实例演示,matchTemplate的6大模板匹配算法
0 0
OpenCV | 分水岭算法进行图像分割
OpenCV | 分水岭算法进行图像分割
0 0
OpenCV的RobustMatch匹配算法
OpenCV的RobustMatch匹配算法
0 0
OpenCV算法加速(3)使用OpenCL
OpenCV算法加速(3)使用OpenCL
0 0
OpenCV算法加速(2)MMX、SSE工业视觉算法优化
OpenCV算法加速(2)MMX、SSE工业视觉算法优化
0 0
+关注
season雅宁
大数据生态圈,计算机视觉,机器学习,高端技术的爱好者,话不多说,上代码!!!
文章
问答
文章排行榜
最热
最新
相关电子书
更多
数据+算法定义新世界
立即下载
基于深度学习的广告CTR预估算法
立即下载
阿里云千亿特征深度学习算法XNN实践
立即下载