python判断两个矩形是否相交_使用Python判断线段是否与矩形相交
直线相交的判定
我们在初等几何中学过如何判断两条直线是否相交。在欧几里得平面上,两条直线要么平行,要么相交,要么重合。这是欧几里得第五公设的推论。相交的两条直线恰好有一个交点,而重合的两条直线有无数个交点。判断两条直线位置关系的代数方法是:联立两条之直线方程,无解,则两条直线平行,存在唯一解则两条直线相交,存在两个及以上的解,则两直线重合。
联立直线方程
线段相交的判定:
分为矩形判定和叉积判定两步
step1:矩形判定
判断分别以两线段为对角线的两个矩形是否相交,若不相交,则两线段一定不相交。两个矩形是否相交的条件是:任一矩形的最右端都大于另一矩形的最左端,且任一矩形最高端大于另一矩形的最低端;只要其中任一条件不满足,则两矩形不相交,也即两线段不相交。
矩形判定:不相交
这一步判定不相交的两条线段直接返回False。
step2:叉积判定
经过上面判定未得到结果的两条线段那进入此步进行判定。
叉积判定:相交
这一步的目的是确定一条线段的两个端点是否在另一线段的两侧,如果两条线段的端点互相位于另一条线段的两侧,则这两条线段相交。
def cross(p1,p2,p3): # 叉积判定
x1=p2[0]-p1[0]
y1=p2[1]-p1[1]
x2=p3[0]-p1[0]
y2=p3[1]-p1[1]
return x1*y2-x2*y1
def segment(p1,p2,p3,p4): #判断两线段是否相交
#矩形判定,以l1、l2为对角线的矩形必相交,否则两线段不相交
if(max(p1[0],p2[0])>=min(p3[0],p4[0]) #矩形1最右端大于矩形2最左端
and max(p3[0],p4[0])>=min(p1[0],p2[0]) #矩形2最右端大于矩形1最左端
and max(p1[1],p2[1])>=min(p3[1],p4[1]) #矩形1最高端大于矩形2最低端
and max(p3[1],p4[1])>=min(p1[1],p2[1])): #矩形2最高端大于矩形1最低端
if(cross(p1,p2,p3)*self.cross(p1,p2,p4)<=0
and cross(p3,p4,p1)*self.cross(p3,p4,p2)<=0):
D=1
else:
D=0
else:
D=0
return D
线段与矩形相交的判定:
矩形的特殊之处在于其有2条对角线,小于其边数4。对于凸多边形,只要一条线段穿越矩形必定与某一条对角线相交。因此我们将线段与矩形相交问题转化为线段与矩形对角线的交点问题,为了排除特殊情况,在检测线段与对角线交点前,我们检测线段的两个端点是否在矩形内。
step1:检测线段端点是否在矩形内
step2:分别检测线段与矩形的两条对角线是否相交
def check(l1,l2,sq):
# step 1 check if end point is in the square
if ( l1[0] >= sq[0] and l1[1] >= sq[1] and l1[0] <= sq[2] and l1[1] <= sq[3]) or
( l2[0] >= s1[0] and l2[1] >= s1[1] and l2[0] <= sq[2] and l2[1] <= sq[3]):
return 1
else:
# step 2 check if diagonal cross the segment
p1 = [sq[0],sq[1]]
p2 = [sq[2],sq[3]]
p3 = [sq[2],sq[1]]
p4 = [sq[0],sq[3]]
if segment(l1,l2,p1,p2) or segment(l1,l2,p3,p4):
return 1
else:
return 0
其中sq=[x_leftdown,y_leftdown,x_rightup,y_rightup]。
python判断两个矩形是否相交_使用Python判断线段是否与矩形相交相关推荐
- c++如何判断两个字符串是否相同?_链表 | 如何判断两个单链表(无环)是否交叉...
如何判断两个单链表(无环)是否交叉 单链表相交指的是两个链表存在完全重合的部分,如下图所示 在上图中,这两个链表相交于结点5,要求判断两个链表是否相交,如果相交,找出相交处的结点. 分析 Hash法 ...
- 在python语言中用=判断两个数值是否相等_在Python语言中,要判断两个值是否不等,应使用下列哪个运算符?...
阅读以下说明,回答问题1至问题3,将答案填入答题纸对应栏内.[说明]在某嵌入式处理器上,编写以下两段秸序(编译选项中,存储采用4字节对齐方式).程序段1:struct studentl {char n ...
- 用python求两个人的平均身高_黄哥Python:分治算法(Divide-and-Conquer)
分治算法(Divide-and-Conquer) 在计算机科学中,分而治之(简称分治法)是基于多分支递归的算法设计范例.分而治之算法的工作原理是将问题递归分解为两个或多个相同或相关类型的子问题,直到这 ...
- 用python求两个人的平均身高_大学python题 求大佬解答!!!
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 7-4 计算指数 (5 分) 真的没骗你,这道才是简单题 -- 对任意给定的不超过10的正整数n,要求你输出2n.不难吧? 输入格式: 输入在一行中给出一 ...
- python计算两字符串中的位置_从Python中的字符串中获取两个字符
how to get in python from string not one character, but two? I have: long_str = 'abcd' for c in long ...
- python输入两个坐标求距离_计算python中*多组*地理坐标之间的距离
编辑: here's a simple notebook example 一般方法,假设您有一个包含点的DataFrame列,并且您想要计算所有这些列之间的距离(例如,如果您有单独的列,则首先将它们组 ...
- python判断两个数是否互质_《算法》第一章——判断两个整数是否互质
判断两个整数互质的方法 概念:公约数只有1的两个数叫做互质数.根据互质数的概念可以对一组数是否互质进行判断.如:9和11的公约数只有1,则它们是互质数. 求商判断法:用大数除以小数,如果除得的余数与其 ...
- python求两数之和的命令_数学建模:科学计算Python2小时-Python基础
这一部分主要面向数模活动中的python基础知识进行讨论 作者 系列文章(科学计算Python2小时)目录:李似:科学计算Python2小时-前言与目录zhuanlan.zhihu.com 首先要说 ...
- python判断set里是否包含值_【python】判断值是否在list和set的对比以及set的实现原理...
判断值是否在set集合中的速度明显要比list快的多, 因为查找set用到了hash,时间在O(1)级别. 假设listA有100w个元素,setA=set(listA)即setA为listA转换之后 ...
- python矩形填充颜色_在Python中找到所有用0填充的矩形
假设我们有一个二进制2D矩阵,现在我们必须找到所有用0填充的矩形的起点和终点.我们必须牢记,矩形是分开的,彼此之间不接触,但是它们可以接触阵列边界.仅包含单个元素的矩形也是可能的. 所以,如果输入像- ...
最新文章
- java 左右键_js 区分鼠标左右键点击
- 动手打造自己强大的右键菜单
- [转]微信的一道前端面试题
- CTF-攻防世界-reverse进阶-srm-50;(巨详细)
- try、catch、finally的执行顺序
- Windows7系统自带的备份与还原功能使用介绍
- 【计算机组成原理】逻辑运算
- javaone_替代JavaOne 2013
- 在装有Anaconda的情况下,使用默认的python程序方法
- Python Imaging Library: ImageQt Module(图像QT模块)
- 二分图的匹配(未完)
- 玩Mega8 智能充电器-12. 终于实现-dV检测(转)
- sql请求失败或服务器无即使响应,SQL2005无法启动SQL Server 请求失败或服务未及时响应等问题的解决方案...
- Hardware概述
- java webp 图片处理_Java处理Webp图片格式转换的示例代码
- UE4 Slate十一 独立程序,制作BlankProgrammer 待完善
- 洛阳九县八取名字_洛阳市地图(洛阳市九县六区地图)
- php的解析别名,浅谈laravel aliases别名的原理
- 泰文组合规则,泰文变形规则
- 语音智能小车:语音识别模块LD3320+STMF103
热门文章
- arcgis engine已知图幅号获取比例尺
- 新手十分钟玩转淘宝客推广攻略
- pat乙级【数列的片段和 (20分)】测试样例修改(第二个测试点)
- 计算机网络路由交换技术运用,计算机网络路由交换的技术应用与发展趋势研究...
- Maven知识补充(项目模型变量,Maven属性,依赖项的范围,查找公共存储库的依赖项等)
- Android 打开淘宝商品详情
- [Winter Vacation] 语文实词虚词练习册答案
- 进程之间的通信方式有哪些?
- fastdb相关备忘
- 当路由器外网IP变更时,执行操作