p点到(a,b)点两所在直线的垂点坐标及p点是否在(a,b)两点所在直线上

简介:
/// <summary>
/// p点到(a,b)点两所在直线的垂点坐标
/// </summary>
/// <param name="a"> 直线上a点 </param>
/// <param name="b"> 直线上b点 </param>
/// <param name="p"> </param>
/// <returns> 垂点坐标 </returns>
public static Vector2D GetVerticalPosition(Vector2D a, Vector2D b, Vector2D p)
{
double fa = b.Y - a.Y;
double fb = a.X - b.X;
double fc = a.Y * b.X - a.X * b.Y;

Vector2D vpt = new Vector2D(); // 垂足
vpt.X = (fb * fb * p.X - fa * fb * p.Y - fa * fc) / (fa * fa + fb * fb);
vpt.Y = (fa * fa * p.Y - fa * fb * p.X - fb * fc) / (fa * fa + fb * fb);

return vpt;
}
/// <summary>
/// p点是否在(a,b)两点所在直线上
/// </summary>
/// <param name="a"></param>
/// <param name="b"></param>
/// <param name="foot"></param>
/// <returns></returns>
public static bool DotIsOnLine(Vector2D a, Vector2D b, Vector2D foot)
{
return Math.Min(a.X, b.X) <= foot.X && foot.X <= Math.Max(a.X, b.X) && Math.Min(a.Y, b.Y) <= foot.Y && foot.Y <= Math.Max(a.Y, b.Y);
}



本文转自94cool博客园博客,原文链接:http://www.cnblogs.com/94cool/p/4654287.html,如需转载请自行联系原作者
相关文章
|
4月前
|
C++
已知线段上某点与起点的距离,求该点的坐标
已知线段上某点与起点的距离,求该点的坐标
45 1
|
4月前
|
C++
C++代码来计算一个点围绕另一个点旋转45度后的坐标
C++代码来计算一个点围绕另一个点旋转45度后的坐标
103 0
|
4月前
|
算法
空间点与直线距离算法
空间点与直线距离算法
60 0
|
7月前
|
JavaScript 前端开发 Java
根据地球上任意两点的经纬度计算两点间的距离
根据地球上任意两点的经纬度计算两点间的距离
357 2
|
7月前
|
存储 C++ 容器
[C++] 点到直线的最大、最小距离
[C++] 点到直线的最大、最小距离
114 0
点和直线的关系
点和直线的关系
103 0
平面上给定n条线段,找出一个点,使这个点到这n条线段的距离和最小。
题目:平面上给定n条线段,找出一个点,使这个点到这n条线段的距离和最小。 源码如下: 1 #include 2 #include 3 #include 4 #include 5 #include 6 #include 7 ...
1115 0