javascript - 如何计算给定三个点的圆心?

标签 javascript geometry

我正在使用 Javascript,我知道 3 个点的位置。我想用这些来找出一个圆的中心点。

我发现了这个逻辑(不是选择的答案,而是有 11 个赞成票的那个):https://math.stackexchange.com/questions/213658/get-the-equation-of-a-circle-when-given-3-points

但我似乎无法理解如何为其编写逻辑。

顺便说一句,我不能使用边界框,这必须使用三个点来完成:)

有什么想法吗?

最佳答案

我最喜欢的分辨率:

平移三个点,使其中一个点位于原点(减去 (X0,Y0))。

圆过两点和原点的方程可以写成

2X.Xc + 2Y.Yc = X² + Y²

插入两个点的坐标,你会得到一个由两个未知数的两个方程组成的简单系统,由 Cramer 提出

Xc = (Z1.Y2 - Z2.Y1) / D
Yc = (X1.Z2 - X2.Z1) / D

D = 2(X1.Y2 - X2.Y1), Z1 = X1²+Y1², Z2 = X2²+Y2²

要翻译回来(添加 (X0,Y0))。


当三个点对齐时公式失败,由 D = 0(或与分子相比较小)诊断。


        X1-= X0; Y1-= Y0; X2-= X0; Y2-= Y0;

        double Z1= X1 * X1 + Y1 * Y1;
        double Z2= X2 * X2 + Y2 * Y2;
        double D= 2 * (X1 * Y2 - X2 * Y1);

        double Xc= (Z1 * Y2 - Z2 * Y1) / D + X0;
        double Yc= (X1 * Z2 - X2 * Z1) / D + Y0;

关于javascript - 如何计算给定三个点的圆心?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32861804/

相关文章:

javascript - D3 JS 传递给匿名函数的 F 是什么意思?

javascript - 使用 npm 终端的 npm 脚本奇怪行为

algorithm - 计算 'local convex hulls'并集的快速算法

css - 如何在 css 中在矩形的顶部制作曲线?仅在上边缘

c - 沿着给定的航向、起点和点之间的距离获取沿线的点

javascript - 如何在node.js中访问子文件中的父模块数据

javascript - 有没有一种方法可以通过 react 导航创建和分派(dispatch)/触发自定义事件?

javascript清除复选框上的输入表单值取消选中

c# - 两个圆的切线

c# - 如何使用 NetTopologySuite 以米为单位获取两点几何的距离?