今天在弄一个查找连通的最大面积的问题。
要把图像弄成黑底,白字,这样才可以正确找到。
然后调用下边的方法:
RETR_CCOMP:提取所有轮廓,并将轮廓组织成双层结构(two-level hierarchy),顶层为连通域的外围边界,次层位内层边界
#include <opencv2/imgproc.hpp> #include <opencv2/highgui.hpp> 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<vector<Point> > 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<vector<cv::Point> > 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<cv::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<int>(label,cv::CC_STAT_LEFT) << std::endl; std::cout << "CC_STAT_TOP = " << stats.at<int>(label,cv::CC_STAT_TOP) << std::endl; std::cout << "CC_STAT_WIDTH = " << stats.at<int>(label,cv::CC_STAT_WIDTH) << std::endl; std::cout << "CC_STAT_HEIGHT = " << stats.at<int>(label,cv::CC_STAT_HEIGHT) << std::endl; std::cout << "CC_STAT_AREA = " << stats.at<int>(label,cv::CC_STAT_AREA) << std::endl; std::cout << "CENTER = (" << centroids.at<double>(label, 0) <<","<< centroids.at<double>(label, 1) << ")"<< std::endl << std::endl; int area = stats.at<int>(label,cv::CC_STAT_AREA); int left = stats.at<int>(label,cv::CC_STAT_LEFT); int top = stats.at<int>(label,cv::CC_STAT_TOP); int width = stats.at<int>(label,cv::CC_STAT_WIDTH); int height = stats.at<int>(label,cv::CC_STAT_HEIGHT); vec_area.push_back(area); vec_width.push_back(width); vec_height.push_back(height); } vector<int>::iterator bigwidth = std::max_element(std::begin(vec_width), std::end(vec_width)); vector<int>::iterator bigheight = std::max_element(std::begin(vec_height), std::end(vec_height)); vector<int>::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<int>(y, x); CV_Assert(0 <= label && label <= nccomps); img_color.at<cv::Vec3b>(y, x) = colors[label]; } cv::imshow("color", img_color); cv::waitKey(); return make_pair( *bigarea , index ); }
我先用这个函数实现了一下,效果正确,还是opencv demo 是正确的,网上找了个例子,害死我了。
说明一下:方法一 比 第二种方法 运行速度快很多哦! 这一点很重要。
以上这篇opencv 查找连通区域 最大面积实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
opencv,连通区域,面积
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】