gpt4 book ai didi

java - LibGDX - 绘制等边三角形

转载 作者:行者123 更新时间:2023-11-30 08:19:12 25 4
gpt4 key购买 nike

我正在尝试使用 LibGDX 库制作一个等边三角形,但我不是最擅长几何/三角学。我非常接近,但一侧太长,我不知道出了什么问题。

这些点是相对于形状中心的。

    shapeX[0] = x + MathUtils.cos(radians) * Variables.lineLength;
shapeY[0] = y + MathUtils.sin(radians) * Variables.lineLength;

shapeX[1] = x + MathUtils.cos(radians - 4 * Variables.pi / (Variables.pi * 2)) * Variables.lineLength;
shapeY[1] = y + MathUtils.sin(radians - 4 * Variables.pi / (Variables.pi * 2)) * Variables.lineLength;

shapeX[2] = x + MathUtils.cos(radians + 4 * Variables.pi / (Variables.pi * 2)) * Variables.lineLength;
shapeY[2] = y + MathUtils.sin(radians + 4 * Variables.pi / (Variables.pi * 2)) * Variables.lineLength;

最佳答案

一个圆有 2pi 弧度。要得到等边n边多边形,请将2pi分成n block :(2/n)pi。当 i = 0,1,...(n-1) 时,多边形顶点将落在 i(2/n)pi 处。由于 n = 3,因此您需要 0*2/3pi = 0pi、1*2/3pi = 2/3pi 和 2*2/3pi = 4/3pi。但使用循环可能比对这些值进行硬编码更容易。

此外,如果您希望边缘具有给定的线长,则必须按 sqrt(3)/3 缩放才能找到半径。为什么?单位圆外接的等边三角形的边长为 3/sqrt(3),因此按倒数缩放半径即可得到单位长度的边。总结一下这一切,

double radius = Math.sqrt(3) / 3 * Variables.lineLength;
for (int i = 0; i < 3; ++i) {
double theta = 2 * Math.PI / 3 * i;
shapeX[i] = x + radius * MathUtils.cos(theta);
shapeY[i] = y + radius * MathUtils.sin(theta);
}

请注意,这会将第一个顶点置于正 x 轴上。要旋转多边形,请将所需的偏移添加到theta。例如,要使第一个顶点位于正 y 轴上,请使用 pi/2。

关于java - LibGDX - 绘制等边三角形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29199458/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com