我假设您想要的是一种生成等边多边形坐标的方法,您可以将其输入到绘图程序中.我不确定你使用的是哪个库,所以我将坚持使用值列表:
import math
def polygon(sides, radius=1, rotation=0, translation=None):
one_segment = math.pi * 2 / sides
points = [
(math.sin(one_segment * i + rotation) * radius,
math.cos(one_segment * i + rotation) * radius)
for i in range(sides)]
if translation:
points = [[sum(pair) for pair in zip(point, translation)]
for point in points]
return points
那里有一点点,所以我会谈谈它.基本方法是扫出一个圆圈,并在其上放置n个等间距点.这些将是我们多边形的点,从12点钟位置开始.
首先要做的是从中心向外计算每个楔形的角度(以弧度表示).圆中的弧度总数为2 pi,因此我们的值为每段2 pi / n.
之后我们将值转换一定量,因为您可能希望多边形位于屏幕的中心,而不是角落.
几个例子
print polygon(5) # A unit pentagon
# [(0.0, 1.0), (0.9510565162951535, 0.30901699437494745), (0.5877852522924732, -0.8090169943749473), (-0.587785252292473, -0.8090169943749476), (-0.9510565162951536,