已知条件:
- 直线上的两点pt1,pt2坐标
- 直线外的一点pt3
求直线的垂线经过pt3,与该直线的交点坐标
/// <summary>
/// 根据两点求出垂线过第三点的直线的交点
/// </summary>
/// <param name="pt1">直线上的点1</param>
/// <param name="pt2">直线上的点2</param>
/// <param name="pt3">垂线上的点(当前鼠标的点)</param>
/// <returns>返回点到直线的垂直交点坐标</returns>
public PointF GetPointToLineVerticalCross(PointF pt1, PointF pt2, PointF pt3)
{
//垂直线
if (pt1.X == pt2.X)
{
return new PointF(pt1.X, pt3.Y);
}
//水平线
if (pt1.Y == pt2.Y)
{
return new PointF(pt3.X, pt1.Y);
}
float A = (pt1.Y - pt2.Y) * 1.0f / (pt1.X - pt2.X);
float B = (pt1.Y - A * pt1.X);
float m = pt3.X + A * pt3.Y;
/// 求两直线交点坐标
PointF ptCross = new PointF(0, 0);
ptCross.X = (m - A * B) * 1.0f / (A * A + 1);
ptCross.Y = A * ptCross.X + B;
return ptCross;
}