使用Python判断线段是不是与矩形相交

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用Python判断线段是不是与矩形相交相关的知识,希望对你有一定的参考价值。

参考技术A 我们在初等几何中学过如何判断两条直线是否相交。在欧几里得平面上,两条直线要么平行,要么相交,要么重合。这是欧几里得第五公设的推论。相交的两条直线恰好有一个交点,而重合的两条直线有无数个交点。判断两条直线位置关系的代数方法是:联立两条之直线方程,无解,则两条直线平行,存在唯一解则两条直线相交,存在两个及以上的解,则两直线重合。

分为矩形判定和叉积判定两步

判断分别以两线段为对角线的两个矩形是否相交,若不相交,则两线段一定不相交。两个矩形是否相交的条件是:任一矩形的最右端都大于另一矩形的最左端,且任一矩形最高端大于另一矩形的最低端;只要其中任一条件不满足,则两矩形不相交,也即两线段不相交。

这一步判定不相交的两条线段直接返回False。

经过上面判定未得到结果的两条线段那进入此步进行判定。

这一步的目的是确定一条线段的两个端点是否在另一线段的两侧,如果两条线段的端点互相位于另一条线段的两侧,则这两条线段相交。

矩形的特殊之处在于其有2条对角线,小于其边数4。对于凸多边形,只要一条线段穿越矩形必定与某一条对角线相交。因此我们将线段与矩形相交问题转化为线段与矩形对角线的交点问题,为了排除特殊情况,在检测线段与对角线交点前,我们检测线段的两个端点是否在矩形内。

其中 sq=[x_leftdown,y_leftdown,x_rightup,y_rightup] 。

以上是关于使用Python判断线段是不是与矩形相交的主要内容,如果未能解决你的问题,请参考以下文章

poj1410(判断线段和矩形是否相交)

POJ1410线段相交快速排斥实验跨立实验

POJ1127 Jack Straws

判断两线段是否相交

两个矩形相交问题-判断是否相交

Codechef SEP14 QRECT cdq分治+线段树