java計算兩條線段交點

一、判斷斜率相同不,y2-y1/x2-x1,y4-y3/x4-x3,相同則無交點,不相同說明直線有交點則執行第二步; 
   二、設y=ax+b,經過斜率可求出a的值,經過座標能夠求出b的值,這樣兩個線段所在直線的兩個方程式就獲得了; 
spa

   三、經過兩個方程式求出交點,再判斷交點是否是落在兩線段交點的區域中code

 

代碼:blog

public  static Point getCrossPoint(Lseg lsegA,Lseg lsegB){
        float x;
        float y;
        float x1=lsegA.getA().getX();
        float y1=lsegA.getA().getY();
        float x2=lsegA.getB().getX();
        float y2=lsegA.getB().getY();
        float x3=lsegB.getA().getX();
        float y3=lsegB.getA().getY();
        float x4=lsegB.getB().getX();
        float y4=lsegB.getB().getY();
        float k1=Float.MAX_VALUE;
        float k2=Float.MAX_VALUE;
        boolean flag1=false;
        boolean flag2=false;
        
        if((x1-x2)==0)
            flag1=true;
        if((x3-x4)==0)
            flag2=true;
        
        if(!flag1)
            k1=(y1-y2)/(x1-x2);
        if(!flag2)
            k2=(y3-y4)/(x3-x4);
        
        if(k1==k2)
            return null;
        
        if(flag1){
            if(flag2)
                return null;
            x=x1;
            if(k2==0){
                y=y3;
            }else{
                y=k2*(x-x4)+y4;
            }
        }else if(flag2){
            x=x3;
            if(k1==0){
                y=y1;
            }else{
                y=k1*(x-x2)+y2;
            }
        }else{
            if(k1==0){
                y=y1;
                x=(y-y4)/k2+x4;
            }else if(k2==0){
                y=y3;
                x=(y-y2)/k1+x2;
            }else{
                x=(k1*x2-k2*x4+y4-y2)/(k1-k2);
                y=k1*(x-x2)+y2;
            }            
        }
        if(between(x1,x2,x)&&between(y1,y2,y)&&between(x3,x4,x)&&between(y3,y4,y)){
            Point point=new Point();
            point.setX(x);
            point.setY(y);
            if(point.equals(lsegA.getA())||point.equals(lsegA.getB()))
                return null;
            return point;
        }else{
            return null;
        }                
    }
    
    public static boolean between(float a,float b,float target){
        if(target>=a-0.01&&target<=b+0.01||target<=a+0.01&&target>=b-0.01)
            return true;
        else
            return false;
    }}
相關文章
相關標籤/搜索