热门标签 | HotTags
当前位置:  开发笔记 > 人工智能 > 正文

opencv求解区域的内接矩形

这篇文章主要为大家详细介绍了opencv求解区域的内接矩形,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

实验室项目中,希望求取一个近似圆形区域的质心,原本使用最小外接圆的质心来等效为该区域质心。但是由于部分区域的形状过于不规则导致发生质心偏移现象。如下图:

蓝色为实际要求质心。红色为等效圆质心

为获取较为准确的质心,拟用最大内接矩形的中心作为该区域质心。

采用改进的中心扩散法求内接矩形:先以最小外接矩的中心作为算法的起点进行中心扩散。得到一个内解矩形,在对最小外接矩的中心进行8邻域的遍历,应用中心扩散法分别求取内接矩,以面积最大的内接矩作为最大内接矩。

使用Opencv关键代码如下:

/**
 * @brief 求取连通区域内接矩
 * @param img:输入图像,单通道二值图,深度为8
 * @param center:最小外接矩的中心
 * @return 最大内接矩形
 * 基于中心扩展算法
 */
cv::Rect InSquare(Mat &img,const Point center)
{
  // --[1]参数检测
  if(img.empty()||
      img.channels()>1
      ||img.depth()>8)
    return Rect();
  //[1]
 
  // --[2] 初始化变量
  int edge[4];
  edge[0]=center.y+1;//top
  edge[1]=center.x+1;//right
  edge[2]=center.y-1;//bottom
  edge[3]=center.x-1;//left
  //[2]
 
  // --[3]边界扩展(中心扩散法)
  bool EXPAND[4]={1,1,1,1};//扩展标记位
  int n=0;
  while (EXPAND[0]||EXPAND[1]||EXPAND[2]||EXPAND[3])
  {
    int edgeID=n%4;
    EXPAND[edgeID]=expandEdge(img,edge,edgeID);
 
    n++;
  }
  //[3]
 
  qDebug()<nr)
      return false;
    for(int i=edge[3];i<=edge[1];++i)
    {
      if(img.at(edge[0],i)==0)
        return false;
    }
    edge[0]++;
    return true;
    break;
  case 1:
    if(edge[1]>nc)
      return false;
    for(int i=edge[2];i<=edge[0];++i)
    {
      if(img.at(i,edge[1])==0)
        return false;
    }
    edge[1]++;
    return true;
    break;
  case 2:
    if(edge[2]<0)
      return false;
    for(int i=edge[3];i<=edge[1];++i)
    {
      if(img.at(edge[2],i)==0)
        return false;
    }
    edge[2]--;
    return true;
    break;
  case 3:
    if(edge[3]<0)
      return false;
    for(int i=edge[2];i<=edge[0];++i)
    {
      if(img.at(i,edge[3])==0)
        return false;
    }
    edge[3]--;
    return true;
    break;
  default:
    return false;
    break;
  }
}

效果:

黑色为内接矩中心,红色为最小外接圆中心

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


推荐阅读
  • 二维几何变换矩阵解析
    本文详细介绍了二维平面上的三种常见几何变换:平移、缩放和旋转。通过引入齐次坐标系,使得这些变换可以通过统一的矩阵乘法实现,从而简化了计算过程。文中不仅提供了理论推导,还附有Python代码示例,帮助读者更好地理解这些概念。 ... [详细]
  • 本文详细介绍了福昕软件公司开发的Foxit PDF SDK ActiveX控件(版本5.20),并提供了关于其在64位Windows 7系统和Visual Studio 2013环境下的使用方法。该控件文件名为FoxitPDFSDKActiveX520_Std_x64.ocx,适用于集成PDF功能到应用程序中。 ... [详细]
  • Redux入门指南
    本文介绍Redux的基本概念和工作原理,帮助初学者理解如何使用Redux管理应用程序的状态。Redux是一个用于JavaScript应用的状态管理库,特别适用于React项目。 ... [详细]
  • 历经三十年的开发,Mathematica 已成为技术计算领域的标杆,为全球的技术创新者、教育工作者、学生及其他用户提供了一个领先的计算平台。最新版本 Mathematica 12.3.1 增加了多项核心语言、数学计算、可视化和图形处理的新功能。 ... [详细]
  • 机器学习核心概念与技术
    本文系统梳理了机器学习的关键知识点,涵盖模型评估、正则化、线性模型、支持向量机、决策树及集成学习等内容,并深入探讨了各算法的原理和应用场景。 ... [详细]
  • 如何使用Ping命令来测试网络连接?当网卡安装和有关参数配置完成后,可以使用ping命令来测试一下网络是否连接成功。以winXP为例1、打开XP下DOS窗口具体操作是点击“开始”菜 ... [详细]
  • 本文总结了优化代码可读性的核心原则与技巧,通过合理的变量命名、函数和对象的结构化组织,以及遵循一致性等方法,帮助开发者编写更易读、维护性更高的代码。 ... [详细]
  • 深入解析Java虚拟机(JVM)架构与原理
    本文旨在为读者提供对Java虚拟机(JVM)的全面理解,涵盖其主要组成部分、工作原理及其在不同平台上的实现。通过详细探讨JVM的结构和内部机制,帮助开发者更好地掌握Java编程的核心技术。 ... [详细]
  • 本文详细介绍了Hive中用于日期和字符串相互转换的多种函数,包括从时间戳到日期格式的转换、日期到时间戳的转换,以及如何处理不同格式的日期字符串。通过这些函数,用户可以轻松实现日期和字符串之间的灵活转换,满足数据处理中的各种需求。 ... [详细]
  • 1.执行sqlsever存储过程,消息:SQLServer阻止了对组件“AdHocDistributedQueries”的STATEMENT“OpenRowsetOpenDatas ... [详细]
  • 本文将详细介绍多个流行的 Android 视频处理开源框架,包括 ijkplayer、FFmpeg、Vitamio、ExoPlayer 等。每个框架都有其独特的优势和应用场景,帮助开发者更高效地进行视频处理和播放。 ... [详细]
  • 本文详细介绍了PHP中的多条件分支结构,包括if、elseif和else语句的使用方法。通过具体示例,解释了如何根据不同的条件执行相应的代码块,并确保每个条件只能触发一次。 ... [详细]
  • 本文介绍了如何在 C# 和 XNA 框架中实现一个自定义的 3x3 矩阵类(MMatrix33),旨在深入理解矩阵运算及其应用场景。该类参考了 AS3 Starling 和其他相关资源,以确保算法的准确性和高效性。 ... [详细]
  • 本文回顾了2017年的转型和2018年的收获,分享了几家知名互联网公司提供的工作机会及面试体验。 ... [详细]
  • 随着生活节奏的加快和压力的增加,越来越多的人感到不快乐。本文探讨了现代社会中导致人们幸福感下降的各种因素,并提供了一些改善建议。 ... [详细]
author-avatar
男孩形式恋人
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有