使用python制作随机多边形

时间:2017-03-28 05:45:16

标签: python dictionary tuples polygon

我是一个非常大的人,并且通过python创建一个随机多边形的代码。 我在代码中找不到任何错误,但我无法打印所有顶点,只能打印一对顶点的x,y坐标。 有人可以告诉我吗?我认为map(tuple,verts)是一个有争议的东西。

非常感谢。

import math, random
def generatePolygon( ctrX, ctrY, aveRadius, irregularity, spikeyness, numVerts ) :

    irregularity = clip( irregularity, 0,1 ) * 2*math.pi / numVerts
    spikeyness = clip( spikeyness, 0,1 ) * aveRadius

    # generate n angle steps
    angleSteps = []
    lower = (2*math.pi / numVerts) - irregularity
    upper = (2*math.pi / numVerts) + irregularity
    sum = 0
    for i in range(numVerts) :
        tmp = random.uniform(lower, upper)
        angleSteps.append( tmp )
        sum = sum + tmp

    # normalize the steps so that point 0 and point n+1 are the same
    k = sum / (2*math.pi)
    for i in range(numVerts) :
        angleSteps[i] = angleSteps[i] / k

    # now generate the points
    points = []
    angle = random.uniform(0, 2*math.pi)
    for i in range(numVerts) :
        r_i = clip( random.gauss(aveRadius, spikeyness), 0, 2*aveRadius )
        x = ctrX + r_i*math.cos(angle)
        y = ctrY + r_i*math.sin(angle)
        points.append(( int(x),int(y) ))
        angle = angle + angleSteps[i]

        return points

def clip(x, min, max) :
    if( min > max ) :  return x    
    elif( x < min ) :  return min
    elif( x > max ) :  return max
    else :             return x


verts = generatePolygon( ctrX=250, ctrY=250, aveRadius=100, irregularity=0, spikeyness=0, numVerts=16 )

tupVerts = list(map(tuple,verts))

print(tupVerts)

1 个答案:

答案 0 :(得分:0)

在计算一个点之后,你很快就从函数返回了。这是问题所在:

for i in range(numVerts) :
    r_i = clip( random.gauss(aveRadius, spikeyness), 0, 2*aveRadius )
    x = ctrX + r_i*math.cos(angle)
    y = ctrY + r_i*math.sin(angle)
    points.append(( int(x),int(y) ))
    angle = angle + angleSteps[i]

    return points # <--- here

for i in range(numVerts) :
    r_i = clip( random.gauss(aveRadius, spikeyness), 0, 2*aveRadius )
    x = ctrX + r_i*math.cos(angle)
    y = ctrY + r_i*math.sin(angle)
    points.append(( int(x),int(y) ))
    angle = angle + angleSteps[i]

return points # <--- Should look like this
相关问题