判断两个矩形是否有重合部分

2024-06-05 14:38

本文主要是介绍判断两个矩形是否有重合部分,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在做人工智能项目,需要对两个矩形是否有重合做出判读

但注意的是,不是判断两个检测目标是否重合,检测目标的矩形只要左上角点和右下角点就可表示一个矩形,判断是否重合比较简单,但是现在是两个矩形是有一定旋转角度的,旋转角度不定,这样就没法像检测目标那样判断了。

目前使用四个点坐标表示一个矩形

判断分两个步骤:

一、当一个矩形的顶点在另一矩形内时,则可以判断两个矩形有重合。当这种情况不存在时,不能判断两个矩形不重合,需要借助其他方法判断。

判断矩形任意一顶点是否在另一矩形内,这样就需要利用点在多边形内的判断方法

可以参考博客https://blog.csdn.net/gf771115/article/details/42870605/,这篇博客对原理做了较为详细的讲解,并且提供了判断函数的不同演进形式。

int pnploy(const int poly_sides, const float *poly_X, const float *poly_Y, const float x, const float y)
{
     int i, j;
     j = poly_sides - 1;
     int res = 0;
     for (i = 0; i<poly_sides; i++)
     {
         if ((poly_Y[i]<y && poly_Y[j] >= y || poly_Y[j]<y && poly_Y[i] >= y) && (poly_X[i] <= x || poly_X[j] <= x))
         {
             res ^= ((poly_X[i] + (y - poly_Y[i]) / (poly_Y[j] - poly_Y[i])*(poly_X[j] - poly_X[i])) < x);
         }
         j = i;
     }
     return res;
}

该判断方法又叫射线法,由点向任何一个方向引出射线,与多边形交点数为奇数的,则点在多边形内,为偶数时,则点不在多边形内,为了简化这种判断过程,通常C++代码中使用水平射线来做计算。

二、当任一矩形的任何顶点都不在另一矩形内时,是不能判断两个矩形不重合的,因为还有一些特殊情况

特例如下,以下情况就是顶点不在另一个矩形内,但是矩形重合的。

这样就需要利用矩形边交叉来判断重合,通常矩形边交叉,则相互重合的。

这样就需要判断两条线段是否交叉,

https://www.cnblogs.com/wuwangchuxin0924/p/6218494.html 该博客为我提供了方法

判断线段交叉两个步骤,(1)快速排斥 (2)跨立实验,具体请参考我上面提供的链接
bool linecross(const Point a, const Point b, const Point c,const Point d)
{
    //快速排斥
    if(!(std::min(a.x,b.x)<=std::max(c.x,d.x)
         && std::min(c.x,d.x)<= std::max(a.x,b.x)
         && std::min(a.y,b.y)<= std::max(c.y,d.y)
         && std::min(c.y,d.y)<= std::max(a.y,b.y)))
        return false;
    //跨立实验
    double u,v,w,z;
    u=(c.x-a.x)*(b.y-a.y)-(b.x-a.x)*(c.y-a.y);  //AC×AB
    v=(d.x-a.x)*(b.y-a.y)-(b.x-a.x)*(d.y-a.y);  //AD×AB
    w=(a.x-c.x)*(d.y-c.y)-(d.x-c.x)*(a.y-c.y);  //CA×AB
    z=(b.x-c.x)*(d.y-c.y)-(d.x-c.x)*(b.y-c.y);  //CB×AB

    if(u*v<=1e-9&&w*z<=1e-9)
        return true;
    return false;
}

 

好,这样我们就可以基于以上提供的方法,做出两个矩形是否会重合的判断逻辑了,目前可以试用于四边形,没测试过其他形状。大家如果觉得判断有问题或者一些效率上的问题,欢迎提出。
//目前只支持4边形交互
bool checkployintersect(const Point ploy1[4], const Point ploy2[4])
{
    Polygon polygon1, polygon2;
    for(int i = 0; i< 4; i++)
    {
        polygon1.x[i]=ploy1[i].x;
        polygon1.y[i]=ploy1[i].y;
        polygon2.x[i]=ploy2[i].x;
        polygon2.y[i]=ploy2[i].y;
    }

    for(int i =0; i<4; i++)
    {
        if(pnploy(4,polygon1.x,polygon1.y, polygon2.x[i], polygon2.y[i]))
        {
            return true;
        }
        if(pnploy(4,polygon2.x,polygon2.y, polygon1.x[i], polygon1.y[i]))
        {
            return true;
        }
    }
    for(int i=0; i<4; i++)
    {
        for(int j=0; j<4; j++)
        {
            if(linecross(ploy1[i%4], ploy1[(i+1)%4], ploy2[j%4], ploy2[(j+1)%4]))
            {
                return true;
            }
        }
    }
    return false;
}

 

这篇关于判断两个矩形是否有重合部分的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1033336

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Linux实现查看某一端口是否开放

《Linux实现查看某一端口是否开放》文章介绍了三种检查端口6379是否开放的方法:通过lsof查看进程占用,用netstat区分TCP/UDP监听状态,以及用telnet测试远程连接可达性... 目录1、使用lsof 命令来查看端口是否开放2、使用netstat 命令来查看端口是否开放3、使用telnet

Spring Boot配置和使用两个数据源的实现步骤

《SpringBoot配置和使用两个数据源的实现步骤》本文详解SpringBoot配置双数据源方法,包含配置文件设置、Bean创建、事务管理器配置及@Qualifier注解使用,强调主数据源标记、代... 目录Spring Boot配置和使用两个数据源技术背景实现步骤1. 配置数据源信息2. 创建数据源Be

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Python如何判断字符串中是否包含特殊字符并替换

《Python如何判断字符串中是否包含特殊字符并替换》这篇文章主要为大家详细介绍了如何使用Python实现判断字符串中是否包含特殊字符并使用空字符串替换掉,文中的示例代码讲解详细,感兴趣的小伙伴可以了... 目录python判断字符串中是否包含特殊字符方法一:使用正则表达式方法二:手动检查特定字符Pytho