已知圆心坐标、圆半径、圆外一点坐标,圆外一点过圆心做直线,求直线与圆相交时,离圆外一点最近交点的坐标

C#写法

 

using System;

 

public class GeometryCalculator

{

    public static void Main()

    {

        // 已知值

        int X0 = 120, Y0 = 100; // 圆心坐标

        int r = 30; // 圆的半径

        int X1 = 50, Y1 = 60; // 圆外点坐标

 

        // 计算圆上最近的点坐标

        var nearestPoint = FindNearestPointOnCircle(X0, Y0, r, X1, Y1);

 

        // 输出结果

        Console.WriteLine($"The nearest point on the circle is at ({nearestPoint.X}, {nearestPoint.Y})");

    }

 

    public static (int X, int Y) FindNearestPointOnCircle(int X0, int Y0, int r, int X1, int Y1)

    {

        // 计算斜率 m 和截距 b

        double m = (Y1 - Y0) / (X1 - X0);

        double b = Y0 - m * X0;

 

        // 圆心到直线的距离公式

        double distance = Math.Abs(m * X0 - Y0 + b) / Math.Sqrt(m * m + 1);

 

        // 计算圆上点到圆心的投影点的坐标

        double Xp = X0 + distance * (X1 - X0) / Math.Sqrt((m * m + 1));

        double Yp = Y0 + distance * (Y1 - Y0) / Math.Sqrt((m * m + 1));

 

        // 计算圆上点到圆心投影点的向量与圆半径的单位向量

        double unitVectorX = (Xp - X0) / r;

        double unitVectorY = (Yp - Y0) / r;

 

        // 计算圆上的点

        int X = (int)Math.Round(X0 + unitVectorX * r);

        int Y = (int)Math.Round(Y0 + unitVectorY * r);

 

        return (X, Y);

    }

}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郁雯汐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值