码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 判断矩形与矩形、圆、三角形的相交问题


    注:以下的矩形均为轴对齐矩形

    1.矩形与矩形的相交判断

    参考自:

    力扣--矩形面积

    力扣--矩形重叠

    判断两个矩形是否相交最简单算法_程序员正茂的博客-CSDN博客_矩形相交算法

    快速判断两个矩形是否相交_szfhy的博客-CSDN博客_判断两个矩形是否相交

    如何判断两个矩形相交_Season的博客-CSDN博客_判断两个矩形相交

    主要有两种方法。

    1)方法一:用边界判断

    第一个矩形:(x1,y1),(x2,y2)
    第二个矩形:  (x3,y3),(x4,y4)

    如果满足max(x1,x3)<=min(x2,x4)&&max(y1,y3)<=min(y2,y4),则相交。

    亦可转化为:x1 <= x4 && x3 <= x2 && y1 <= y4 && y3 <= y2

    并且新构成的矩形为(max(x1,x3),max(y1,y3))、(min(x2,x4),min(y2,y4))。可以根据新的点求出矩形的面积,如果用新的点求出的边长小于0,说明是不相交的。

    2)方法二:用两个矩形的中心坐标的向量来判断

    假设两个矩形的中心为p1、p2。那么其构成的向量p1p2的x分量的绝对值要小于两矩形长的一半,向量p1p2的x分量的绝对值要小于两矩形宽的一半。

    2.矩形与圆的相交判断

    主要有以下三种比较好的方法,相较于矩形与矩形之间的相交判断难了一个档次。

    1)方法一

    具体推导见参考链接:

    怎样判断平面上一个矩形和一个圆形是否有重叠? - 知乎

    力扣力扣--【圆和矩形是否有重叠】

    这种做法很巧妙,可以理解为是在找出圆心距离矩形最近的距离,然后判断该距离是否小于圆的半径。

    2)方法二

    具体推导见参考链接:

    力扣--一张图,秒懂。

    这种做法相对方法一好理解,就是找到圆心在哪些区域圆是与矩形相交的,然后依次判断圆心是否在这些区域即可。

    3)方法三

    力扣 验证矩形区域内的点到圆心最小距离(x,y 分别独立选择,三行代码(骗浏览))

    其实本质上就是方法一的变种,但是更偏向代数去理解。

    3.矩形与三角形的相交判断

    目前只想到方法一,有待后面继续更新

    1)方法一:

    参考自:三角形和矩形相交的判断_双杯献酒的博客-CSDN博客

    分为三种情况:

    三角形和矩形相交
    (1)如果三角形在矩形内部, 则三角形和矩形相交.
       这种情况判断三角形的三个点是否在矩形内即可。
    (2)如果矩形在三角形内部, 则三角形和矩形相交
    这种情况判断矩形的四个点是否在三角形内即可。
    (3)如果三角形至少有一条边(线段)和矩形的至少一条边(线段)相交,
    这时候应该就得通过求出三角形三条边的直线方程,判断直线方程与矩形的交点个数来判断了。
     

  • 相关阅读:
    idea如何更改编辑器字体大小和框字体大小
    【Python】八、函数的使用
    (四) Docker镜像
    Spring高手之路14——深入浅出:SPI机制在JDK与Spring Boot中的应用
    Git常用命令
    【学相伴】狂神说 RabbitMQ快速入门笔记(简单使用RabbitMQ)SpringBoot整和RabbitMQ
    ThreadX任务栈大小确定及其溢出检测方法详解
    设计模式_责任链
    《俞军产品方法论》笔记心得 03
    codeforces每日5题(均1600)-第二十九天
  • 原文地址:https://blog.csdn.net/qq_42987967/article/details/126855043
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号