OpenCV实现最小外接正矩形

 更新时间:2020年07月21日 11:38:48   作者:fancy_MSF  
这篇文章主要为大家详细介绍了OpenCV实现最小外接正矩形,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了OpenCV实现最小外接正矩形的具体代码,供大家参考,具体内容如下

#include "stdafx.h" 
#include "cv.h"
#include "highgui.h" 
#include "cxcore.h"
#include "math.h" 
#include <iostream.h>
int main(int argc, char* argv[])
 
{  
 
 IplImage *src; 
 IplImage *dst;
 IplImage *ROI;
 CvMemStorage* storage=cvCreateMemStorage(0); 
 CvSeq* contour=0; 
 src=cvLoadImage("I:\\test.jpg",0);
 cvNamedWindow("image0",1);
 cvShowImage("image0",src);
 
 int  hei=src->height;
 int wid=src->width; 
 uchar *data;
 data=(uchar*)src->imageData;
 int widstep=src->widthStep;
 int channel=src->nChannels;
 dst=cvCreateImage(cvSize(wid,hei),IPL_DEPTH_8U,3);
 ROI=cvCreateImage(cvSize(wid,hei),IPL_DEPTH_8U,3);
 
 for (int i=0;i<hei;i++)
 
 {
 
   for(int j=0;j<wid;j++)
 
   {
 
    if (data[i*widstep+j*channel]>120)
 
    {
 
      data[i*widstep+j*channel]=0;
 
    }
 
    else
 
    {
 
      data[i*widstep+j*channel]=255;
 
    }
 
   }
 
 }
 
 cvNamedWindow("image",0); 
 cvShowImage("image",src); 
 printf("图像的高为:%d,宽为:%d\n\n",hei,wid); 
 cvCvtColor(src, dst, CV_GRAY2BGR);;
cvFindContours(src,storage,&contour,sizeof(CvContour),CV_RETR_CCOMP,CV_CHAIN_APPROX_SIMPLE); 
 for(;contour!=0;contour=contour->h_next) 
 
 {
 
   double length =cvArcLength(contour); 
   double area =fabs(cvContourArea(contour)); 
   CvRect rect = cvBoundingRect(contour,1); 
   cout<<"Length="<<length<<"  Area="<<area<<endl;  
   CvPoint p1;
   CvPoint p2; 
   p1.x=rect.x; 
   p1.y=rect.y;
   p2.x=rect.x+rect.width;
   p2.y=rect.y+rect.height;
   cout<<"p1=("<<p1.x<<","<<p1.y<<")";
   cout<<"p2=("<<p2.x<<","<<p2.y<<")"<<endl;
   cvRectangle(dst,p1,p2,CV_RGB(255,0,0),1,8,0); 
 
 }
 
   cvNamedWindow("dst",1); 
   cvShowImage("dst",dst);
   cvWaitKey(0);
 
 return 0; 
 
}

原图:

二值化反色图:

最小正矩形图:

最小正矩形信息:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Qt线程池QThreadPool的使用详解

    Qt线程池QThreadPool的使用详解

    本文主要介绍了Qt线程池QThreadPool的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • C++简明讲解类型转换的使用与作用

    C++简明讲解类型转换的使用与作用

    类型转换(type cast),是高级语言的一个基本语法。它被实现为一个特殊的运算符,以小括号内加上类型名来表示,接下来让我们一起来详细了解
    2022-04-04
  • 浅谈c语言中类型隐性转换的坑

    浅谈c语言中类型隐性转换的坑

    下面小编就为大家带来一篇浅谈c语言中类型隐性转换的坑。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • 单线程会导致死锁你知道吗

    单线程会导致死锁你知道吗

    这篇文章主要为大家详细介绍了单线程会不会导致死锁,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • 如何把C++的源代码改写成C代码的方法

    如何把C++的源代码改写成C代码的方法

    这篇文章主要介绍了如何把C++的源代码改写成C代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • 深入C语言把文件读入字符串以及将字符串写入文件的解决方法

    深入C语言把文件读入字符串以及将字符串写入文件的解决方法

    本篇文章是对C语言把文件读入字符串以及将字符串写入文件的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C语言实现数字雨效果

    C语言实现数字雨效果

    这篇文章主要为大家详细介绍了C语言实现数字雨效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • OpenCV中findContours函数参数详解

    OpenCV中findContours函数参数详解

    Opencv中通过使用findContours函数,简单几个的步骤就可以检测出物体的轮廓,很方便。本文将和大家一起探讨一下findContours方法中各参数的含义及用法,感兴趣的可以了解一下
    2022-08-08
  • C/C++读写JSON数据的详细过程记录

    C/C++读写JSON数据的详细过程记录

    JSON文件无论是在web开发、客户端开发、服务端等开发中都是应用比较广泛的的第一种轻量级数据交换格式,非常方便阅读和编写,下面这篇文章主要给大家介绍了关于C/C++读写JSON数据的详细过程,需要的朋友可以参考下
    2023-04-04
  • C语言中隐藏结构体的细节

    C语言中隐藏结构体的细节

    以笔者粗浅的认识,有两种最常用的方法,可以实现库内结构体定义的隐藏:接口函数形参使用结构体指针,接口函数形参使用句柄。
    2017-05-05

最新评论