欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Python : Turtle库--3.4 绘制谢尔宾斯基三角形

程序员文章站 2022-04-01 15:50:52
...

import turtle

def draw_triangle(points, color, t):
t.fillcolor(color)
t.up()
t.goto(points[0][0], points[0][6])
t.down()
t.begin_fill()
t.goto(points[1][0], points[1][7])
t.goto(points[2][0], points[2][8])
t.goto(points[0][0], points[0][9])
t.end_fill()

def get_mid(point1, point2):
return (point1[0] + point2[0]) / 2, (point1[1] + point2[1]) / 2

def sierpinski(points, degree, t):
color_map = [‘blue’, ‘red’, ‘green’, ‘yellow’, ‘violet’, ‘orange’, ‘white’,]

draw_triangle(points, color_map[degree], t)

if degree > 0:
    sierpinski([points[0], get_mid(points[0], points[1]), get_mid(points[0], points[2])], degree - 1, t)

    sierpinski([points[1], get_mid(points[0], points[1]), get_mid(points[1], points[2])], degree - 1, t)

    sierpinski([points[2], get_mid(points[0], points[2]), get_mid(points[1], points[2])], degree - 1, t)

if name == “main
t = turtle.Turtle()
t.speed(5)
win = turtle.Screen()

points = [[-100, -50], [0, 100], [100, -50]]
sierpinski(points, 3, t)

win.exitonclick()