成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python筆下那些神奇的樹

開發(fā) 后端
turtle是一只神奇的小海龜,可以畫出大千世界。而turtle加入了python大家族,像是如龜得水,變得更加受歡迎。

turtle是一只神奇的小海龜,可以畫出大千世界。而turtle加入了python大家族,像是如龜得水,變得更加受歡迎。

古人有詩云“庭中有奇樹,綠葉發(fā)華滋”,樹之美,或婀娜、或繁茂、或蒼勁、或青翠。python-turtle筆下的樹更是別有一番風味。

小園新種紅櫻樹,閑繞花行便當游。 

  1. coding=gbk 
  2. import turtle as Timport randomimport time 
  3. # 畫櫻花的軀干(60,t) 
  4. def Tree(branch, t):    time.sleep(0.0005) 
  5.     if branch > 3: 
  6.         if 8 <= branch <= 12: 
  7.             if random.randint(0, 2) == 0: 
  8.                 t.color('snow')  # 白 
  9.             else: 
  10.                 t.color('lightcoral')  # 淡珊瑚色 
  11.             t.pensize(branch / 3) 
  12.         elif branch < 8: 
  13.             if random.randint(0, 1) == 0: 
  14.                 t.color('snow') 
  15.             else: 
  16.                 t.color('lightcoral')  # 淡珊瑚色 
  17.             t.pensize(branch / 2) 
  18.         else: 
  19.             t.color('sienna')  # 赭(zhě)色 
  20.             t.pensize(branch / 10)  # 6 
  21.         t.forward(branch)        a = 1.5 * random.random() 
  22.         t.right(20 * a) 
  23.         b = 1.5 * random.random() 
  24.         Tree(branch - 10 * b, t) 
  25.         t.left(40 * a) 
  26.         Tree(branch - 10 * b, t) 
  27.         t.right(20 * a) 
  28.         t.up()        t.backward(branch)        t.down()# 掉落的花瓣def Petal(m, t):    for i in range(m): 
  29.         a = 200 - 400 * random.random() 
  30.         b = 10 - 20 * random.random() 
  31.         t.up()        t.forward(b)        t.left(90) 
  32.         t.forward(a)        t.down()        t.color('lightcoral')  # 淡珊瑚色 
  33.         t.circle(1) 
  34.         t.up()        t.backward(a)        t.right(90) 
  35.         t.backward(b)# 繪圖區(qū)域t = T.Turtle()# 畫布大小w = T.Screen()# 隱藏畫筆t.hideturtle()  t.getscreen().tracer(5, 0) 
  36. # wheat小麥w.screensize(bg='white')   
  37. t.left(90) 
  38. t.up()t.backward(150) 
  39. t.down()t.color('sienna') 
  40. # 畫櫻花的軀干Tree(60, t) 
  41. # 掉落的花瓣Petal(200, t) 
  42. w.exitonclick() 

江南有丹橘,經冬猶綠林

  1. coding=gbk 
  2. from turtle import *from random import * 
  3. from math import * 
  4. class Tree:    def __init__(self):        setup(1000, 500) 
  5.         bgcolor(1, 1, 1)  # 背景色 
  6.         # ht()  # 隱藏turtle        speed(10)  # 速度 1-10漸進,0 最快 
  7.         # tracer(1, 100)    # 設置繪圖屏幕刷新頻率,參數1設置在正常刷新頻次的第參數1次刷新,參數2設置每次刷新的時延 
  8.         tracer(0, 0) 
  9.         pu()  # 抬筆        backward(100) 
  10.         # 保證筆觸箭頭方向始終不向下,此處使其左轉90度,而不是右轉 
  11.         left(90)  # 左轉90度 
  12.         backward(300)  # 后退300 
  13.     def tree(self, n, l):        pd()  # 下筆        # 陰影效果        t = cos(radians(heading() + 45)) / 8 + 0.25 
  14.         pencolor(t, t, t)        pensize(n / 1.2) 
  15.         forward(l)  # 畫樹枝        if n > 0: 
  16.             b = random() * 15 + 10  # 右分支偏轉角度 
  17.             c = random() * 15 + 10  # 左分支偏轉角度 
  18.             d = l * (random() * 0.25 + 0.7)  # 下一個分支的長度 
  19.             # 右轉一定角度,畫右分支            right(b)            self.tree(n - 1, d) 
  20.             # 左轉一定角度,畫左分支            left(b + c)            self.tree(n - 1, d) 
  21.             # 轉回來            right(c)        else: 
  22.             # 畫葉子            right(90) 
  23.             n = cos(radians(heading() - 45)) / 4 + 0.5 
  24.             pencolor(n, n * 0.8, n * 0.8) 
  25.             fillcolor(n, n * 0.8, n * 0.8) 
  26.             begin_fill()            circle(3) 
  27.             left(90) 
  28.             end_fill()            # 添加0.3倍的飄落葉子 
  29.             if random() > 0.7: 
  30.                 pu()                # 飄落                t = heading()                an = -40 + random() * 40 
  31.                 setheading(an)                dis = int(800 * random() * 0.5 + 400 * random() * 0.3 + 200 * random() * 0.2) 
  32.                 forward(dis)                setheading(t)                # 畫葉子                pd()                right(90) 
  33.                 n = cos(radians(heading() - 45)) / 4 + 0.5 
  34.                 pencolor(n * 0.5 + 0.5, 0.4 + n * 0.4, 0.4 + n * 0.4) 
  35.                 fillcolor(n, n * 0.8, n * 0.8) 
  36.                 begin_fill()                circle(2) 
  37.                 left(90) 
  38.                 end_fill()                pu()                # 返回                t = heading()                setheading(an)                backward(dis)                setheading(t)            # pass        pu()        backward(l)  # 退回def main():    tree = Tree()    tree.tree(12, 100)  # 遞歸7層 
  39.     done()if __name__ == '__main__': 
  40.     main() 

落紅不是無情物,化作春泥更護花

  1. coding=gbk 
  2. from turtle import * 
  3. from random import * 
  4. # 畫樹方法def drawTree(n, l):    pendown()    pencolor('#5d3c3c') 
  5.     pensize( n / 1.5) 
  6.     forward(l)    if n > 0: 
  7.         dr = randint(30, 40) 
  8.         dl =  randint(30, 40) 
  9.         move = l * (random() * 0.4 + 0.5) 
  10.         right(dr)        drawTree(n - 1, move) 
  11.         left(dr + dl)        drawTree(n - 1, move) 
  12.         right(dl)    else: 
  13.         drawPetal(3) 
  14.     penup()    backward(l)# 花瓣位置生成def petalPlace(m, x, y):    penup()    goto(x, y) 
  15.     pendown()    setheading(0) 
  16.     tracer(False)    for i in range(m): 
  17.         if i == 0: 
  18.             drawPetal(5) 
  19.         else: 
  20.             penup()            goto(x, y) 
  21.             a = randint(20, 400) 
  22.             b = randint(-50, 50) 
  23.             forward(a)            left(90) 
  24.             forward(b)            right(90) 
  25.             pendown()            drawPetal(5) 
  26. # 花朵繪畫方法def drawPetal(n):    colormode(255) 
  27.     r = randint(200, 255) 
  28.     g = randint(8, 158) 
  29.     b = randint(8, 158) 
  30.     begin_fill()    fillcolor(r, g, b)    pencolor(r, g, b)    circle(n)    end_fill()# 啟動方法def run():    setup(1.0, 1.0) 
  31.     penup()    goto(-50, -150) 
  32.     left(90) 
  33.     pendown()    hideturtle()    tracer(False)    drawTree(13, 150) 
  34.     petalPlace(160, -100, -150) 
  35. run()done() 

川原秋色靜,蘆葦晚風鳴

Python筆下那些神奇的樹

  1. import turtle 
  2. import randomstack = []def createWord(max_it, word, proc_rules, x, y, turn): 
  3.     turtle.up()    turtle.home()    turtle.goto(x, y)    turtle.right(turn)    turtle.down()    t = 0 
  4.     while t < max_it: 
  5.         word = rewrite(word, proc_rules)        drawit(word, 5, 20) 
  6.         tt = t+1 
  7. def rewrite(word, proc_rules): 
  8.     wordList = list(word)    for i in range(len(wordList)): 
  9.         curChar = wordList[i]        if curChar in proc_rules: 
  10.             wordList[i] = proc_rules[curChar]    return "".join(wordList) 
  11. def drawit(newWord, d, angle): 
  12.     newWordLs = list(newWord)    for i in range(len(newWordLs)): 
  13.         cur_Char = newWordLs[i]        if cur_Char == 'F': 
  14.             turtle.forward(d)        elif cur_Char == '+': 
  15.             turtle.right(angle)        elif cur_Char == '-': 
  16.             turtle.left(angle)        elif cur_Char == '[': 
  17.             state_push()        elif cur_Char == ']': 
  18.             state_pop()def state_push(): 
  19.     global stack 
  20.     stack.append((turtle.position(), turtle.heading()))def state_pop(): 
  21.     global stack 
  22.     position, heading = stack.pop()    turtle.up()    turtle.goto(position)    turtle.setheading(heading)    turtle.down()def randomStart(): 
  23.     x = random.randint(-300, 300) 
  24.     y = random.randint(-320, -280) 
  25.     heading = random.randint(-100, -80) 
  26.     return ((x, y), heading) 
  27. def main(): 
  28.     rule_sets = []    rule_sets.append(((3, 5), 'F', {'F':'F[+F][-F]F'})) 
  29.     rule_sets.append(((4, 6), 'B', {'B':'F[-B][+ B]', 'F':'FF'})) 
  30.     rule_sets.append(((2, 4), 'F', {'F':'FF+[+F-F-F]-[-F+F+F]'})) 
  31.     tree_count = 50 
  32.     turtle.tracer(10, 0) 
  33.     for x in range(tree_count): 
  34.         rand_i = random.randint(0, len(rule_sets) - 1) 
  35.         selected_ruleset = rule_sets[rand_i]        i_range, word, rule = selected_ruleset        low, high = i_range        i = random.randint(low, high)        start_position, start_heading = randomStart()        start_x, start_y = start_position        createWord(i, word, rule, start_x, start_y, start_heading)if __name__ == '__main__': main() 

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2016-08-04 13:42:25

ExcelExcel快捷鍵

2021-05-05 14:00:25

QQ手機QQ移動應用

2020-06-08 07:52:31

Python開發(fā)工具

2018-09-03 16:05:03

編程語言Python代碼技巧

2024-01-03 08:12:10

計算求和Python內置函數

2025-06-04 08:05:00

Peewee?數據庫開發(fā)

2025-06-09 10:15:00

FastAPIPython

2021-11-02 16:25:41

Python代碼技巧

2025-05-27 08:00:00

Pythonemoji

2025-06-09 07:25:00

filelock數據庫

2025-06-05 08:10:00

PyneconePythonWeb 應用

2025-06-05 10:00:00

GensimPython

2025-05-29 10:00:00

ZODBPython數據庫

2025-06-04 10:05:00

Gooey開源Python

2025-06-10 08:00:00

Pygalpython

2025-05-28 08:00:00

Pythonpython-jos開發(fā)

2019-10-15 15:15:31

Python大數據函數

2024-04-01 05:00:00

GUIpythonDearPyGui

2021-03-09 23:12:51

Python集合項目

2017-08-08 16:04:30

Python圖片處理文章提取器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲一区二区在线视频 | 在线黄av | 国产一级一片免费播放 | 亚洲国产一区二区在线 | 欧美在线一区视频 | 热久久久久| 另类专区成人 | 97操操 | av福利网站 | 天天操网 | 一级黄在线观看 | 久久久久久毛片免费观看 | 欧美性极品xxxx做受 | 国产精品中文在线 | 91久久 | 亚洲精品久久久久久宅男 | 国产一区高清 | 午夜免费福利电影 | av网站免费看 | 天天干天天色 | 91精品福利 | 亚洲成人动漫在线观看 | 欧美成人精品激情在线观看 | 精品国产乱码久久久久久蜜柚 | 天天躁日日躁狠狠很躁 | 久热国产在线 | 91天堂网 | 999免费观看视频 | 精品成人一区 | 亚洲国产成人av好男人在线观看 | 久久99精品国产 | 精品视频一区二区 | 99热精品国产 | 国产欧美一级 | 91在线免费观看 | 午夜影院网站 | 欧美理论 | 理论片免费在线观看 | 请别相信他免费喜剧电影在线观看 | 欧美大片久久久 | 日韩久久久久久久 |