十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶(hù) + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專(zhuān)業(yè)推廣+無(wú)憂(yōu)售后,網(wǎng)站問(wèn)題一站解決
創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買(mǎi)多久送多久,劃算不套路!
讓客戶(hù)滿(mǎn)意是我們工作的目標(biāo),不斷超越客戶(hù)的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶(hù),將通過(guò)不懈努力成為客戶(hù)在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名申請(qǐng)、雅安服務(wù)器托管、營(yíng)銷(xiāo)軟件、網(wǎng)站建設(shè)、金寨網(wǎng)站維護(hù)、網(wǎng)站推廣。這篇文章將為大家詳細(xì)講解有關(guān)Python畫(huà)樹(shù)的方法,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
用Python畫(huà)出的三種樹(shù):
第一種樹(shù):
# 圖一: from turtle import * from random import * from math import * def tree(n, l): pd() # 下筆 # 陰影效果 t = cos(radians(heading() + 45)) / 8 + 0.25 pencolor(t, t, t) pensize(n / 4) forward(l) # 畫(huà)樹(shù)枝 if n > 0: b = random() * 15 + 10 # 右分支偏轉(zhuǎn)角度 c = random() * 15 + 10 # 左分支偏轉(zhuǎn)角度 d = l * (random() * 0.35 + 0.6) # 下一個(gè)分支的長(zhǎng)度 # 右轉(zhuǎn)一定角度,畫(huà)右分支 right(b) tree(n - 1, d) # 左轉(zhuǎn)一定角度,畫(huà)左分支 left(b + c) tree(n - 1, d) # 轉(zhuǎn)回來(lái) right(c) else: # 畫(huà)葉子 right(90) n = cos(radians(heading() - 45)) / 4 + 0.5 pencolor(n, n, n) circle(2) left(90) pu() backward(l)# 退回 bgcolor(0.5, 0.5, 0.5) # 背景色 ht() # 隱藏turtle speed(0) # 速度,1-10漸進(jìn),0最快 tracer(0, 0) left(90) # 左轉(zhuǎn)90度 pu() # 抬筆 backward(300) # 后退300 tree(13, 100) # 遞歸7層 done()
繪圖如下:

第二種樹(shù):
# 圖二: from turtle import * from random import * from math import * def tree(n, l): pd() # 下筆 # 陰影效果 t = cos(radians(heading() + 45)) / 8 + 0.25 pencolor(t, t, t) pensize(n / 3) forward(l) # 畫(huà)樹(shù)枝 if n > 0: b = random() * 15 + 10 # 右分支偏轉(zhuǎn)角度 c = random() * 15 + 10 # 左分支偏轉(zhuǎn)角度 d = l * (random() * 0.25 + 0.7) # 下一個(gè)分支的長(zhǎng)度 # 右轉(zhuǎn)一定角度,畫(huà)右分支 right(b) tree(n - 1, d) # 左轉(zhuǎn)一定角度,畫(huà)左分支 left(b + c) tree(n - 1, d) # 轉(zhuǎn)回來(lái) right(c) else: # 畫(huà)葉子 right(90) n = cos(radians(heading() - 45)) / 4 + 0.5 pencolor(n, n*0.8, n*0.8) circle(3) left(90) # 添加0.3倍的飄落葉子 if(random() > 0.7): pu() # 飄落 t = heading() an = -40 + random()*40 setheading(an) dis = int(800*random()*0.5 + 400*random()*0.3 + 200*random()*0.2) forward(dis) setheading(t) # 畫(huà)葉子 pd() right(90) n = cos(radians(heading() - 45)) / 4 + 0.5 pencolor(n*0.5+0.5, 0.4+n*0.4, 0.4+n*0.4) circle(2) left(90) pu() #返回 t = heading() setheading(an) backward(dis) setheading(t) pu() backward(l)# 退回 bgcolor(0.5, 0.5, 0.5) # 背景色 ht() # 隱藏turtle speed(0) # 速度,1-10漸進(jìn),0最快 tracer(0, 0) pu() # 抬筆 backward(100) left(90) # 左轉(zhuǎn)90度 pu() # 抬筆 backward(300) # 后退300 tree(12, 100) # 遞歸7層 done()
繪圖如下:

第三種樹(shù):
# 圖三:
import turtle
import random
from turtle import *
from time import sleep
t = turtle.Turtle()
w = turtle.Screen()
def tree(branchLen, t):
if branchLen > 3:
if 8 <= branchLen <= 12:
if random.randint(0, 2) == 0:
t.color('snow')
else:
t.color('lightcoral')
t.pensize(branchLen / 3)
elif branchLen < 8:
if random.randint(0, 1) == 0:
t.color('snow')
else:
t.color('lightcoral')
t.pensize(branchLen / 2)
else:
t.color('sienna')
t.pensize(branchLen / 10)
t.forward(branchLen)
a = 1.5 * random.random()
t.right(20*a)
b = 1.5 * random.random()
tree(branchLen-10*b, t)
t.left(40*a)
tree(branchLen-10*b, t)
t.right(20*a)
t.up()
t.backward(branchLen)
t.down()
def petal(m, t): # 樹(shù)下花瓣
for i in range(m):
a = 200 - 400 * random.random()
b = 10 - 20 * random.random()
t.up()
t.forward(b)
t.left(90)
t.forward(a)
t.down()
t.color("lightcoral")
t.circle(1)
t.up()
t.backward(a)
t.right(90)
t.backward(b)
def main():
t = turtle.Turtle()
myWin = turtle.Screen()
getscreen().tracer(5, 0)
turtle.screensize(bg='wheat')
t.left(90)
t.up()
t.backward(150)
t.down()
t.color('sienna')
tree(60, t)
petal(100, t)
myWin.exitonclick()
main()繪圖如下:

關(guān)于Python畫(huà)樹(shù)的方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。