【发布时间】:2011-05-05 10:36:13
【问题描述】:
我在圆周上有三个点:
pt A = (A.x, A.y);
pt B = (B.x, B.y);
pt C = (C.x, C.y);
如何计算圆心?
在 Processing (Java) 中实现它。
我找到了答案并实施了一个可行的解决方案:
pt circleCenter(pt A, pt B, pt C) {
float yDelta_a = B.y - A.y;
float xDelta_a = B.x - A.x;
float yDelta_b = C.y - B.y;
float xDelta_b = C.x - B.x;
pt center = P(0,0);
float aSlope = yDelta_a/xDelta_a;
float bSlope = yDelta_b/xDelta_b;
center.x = (aSlope*bSlope*(A.y - C.y) + bSlope*(A.x + B.x)
- aSlope*(B.x+C.x) )/(2* (bSlope-aSlope) );
center.y = -1*(center.x - (A.x+B.x)/2)/aSlope + (A.y+B.y)/2;
return center;
}
【问题讨论】:
-
非常感谢您发布问题的答案。
-
如果
B.x - A.x或C.x - B.x为零,您的解决方案会产生奇怪的结果,因为您随后除以零。
标签: java algorithm geometry computational-geometry