OpenCV入门系列 —— findContours查找轮廓

OpenCV入门系列 —— findContours查找轮廓


前言

随着工业自动化、智能化的不断推进,机器视觉(2D/3D)在工业领域的应用和重要程度也同步激增(识别、定位、抓取、测量,缺陷检测等),而针对不同作业场景进行解决方案设计时,通常会借助PCL、OpenCV、Eigen等简单方便的开源算法库进行方案的快速验证和迭代以满足作业场景下的目标需求。

为了让对工业机器视觉方向感兴趣的同学能够少走一些弯路,故推出了此一系列简易入门教程示例,让初次使用者能够最简单直观地感受到当前所用算法模块的执行效果。

后续会逐步扩增与工业机器视觉相关的一些其它内容,如:

项目案例剖析场景数据分析基础算法模块相机评测 等;

如有兴趣可加入群聊(若入群二维码被屏蔽,则可以通过Q群(1032861997)或评论、私信博主“群聊”,邀请入群),与同道同学及圈内同行一起交流讨论。


程序说明

查找图片中的轮廓,并对每个轮廓区域进行随机着色;

输出结果

在这里插入图片描述

代码示例

/*
 * @File: find_contours.cpp
 * @Brief: opencv course
 * @Description: 展示轮廓检测效果
 * @Version: 0.0.1
 * @Author: MuYv
 */
#include <iostream>
#include <string>
#include <opencv2/opencv.hpp>



int main(int argc, char** argv){
    
    
    if(argc != 2){
    
    
        std::cout<<"Usage: exec img_file_path"<<std::endl;
        return -1;
    }
    const std::string kImgFilePath = argv[1];   // "../imgs/plant.jpg"

    // 加载为 rgb 3通道彩色图数据
    cv::Mat img_src = cv::imread(kImgFilePath, cv::IMREAD_GRAYSCALE);

    // 初始化结果图
	cv::Mat img_dst = cv::Mat::zeros(img_src.rows, img_src.cols, CV_8UC3);

	// srcImage取大于阈值119的那部分
	cv::Mat img_threshold = img_src > 119;

	// 定义轮廓和层次结构
	std::vector<std::vector<cv::Point> > contours;
	std::vector<cv::Vec4i> hierarchy;

	// 查找轮廓
	cv::findContours(img_threshold, contours, hierarchy, cv::RETR_CCOMP, cv::CHAIN_APPROX_SIMPLE);

	// 遍历所有顶层的轮廓, 以随机颜色绘制出每个连接组件颜色
	for( int index = 0; index >= 0; index = hierarchy[index][0] ){
    
    
		cv::Scalar color( rand()&255, rand()&255, rand()&255 );
		cv::drawContours( img_dst, contours, index, color, cv::FILLED, 8, hierarchy );
	}

	// 显示最后的轮廓图
	cv::imshow( "轮廓图", img_dst );
    cv::imshow("img_src", img_src);
	cv::imshow("img_threshold", img_threshold);
    
    // 等待n毫秒后关闭窗口,0代表一直开启,直到任意按键触发关闭窗口
    cv::waitKey(0);

    return 0;
}

注:部分测试所用图片数据来源于网络,如有侵权,请联系博主删除,谢谢。

猜你喜欢

转载自blog.csdn.net/memorynode/article/details/125174787