zoukankan      html  css  js  c++  java
  • 【OpenCV学习】图像轮廓的提取和绘制

    作者:gnuhpc
    出处:http://www.cnblogs.com/gnuhpc/

    #include "highgui.h"
    #include "cv.h"
    #include <iostream>
    #include <iomanip>
    
    using namespace std;
    
    int main(void)
    {
        int i=0;
        int mode = CV_RETR_CCOMP;//设置提取轮廓模式
        int contours_num=0;//提取轮廓的数目
        CvScalar external_color;//绘制轮廓线的颜色
        CvScalar hole_color;
        CvMemStorage *storage = cvCreateMemStorage(0);
        CvSeq *contours =0;//存储提取的轮廓图像
    
        IplImage *pImg = NULL;
        IplImage *pContourImg = NULL;//显示提取的轮廓图像
        IplImage *src=/blog.armyourlife.info/cvLoadImage("1.png",1);
    
        pImg = cvCreateImage(cvGetSize(src),src->depth,1);
        pContourImg =cvCreateImage(cvGetSize(pImg),IPL_DEPTH_8U,3);
        cvCvtColor(src,pImg,CV_BGR2GRAY);//将读取的图像转化为灰度图像
        cvNamedWindow("src",1);
        cvNamedWindow("contour",1);
        cvShowImage("src",src);//显示原图
        cvThreshold(pImg,pImg,200,255,CV_THRESH_BINARY);//二值化
        mode = CV_RETR_LIST;
        contours_num=cvFindContours(pImg,storage,&contours,sizeof(CvContour),mode,CV_CHAIN_APPROX_NONE);
        cout<<contours_num<<" "<<endl;//打印找到的轮廓的数目
        for (;contours!=0;contours=contours->h_next)
        {
            hole_color=CV_RGB(rand()&255,rand()&255,rand()&255);
            external_color = CV_RGB(rand()&255,rand()&255,rand()&255);
            cvDrawContours(pContourImg,contours,external_color,hole_color,1,2,8);
        }
    
        cvShowImage("contour",pContourImg);
        cvWaitKey(0);
        cvReleaseImage(&src);
        cvReleaseImage(&pImg);
        cvReleaseImage(&pContourImg);
        cvReleaseMemStorage(&storage);
    }


                   作者:gnuhpc
                   出处:http://www.cnblogs.com/gnuhpc/
                   除非另有声明,本网站采用知识共享“署名 2.5 中国大陆”许可协议授权。


    分享到:

  • 相关阅读:
    7.15 更改累计和中的值
    7.10 计算中间值
    7.11 求总和的百分比
    7.9 计算模式
    7.8 计算累计差
    7.4 求一个表的行数
    7.6 生成累计和
    7.7 生成累积乘积
    7.2 求某列中的最小、最大值
    7.3 对某列的值求和
  • 原文地址:https://www.cnblogs.com/gnuhpc/p/2573806.html
Copyright © 2011-2022 走看看