• 欢迎大家交换友链,可在https://www.stubbornhuang.com/申请友情链接进行友链交换申请!

  • 本站会放置Google广告用于维持域名以及网站服务器费用。

  • 本站由于前段时间遭受到大量临时和国外邮箱注册,所以对可注册的邮箱类型进行了限制!

  • 如果觉得本站的内容有帮助,可以考虑打赏博主哦!

  • 问题反馈可发送邮件到stubbornhuang@qq.com

  • 工资「喂饱肚子」,副业「养活灵魂」!

  • 感谢大家访问本站,希望本站的内容可以帮助到大家!

  • 计算机图形学与计算几何经典必备书单整理,下载链接可参考:https://www.stubbornhuang.com/1256/

  • 在本站开通年度VIP,无限制下载本站资源和阅读本站文章

OpenCV – 使用findContours()查找图片轮廓线,并将轮廓线坐标点输出

OpenCV 发布于2019-11-18 阅读 8,414次 0次评论 0次点赞 本文共1290个字,阅读需要4分钟。

1 示例代码

使用findContours()查找图片轮廓线,并将轮廓线坐标点输出,访问二维vector,使用迭代器和下标两种方式。

#include <iostream> 
#include <fstream>
#include <opencv2/opencv.hpp>
#include <opencv2/core/core.hpp> 
#include<opencv2/highgui/highgui.hpp> 
#include <opencv2/imgproc/imgproc.hpp>
#include <math.h>
using namespace cv; 
using namespace std;
int main() 
{ 
    //载入原始图,且必须以二值图模式载入
    Mat M=imread("E:/A.bmp",0);
    imshow("原始图",M);

    waitKey(500); //等待5000ms后窗口自动关闭
    //初始化结果图
    Mat dstImage=Mat::zeros(M.rows,M.cols,CV_8UC3);

    //M提取阈值小于250的部分
    M=M<250;
    imshow("阈值",M);
    waitKey(50);
    //定义轮廓和层次结构
    vector<vector<Point>>contours;
    vector<Vec4i>hierarchy;
    findContours(M,contours,hierarchy,RETR_EXTERNAL,CHAIN_APPROX_NONE);
    //迭代器输出
    /*for (vector<vector<Point>>::iterator it=contours.begin();it!=contours.end();++it)
    {
        for (vector<Point>::iterator inner_it=it->begin();inner_it!=it->end();++inner_it)
        {
            cout<<*inner_it<<endl;
        }
    }
*/
    //下标输出
    for (int i=0;i<contours.size();i++)
    {
        for (int j=0;j<contours[i].size();j++)
        {
            cout<<contours[i][j].x<<"   "<<contours[i][j].y<<endl;
            ofstream f;
            f.open("E:/坐标轮廓线.txt",ios::out|ios::app);
            f<<contours[i][j].x<<"  "<<contours[i][j].y<<endl;
        }
    }

    //遍历顶层轮廓,以随机颜色绘制出每个连接组件颜色
    int index=0;
    for (;index>=0;index=hierarchy[index][0])
    {
        Scalar color(rand()%255,rand()%255,rand()%255);
        drawContours(dstImage,contours,index,color,1,8,hierarchy);
    }

    imshow("轮廓图",dstImage);
    waitKey(5000); //等待5000ms后窗口自动关闭
    getchar();
}

欢迎扫码关注我的微信公众号,及时获取文章更新

微信公众号二维码

本文作者:StubbornHuang

版权声明:本文为站长原创文章,如果转载请注明原文链接!

原文标题:OpenCV – 使用findContours()查找图片轮廓线,并将轮廓线坐标点输出

原文链接:https://www.stubbornhuang.com/441/

发布于:2019年11月18日 22:32:55

修改于:2023年06月26日 22:53:49

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

文章末尾
上一篇
OpenCV - 新建一个图片,并在图片上画由一点到另一点的直线,采用反走样形式
OpenCV
下一篇
OpenCV - 静态图片人脸检测和摄像头人脸检测
OpenCV
当前分类随机文章推荐

发表评论

您必须 [ 登录 ] 才能发表留言!

关注我们的公众号

微信公众号