C#已知三个点,求圆心和半径

public void FitCircleFromThreePoints(double Points1X, double Points1Y, double Points2X, double Points2Y, double Points3X, double Points3Y, out double Col, out double Row, out double Rad)
{
      try
      {
      		//先判断一下这三个点是否共线,如果共线就不求了。
      		if ((Points1X - Points2X) / (Points1Y - Points2Y) == (Points2X - Points3X) / (Points2Y - Points3Y))
      		{
      		Col = 0;
      		Row = 0;
      		Rad = 0;
          		return ;
      		}
      		//求圆形
      		double x1, y1, x2, y2, x3, y3;
      		double a, b, c, g, h, f;
      		x1 = Points1X;
      		y1 = Points1Y;
      		x2 = Points2X;
      		y2 = Points2Y;
      		x3 = Points3X;
      		y3 = Points3Y;
      		h = 2 * (x2 - x1);
      		f = 2 * (y2 - y1);
      		g = x2 * x2 - x1 * x1 + y2 * y2 - y1 * y1;
      		a = 2 * (x3 - x2);
      		b = 2 * (y3 - y2);
      		c = x3 * x3 - x2 * x2 + y3 * y3 - y2 * y2;
      		Col = (g * b - c * f) / (h * b - a * f);
      		Row = (a * g - c * h) / (a * f - b * h);
      		Rad = Math.Sqrt((Col - x1) * (Col - x1) + (Row - y1) * (Row - y1));
      		}
      catch
      {
      		Col = 0;
         	Row = 0;
         	Rad = 0;
       }
}

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值