如何判断两个矩形是否相交

来源:学生作业帮助网 编辑:作业帮 时间:2024/11/08 18:52:23

如何判断两个矩形是否相交
如何判断两个矩形是否相交

如何判断两个矩形是否相交
1、一个矩形只有一个角的点在另一个矩形内;\x0d2、一个矩形a只一条边上的2个顶角在另一个矩形b内(这种情况对于另一个矩形b来说却是4个顶角都在矩形a之外,所以要交换判断).\x0d3、一个矩形穿过另一个矩形;\x0d这位朋友想了这么三种情形之后,觉得把这些情形写成代码过于复杂,这才跑到论坛上来提问.\x0d有的时候,程序员考虑问题的方向就得跟别人不一样,换一个角度考虑,这个问题将变得简单:\x0d如果两个矩形相交,则必然存在线条交叉,而能交叉的线条只有横线和竖线,两根横线或两根竖线都不可能交叉.所以,这个问题就转化成寻找是否存在交叉的横线与竖线.\x0d另外,A线与B线交叉等价于B线与A线交叉,所以,只要写一个函数就足够用了,多调用几次,反正计算机是专门做简单而又烦琐的工作的.\x0d下面是这个函数:判断一条横线和一条竖线是否交叉.该函数的参数分别是:横线左、横线右,横线Y,竖线上,竖线下,竖线X.\x0dbool CrossLine(left,right,y,top,bottom,x){//判断一根横线和一根竖线是否交叉\x0d//横线有三个参数:left,right和y\x0d//竖线有三个参数:top,bottom和x\x0dreturn (top < y) && (bottom > y)\x0d&& (left < x) && (right > x);}下面是判断两个矩形是否相交的函数,把同一个函数多调用几篇就OK了.\x0dbool CrossRect(CRect &r1,CRect &r2){//判断两个矩形是否相交,\x0d//从一个矩形中取出一条横线,与另一矩形中的一条竖线判断是否交叉