PHP判断两个矩形是否相交

<?php

$s = is_rect_intersect(1,2,1,2,4,5,0,3);
var_dump($s);


/*
如果两个矩形相交,那么矩形A B的中心点和矩形的边长是有一定关系的。
Case 2345中,两个中心点间的距离肯定小于AB边长和的一半。
Case 1中就像等了。
设A[x01,y01,x02,y02]  B[x11,y11,x12,y12].
矩形A和矩形B物理中心点X方向的距离为Lx:abs( (x01+x02)/2 – (x11+x12) /2)
矩形A和矩形B物理中心点Y方向的距离为Ly:abs( (y01+y02)/2 – (y11+y12) /2)
矩形A和矩形B X方向的边长为 Sax:abs(x01-x02)  Sbx: abs(x11-x12)
矩形A和矩形B Y方向的边长为 Say:abs(y01-y02)  Sby: abs(y11-y12)
如果AB相交,则满足下列关系:
Lx <= (Sax + Sbx)/2 && Ly <=(Say+ Sby)/2
参考地址:https://blog.csdn.net/szfhy/article/details/49740191
 */
function is_rect_intersect($x01,$x02,$y01,$y02,$x11,$x12,$y11,$y12){
    $zx = abs($x01+$x02-$x11-$x12);                 
    $x  = abs($x01 - $x02) + abs($x11 - $x12);      
    $zy = abs($y01 + $y02 - $y11 - $y12);           
    $y  = abs($y01 - $y02) + abs($y11 - $y12);      
    if($zx <= $x && $zy <= $y){
        return 1;
    }else{
        return 0;
    }
}

猜你喜欢

转载自www.cnblogs.com/wanghaokun/p/11011064.html