1. 先求出线的方向角(用向量)
// 得到两点的角度
// 0 - 360 以 point1 为圆心绕一周
double getAngleFromTwoPoint(CPoint point1, CPoint point2)
{
double angle = 0;
CPoint O = point1; //以第一点为圆心旋转
CPoint A = point2;
double r = getTheRealLengthOfTheLine(O, A, FALSE); //这只是求两点间距离很简单的我就不贴了
CPoint B = CPoint(O.x + r, O.y); //以圆心O为起点 O点右侧距离r个像素长度做B点(O->B)
CPoint OA = CPoint(A.x - O.x, A.y - O.y); //向量OA O->A
CPoint OB = CPoint(B.x - O.x, B.y - O.y); //向量OB O->B
double sin = (OA.x * OB.y - OB.x * OA.y) / (r * r); // |OA| = |OB| = r
angle = ASIN(sin); //弧度 ASIN(c) = (asin(c) * (180.0 / PI))
if (O.x < A.x && O.y > A.y) //象限1
angle = angle;
else if (O.x > A.x && O.y > A.y) //象限2
本文介绍了如何在MFC中使用任意三点来绘制圆弧并计算弧长。首先,通过向量求出线的方向角,接着主要讨论了判断B点范围的方法。参考链接提供了详细的实现细节。
订阅专栏 解锁全文
2919

被折叠的 条评论
为什么被折叠?



