今天在弄一个查找连通的最大面积的问题。

要把图像弄成黑底,白字,这样才可以正确找到。

然后调用下边的方法:

RETR_CCOMP:提取所有轮廓,并将轮廓组织成双层结构(two-level hierarchy),顶层为连通域的外围边界,次层位内层边界

#include #include using namespace cv;

using namespace std;

int main( int argc, char** argv )

{

Mat src = imread( argv[1] );

int largest_area=0;

int largest_contour_index=0;

Rect bounding_rect;

Mat thr;

cvtColor( src, thr, COLOR_BGR2GRAY ); //Convert to gray

threshold( thr, thr, 125, 255, THRESH_BINARY ); //Threshold the gray

bitwise_not(thr,thr); //这里先变反转颜色

vector> contours; // Vector for storing contours

findContours( thr, contours, RETR_CCOMP, CHAIN_APPROX_SIMPLE ); // Find the contours in the image

for( size_t i = 0; i< contours.size(); i++ ) // iterate through each contour.

{

double area = contourArea( contours[i] ); // Find the area of contour

if( area > largest_area )

{

largest_area = area;

largest_contour_index = i; //Store the index of largest contour

bounding_rect = boundingRect( contours[i] ); // Find the bounding rectangle for biggest contour

}

}

drawContours( src, contours,largest_contour_index, Scalar( 0, 255, 0 ), 2 ); // Draw the largest contour using previously stored index.

imshow( "result", src );

waitKey();

return 0;

}

方法二: connectedComponentsWithStats

std::pair< int , int > MaxAreaFromSource(Mat srcImage, Mat &dstImage, int index)

{

/*

vector> contours; // Vector for storing contours

int largest_area=0;

size_t largest_contour_index=0;

Rect bounding_rect;

findContours( srcImage, contours, RETR_CCOMP, CHAIN_APPROX_SIMPLE ); // Find the contours in the image

for( size_t i = 0; i< contours.size(); i++ ) // iterate through each contour.

{

double area = contourArea( contours[i] ); // Find the area of contour

if( area > largest_area )

{

largest_area = area;

largest_contour_index = i; //Store the index of largest contour

bounding_rect = boundingRect( contours[i] ); // Find the bounding rectangle for biggest contour

}

}

Mat dst;

cvtColor(srcImage, dst, CV_GRAY2RGB);

drawContours( dst, contours,largest_contour_index, Scalar( 0, 255, 0 ), 2 ); // Draw the largest contour using previously stored index.

imshow( "result", dst );

waitKey();

printf("%%%%%%%%%%%max area:%d\n", largest_area);

return make_pair( largest_area, index);

*/

cv::Mat img_bool, labels, stats, centroids, img_color, img_gray;

//连通域计算

int nccomps = cv::connectedComponentsWithStats (

srcImage, //二值图像

labels, //和原图一样大的标记图

stats, //nccomps×5的矩阵 表示每个连通区域的外接矩形和面积(pixel)

centroids //nccomps×2的矩阵 表示每个连通区域的质心

);

//cv::imshow("labels", labels);

//cv::waitKey();

vectorcolors(nccomps);

colors[0] = cv::Vec3b(0,0,0); // background pixels remain black.

printf( "index:%d==================\n",index );

vector< int >vec_width,vec_area,vec_height;

for(int label = 1; label < nccomps; ++label)

{

colors[label] = cv::Vec3b( (std::rand()&255), (std::rand()&255), (std::rand()&255) );

std::cout << "Component "<< label << std::endl;

std::cout << "CC_STAT_LEFT = " << stats.at(label,cv::CC_STAT_LEFT) << std::endl;

std::cout << "CC_STAT_TOP = " << stats.at(label,cv::CC_STAT_TOP) << std::endl;

std::cout << "CC_STAT_WIDTH = " << stats.at(label,cv::CC_STAT_WIDTH) << std::endl;

std::cout << "CC_STAT_HEIGHT = " << stats.at(label,cv::CC_STAT_HEIGHT) << std::endl;

std::cout << "CC_STAT_AREA = " << stats.at(label,cv::CC_STAT_AREA) << std::endl;

std::cout << "CENTER = (" << centroids.at(label, 0)

int area = stats.at(label,cv::CC_STAT_AREA);

int left = stats.at(label,cv::CC_STAT_LEFT);

int top = stats.at(label,cv::CC_STAT_TOP);

int width = stats.at(label,cv::CC_STAT_WIDTH);

int height = stats.at(label,cv::CC_STAT_HEIGHT);

vec_area.push_back(area);

vec_width.push_back(width);

vec_height.push_back(height);

}

vector::iterator bigwidth = std::max_element(std::begin(vec_width), std::end(vec_width));

vector::iterator bigheight = std::max_element(std::begin(vec_height), std::end(vec_height));

vector::iterator bigarea = std::max_element(std::begin(vec_area), std::end(vec_area));

//printf( "area:%d------------width:%d height:%d \n", *bigarea, *bigwidth, *bigheight );

//按照label值,对不同的连通域进行着色

img_color = cv::Mat::zeros(srcImage.size(), CV_8UC3);

for( int y = 0; y < img_color.rows; y++ )

for( int x = 0; x < img_color.cols; x++ )

{

int label = labels.at(y, x);

CV_Assert(0 <= label && label <= nccomps);

img_color.at(y, x) = colors[label];

}

cv::imshow("color", img_color);

cv::waitKey();

return make_pair( *bigarea , index );

}

我先用这个函数实现了一下,效果正确,还是opencv demo 是正确的,网上找了个例子,害死我了。

说明一下:方法一 比 第二种方法 运行速度快很多哦! 这一点很重要。

opencv 最大连通域_opencv 查找连通区域 最大面积相关推荐

  1. opencv 最大连通域_opencv 查找连通区域 最大面积实例

    今天在弄一个查找连通的最大面积的问题. 要把图像弄成黑底,白字,这样才可以正确找到. 然后调用下边的方法: RETR_CCOMP:提取所有轮廓,并将轮廓组织成双层结构(two-level hierar ...

  2. OpenCV与图像处理学习九——连通区域分析算法(含代码)

    OpenCV与图像处理学习九--连通区域分析算法(含代码) 一.连通区域概要 二.Two-Pass算法 三.代码实现 一.连通区域概要 连通区域(Connected Component)一般是指图像中 ...

  3. opencv(十三)-快速连通区域分析

    索引目录 1.连通区域标记算法 2.剔除小连通区域 参考 1.连通区域标记算法 连接区域标记算法(connected component labeling algorithm)是图像分析中最常用的算法 ...

  4. OpenCV二值图像处理——阈值,连通区域分析(C++)

    阈值 阈值又叫临界值,是指一个效应能够产生的最低值或最高值 对于图像的直方图存在明显边界的图像,我们可以很容易找到这个阈值,但是如果图像直方图分界不明显,那么这个阈值的寻找将变得十分困难.因此我们存在 ...

  5. OpenCV删除面积小的区域 实现图像二值化分割 标记连通区域

    OpenCV删除面积小的区域 实现图像二值化分割 标记连通区域    [尊重原创,转载请注明出处]http://blog.csdn.net/guyuealian/article/details/781 ...

  6. c++读出像素矩阵_Python传numpy矩阵调c++(求3D图像连通区域)

    Python有很多种调c++的方法,有的复杂有的简单,有时使用的时候反而不知道到底该用哪一种比较好,其实没有最好的方法,只有适合不适合自己.本文从我所遇到的问题说起,然后讲述另一种比较简单的pytho ...

  7. Matlab形态学图像处理:二值图像分割 标记连通区域和重心位置 删除连通区域

    Matlab形态学图像处理:二值图像分割 标记连通区域和重心位置 删除连通区域 [尊重原创,转载请注明出处]http://blog.csdn.net/guyuealian/article/detail ...

  8. cv2.connectedComponentsWithStats 计算不规则连通区域

    cv2.connectedComponentsWithStats 计算不规则连通区域 num, labels, stats, centroids = cv2.connectedComponentsWi ...

  9. ViSP学习笔记(十四):连通区域跟踪

    开发环境:Ubuntu 18.04 LTS + ROS Melodic + ViSP 3.3.1 文章内容主要参考ViSP官方教学文档:https://visp-doc.inria.fr/doxyge ...

最新文章

  1. 启动controller节点nova组件服务,报错ERROR 13
  2. matlab无限长序列卷积,怎样求未知长度序列的卷积
  3. frida 安装特定版本
  4. RocketMQ(二)——系统架构及基本知识
  5. dos2unix命令找不到_Linux系统中的dos2unix命令
  6. formdata上传文件_封装一个多文件断点续传、分片上传、秒传、重试机制的组件...
  7. Bailian3703 寻找平面上的极大点【最值】
  8. 修改配置文件后不重启程序即时生效
  9. 使用npm-check-updates模块升级插件
  10. Android URL Scheme
  11. JAVA代码翻译更新(第五篇)
  12. 开源HTML编辑器xhEditor用法详解
  13. 12306列车时刻表查询api功能实现
  14. Pytorch 之torch.nn初探
  15. 聚观早报|苹果默认不再接受隔空投送;Mete被裁员工将获薪水补偿
  16. pandas读取excel数据并对重复数据进行标记或者删除
  17. 各种Lisp系语言大检阅
  18. Black Arch虚拟机安装及配置
  19. 斩获iOS美国游戏榜单TOP2 触宝游戏战略进入高速发展轨道
  20. 移动机器人技术(9)-- 全向移动机器人Modeling and Control

热门文章

  1. 微信小程序连接阿里云物联网平台操控设备(IOT)一
  2. nginx设置超时时间
  3. 仙人掌直径--poj3567/bzoj1023
  4. 演进分组系统的几个概念 EPS/EPC/SAE/LTE/EUTRAN
  5. Kafka-eagle 安装教程
  6. 如何使用 OceanBase 分区表进行水平拆分
  7. jQuery实用的媒体视频播放器插件
  8. 怎么把苹果手机通讯录导入华为手机_如何将通讯录批量转换为vcf格式导入手机,苹果手机如何批量删除通讯录?
  9. Python学习之魔法方法
  10. linux C++ 使用openssl rsa算法实现对计算机物理地址进行签名和认证