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

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

然后调用下边的方法:

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();

vector<:vec3b> colors(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) <(label, 1) << ")"<< std::endl << std::endl;

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<:vec3b>(y, x) = colors[label];

}

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

cv::waitKey();

return make_pair( *bigarea , index );

}

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

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

以上这篇opencv 查找连通区域 最大面积实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

python 连通区域_opencv 查找连通区域 最大面积实例相关推荐

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

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

  2. opencv 最大连通域_opencv 查找连通区域 最大面积

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

  3. python 连通区域_二值图像连通区域标记

    原像素矩阵M为: 根据原像素矩阵M大小,初始化标记矩阵labelM: 算法流程 1.    首先要确定是标记8邻域连通还是4邻域连通,如果是8邻域连通,就用模板1,如果是4邻域连通,就用模板2.中间像 ...

  4. 深度学习,分割后处理之通过连通成分分析去除假阳性区域,提高分割准确度

    用深度学习方法得到的分割结果,会有一些假阳性区域.通过去除这些假阳性区域,可以提高分割结果. 比如说做肾分割,大家都知道,肾只有左右两边有,如果分割结果出现了三个区域,则可以根据常识,去除那个假阳性区 ...

  5. 联通块 【题目描述】 一个n * m的方格图,一些格子被涂成了黑色,在方格图中被标为1,白色格子标为0。问有多少个四连通的黑色格子连通块。四连通的黑色格子连通块指的是一片由黑色格子组成的区域,其中的每

    联通块 [题目描述] 一个n * m的方格图,一些格子被涂成了黑色,在方格图中被标为1,白色格子标为0.问有多少个四连通的黑色格子连通块.四连通的黑色格子连通块指的是一片由黑色格子组成的区域,其中的每 ...

  6. 用matlab给图片标记区域,MATLAB二值图像连通区域标记(两步法)

    posted on2012-12-06 16:24Dsp Tian 两步法中第二步是比较麻烦的,其中用到了不相交集合的一些理论,尤其是不相交集合森林,这里的find_set函数就是参考<算法导论 ...

  7. kotlin 查找id_Kotlin程序查找Square区域

    kotlin 查找id Formula to find area of Square: area = side*side 查找Square面积的公式: area = side * side Given ...

  8. VBA Excel如何在工作表区域内查找某个值,发回这个值所在的行号、列号

    用VBA代码编写,如何在工作表区域内查找某个值,发回这个值所在的行号.列号 spwangxu | 浏览 7128 次 推荐于2016-01-03 11:29:18 最佳答案 1 2 3 4 5 6 7 ...

  9. Python批量裁剪图形外围空白区域-续

    一.基本描述 批量裁剪掉图片的背景区域,一般是白色背景,从而减少背景值的干扰和减少存储空间. 原文链接:Python批量裁剪图形外围空白区域 原文是通过检索所有图片的最小裁剪区域坐标值,然后再对图片进 ...

  10. 四连通,和八连通的详解(MATLAB)

    转至:http://www.cnblogs.com/xiaojidan/archive/2012/08/20/2647261.html 功能:标注二进制图像中已连接的部分. 语法:L = bwlabe ...

最新文章

  1. tar 和gzip 的区别
  2. 计算机窗口还原,win8系统找回计算机窗口“回收站”的还原办法
  3. 微软算法100题11 求二叉树中两节点之间的最大距离
  4. HDU 5112 A Curious Matt 水题
  5. linux下将硬件时钟调整为与本地时钟一致
  6. oracle 表结构语句,oracle查询表结构语句
  7. No space left on device 解决 Cydia 安装应用错误
  8. php thread linux,Linux_linux内核函数kernel_thread,设备驱动程序中,如果需要几 - phpStudy...
  9. Web前端笔记-two.js画三角形及画tip含tip旋转
  10. PyCharm2019.1.1安装(Win10)
  11. SAP License:固定资产减值的两种逻辑
  12. Golang slice高级应用
  13. Oracle-并行多线程和视图view的应用
  14. 基于MATLAB步态算法仿真的六足仿生机器人
  15. c++用两个队列实现一个栈
  16. win 安装 Xshell 5
  17. 关于html5小游戏的书,HTML5小游戏:書道 - 书法之境 道之升华
  18. AM5SE-IS防孤岛保护装置如何解决分布式光伏发电过程中的影响?
  19. 京东云主机使用-搭建简单网页(macOS)
  20. 网络工程师十月份免费讲座

热门文章

  1. python习题练习1224
  2. 计算机扫盲教程,cmd应用基础 扫盲教程 | Lellansin's 冰森
  3. 语音论文阅读TINY TRANSDUCER: A HIGHLY-EFFICIENT SPEECH RECOGNITION MODEL ON EDGE DEVICES
  4. 服务器word文档会是只读的,Word自动变只读模式怎么办? 这样可取消Word只读
  5. c语言汇编混合编译不了,IAR汇编与C语言混合编程的问题(内附源程序)
  6. 苹果手机linux系统版本号,Linux下查看系统版本号信息的方法(转)
  7. ArcGIS Pro 创建tpk
  8. 虾皮店铺如何快速上传商品
  9. Mplayer播放器程序设计Linux,Linux下编程实现mplayer播放器总结
  10. 微服务守护神-Sentinel-概念