天气与日历 切换到窄版

 找回密码
 立即注册
中国膜结构网
十大进口膜材评选 十大国产膜材评选 十大膜结构设计评选 十大膜结构公司评选
查看: 58|回复: 0

c++ 圆上任意点坐标计算_三点确定一个圆的算法(C++代码)

[复制链接]

该用户从未签到

主题

0

回帖

2912

积分

管理员

积分
2912
发表于 2024-6-22 09:46:18 | 显示全部楼层 |阅读模式
QPointF tcircle(QPointF pt1, QPointF pt2, QPointF pt3, double &radius)

{

double x1 = pt1.x(), x2 = pt2.x(), x3 = pt3.x();

double y1 = pt1.y(), y2 = pt2.y(), y3 = pt3.y();

double a = x1 - x2;

double b = y1 - y2;

double c = x1 - x3;

double d = y1 - y3;

double e = ((x1 * x1 - x2 * x2) + (y1 * y1 - y2 * y2)) / 2.0;

double f = ((x1 * x1 - x3 * x3) + (y1 * y1 - y3 * y3)) / 2.0;

double det = b * c - a * d;

if( fabs(det)

{

radius = -1;

return QPointF(0,0);

}

double x0 = -(d * e - b * f) / det;

double y0 = -(a * f - c * e) / det;

radius = hypot(x1 - x0, y1 - y0);

return QPointF(x0, y0);

}

 

 

 

 

c++ 圆上任意点坐标计算_三点确定一个圆的算法(C++代码)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|中国膜结构网|中国膜结构协会|进口膜材|国产膜材|ETFE|PVDF|PTFE|设计|施工|安装|车棚|看台|污水池|中国膜结构网_中国空间膜结构协会

GMT+8, 2024-11-1 10:21 , Processed in 0.149806 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表