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; 
 
}

原图:

二值化反色图:

最小正矩形图:

最小正矩形信息:

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

相关文章

  • Opencv实现拼图板游戏

    Opencv实现拼图板游戏

    这篇文章主要为大家详细介绍了Opencv实现拼图板小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • 浅理解C++ 人脸识别系统的实现

    浅理解C++ 人脸识别系统的实现

    这篇文章主要介绍了浅理解C++ 人脸识别系统的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • strcat函数实现简单示例

    strcat函数实现简单示例

    这篇文章主要介绍了strcat函数实现简单示例,需要的朋友可以参考下
    2014-03-03
  • 使用C++创建多个IPC机制的上层接口

    使用C++创建多个IPC机制的上层接口

    设计一个上层的IPC接口,这个接口将在未来封装底层的通信机制,这样的设计要求接口足够抽象,以便于底层实现的细节对上层用户透明,本文给大家介绍了如何使用C++创建多个IPC机制的上层接口,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • C++约瑟夫环问题详解

    C++约瑟夫环问题详解

    大家好,本篇文章主要讲的是C++约瑟夫环问题详解 ,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2022-01-01
  • c++优先队列(priority_queue)用法详解

    c++优先队列(priority_queue)用法详解

    这篇文章主要介绍了c++优先队列(priority_queue)用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • C语言实现绘制南丁格尔玫瑰图的示例代码

    C语言实现绘制南丁格尔玫瑰图的示例代码

    玫瑰图中有一种不等半径的统计图称为南丁格尔玫瑰图,网上很热门,是一很有艺术感的漂亮的统计图,下面我们就来看看如何使用C语言绘制它吧
    2024-03-03
  • C++ LeetCode1945题解字符串转化后的各位数字之和

    C++ LeetCode1945题解字符串转化后的各位数字之和

    这篇文章主要为大家介绍了C++ LeetCode1945题解字符串转化后的各位数字之和示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • 初识C++ Vector模板与实例化原理

    初识C++ Vector模板与实例化原理

    这篇文章主要为大家介绍了初识C++ Vector模板与实例化原理,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • VSCode插件开发全攻略之跳转到定义、自动补全、悬停提示功能

    VSCode插件开发全攻略之跳转到定义、自动补全、悬停提示功能

    这篇文章主要介绍了VSCode插件开发全攻略之跳转到定义、自动补全、悬停提示,需要的朋友可以参考下
    2020-05-05

最新评论