国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

C# 判斷兩條直線是否相交

2019-11-17 02:32:48
字體:
來源:轉載
供稿:網友

C# 判斷兩條直線是否相交

直接上代碼,過程不復雜

/// <summary>/// 判斷兩條線是否相交/// </summary>/// <param name="a">線段1起點坐標</param>/// <param name="b">線段1終點坐標</param>/// <param name="c">線段2起點坐標</param>/// <param name="d">線段2終點坐標</param>/// <param name="intersection">相交點坐標</param>/// <returns>是否相交 0:兩線平行  -1:不平行且未相交  1:兩線相交</returns>PRivate int GetIntersection(Point a, Point b, Point c, Point d ,ref Point intersection){    //判斷異常    if (Math.Abs(b.X - a.Y) + Math.Abs(b.X - a.X) + Math.Abs(d.Y - c.Y) + Math.Abs(d.X - c.X) == 0)    {        if (c.X - a.X == 0)        {           Debug.Print("ABCD是同一個點!");         }        else        {            Debug.Print("AB是一個點,CD是一個點,且AC不同!");        }        return 0;    }    if (Math.Abs(b.Y - a.Y) + Math.Abs(b.X - a.X) == 0)    {        if ((a.X - d.X) * (c.Y - d.Y) - (a.Y - d.Y) * (c.X - d.X) == 0)        {            Debug.Print ("A、B是一個點,且在CD線段上!");        }        else        {             Debug.Print ("A、B是一個點,且不在CD線段上!");        }        return 0;    }    if (Math.Abs(d.Y - c.Y) + Math.Abs(d.X - c.X) == 0)    {        if ((d.X - b.X) * (a.Y - b.Y) - (d.Y - b.Y) * (a.X - b.X) == 0)        {            Debug.Print ("C、D是一個點,且在AB線段上!");        }        else        {            Debug.Print ("C、D是一個點,且不在AB線段上!");        }    }    if ((b.Y - a.Y) * (c.X - d.X) - (b.X - a.X) * (c.Y - d.Y) == 0)    {        Debug.Print ("線段平行,無交點!");        return 0;    }       intersection.X = ((b.X - a.X) * (c.X - d.X) * (c.Y - a.Y) - c.X * (b.X - a.X) * (c.Y - d.Y) + a.X * (b.Y - a.Y) * (c.X - d.X)) / ((b.Y - a.Y) * (c.X - d.X) - (b.X - a.X) * (c.Y - d.Y));    intersection.Y = ((b.Y - a.Y) * (c.Y - d.Y) * (c.X - a.X) - c.Y * (b.Y - a.Y) * (c.X - d.X) + a.Y * (b.X - a.X) * (c.Y - d.Y)) / ((b.X - a.X) * (c.Y - d.Y) - (b.Y - a.Y) * (c.X - d.X));       if ((intersection.X - a.X) * (intersection.X - b.X) <= 0 && (intersection.X - c.X) * (intersection.X - d.X) <= 0 && (intersection.Y - a.Y) * (intersection.Y - b.Y) <= 0 && (intersection.Y - c.Y) * (intersection.Y - d.Y) <= 0)    {        Debug.Print ("線段相交于點(" + intersection.X + "," + intersection.Y + ")!");        return 1; //'相交    }    else    {        Debug.Print ("線段相交于虛交點(" + intersection.X + "," + intersection.Y + ")!");        return -1; //'相交但不在線段上    }}

上一篇:持續集成方案(一)

下一篇:HtmlEntities

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沙雅县| 监利县| 宜兰县| 上饶市| 佛坪县| 大悟县| 固始县| 万荣县| 阳谷县| 松滋市| 宁明县| 沿河| 留坝县| 崇信县| 玛多县| 阳东县| 湘阴县| 韶关市| 靖西县| 通州区| 汝城县| 左权县| 旌德县| 日土县| 新余市| 仁寿县| 体育| 剑川县| 宜兰县| 洱源县| 清丰县| 云霄县| 洛阳市| 徐州市| 抚顺县| 贺兰县| 隆尧县| 遂昌县| 赣榆县| 永修县| 曲沃县|