这解释起来很复杂,所以我会尽力而为,如果有什么遗漏的地方,请告诉我,我会改正的。
我的问题是,我的任务是画出这个形状,
这将使用 C++ 编写代码来计算此形状上的点。
重要细节。
用户输入 - 中心点 (X, Y)、要显示的点数、字体大小(影响半径)
输出 - 形状上的坐标列表。
一旦我有了这些点,总体目标就是将它们放入 Excel 上的图表中,并希望它会以用户输入的大小为我绘制它!
我知道最大半径为 165 毫米,最小为 35 毫米。我决定我的基本字体大小应该是 20。然后我想了想,想出了这个等式。
半径 =(选择的字体大小/20)*130。这只是一个估计,我意识到它可能不对,但我认为它至少可以作为一个模板。
然后我决定我应该创建两个不同的圆,两个不同的中心点,然后将它们连接在一起以创建形状。我认为 INSIDE 线必须有一个更大的半径和一个沿 X 轴更远的中心点(Y 保持不变),因为它可以切入外线。
所以我将第二个中心点定义为 (X+4, Y)。(再次,只是估计,认为它们相距多远并不重要)。
然后我决定 Radius 2 = (Chosen Font Size/20)*165 (max radius)
所以,我有我的 2 个半径和两个中心点。
现在要计算圆圈上的点,我真的很努力。我决定最好的方法是创建一个增量(这里是模板)
for(int i=0; i<=n; i++) //where 'n' is users chosen number of points
{
//Equation for X point
//Equation for Y Point
cout<<"("<<X<<","<<Y<<")"<<endl;
}
现在,对于我的一生,我无法找出一个方程式来计算分数。我找到了涉及角度的方程,但因为我没有,所以我很挣扎。
本质上,我是在尝试在这里计算“P”点,除了一直绕着圆圈。 (来源:tutorvista.com)
我想的另一点可能是一个问题是对计算出的值施加限制以仅显示形状上的值。?除了使外线成为一个完整的半圆以使我有最大半径之外,不确定如何选择限制?
所以。有没有人可以与我分享有关如何准确进行的任何提示/提示/链接?
再次感谢,问题有任何问题,如果你让我知道,对不起,我会尽力纠正。
干杯
更新;
R1 = (Font/20)*130;
R2 = (Font/20)*165;
for(X1=0; X1<=n; X1++)
{
Y1 = ((2*Y)+(pow(((4*((pow((X1-X), 2)))+(pow(R1, 2)))), 0.5)))/2;
Y2 = ((2*Y)-(pow(((4*((pow((X1-X), 2)))+(pow(R1, 2)))), 0.5)))/2;
cout<<"("<<X1<<","<<Y1<<")";
cout<<"("<<X1<<","<<Y2<<")";
}
观点?