[英]restoring recorded state in l-system code using turtle graphics
我正在使用海龜圖形來重現 l 系統(TurtleWorld 庫)。 我嘗試應用的規則在不涉及返回到以前保存的 state 時效果很好,但是只要有 [ 和 ](參見下面的規則),事情就會中斷,烏龜只會隨機繪制 bs。
基本上,我認為檢查 ']' 存在位置的 IF 語句是代碼中斷的地方。 (另外,我知道它目前沒有優化,為了清楚起見,我寫了一個可靠的 IF ......)
編輯:新代碼 - 這整個計算角度的事情是不必要的,因為我們有 get_heading(),它告訴我們我們所面對的角度。
import turtle
turtle.down()
n = 'F'
s1 = 'F'
s2 = 'FF-[-F+F+F]+[+F-F-F]'
#s3 = 'F'
#s4 = 'FF'
steps = 5
for i in range(steps):
n = n.replace(s1,s2)
#n = n.replace(s3,s4)
a = 25
x = []
y = []
angle = []
for i in n:
if i == 'F':
turtle.forward(2)
if i == '+':
turtle.left(a)
if i == '-':
turtle.right(a)
if i=='[':
x.append(turtle.xcor())
y.append(turtle.ycor())
angle.append(turtle.heading())
if i==']':
turtle.pu()
turtle.setpos(x[len(x)-1],y[len(y)-1])
turtle.right(turtle.heading())
turtle.setheading(angle[len(angle)-1])
x.pop()
y.pop()
angle.pop()
turtle.pd()
幾個想法:
]
-處理程序中將angle
設置為新角度( newa
)。newa>0
會將其向左轉。rt
可以很好地處理負角嗎?pop
並推送 state 的元組或類似的東西,您可以大大簡化您的代碼。-1
的索引等於len(lst) - 1
。 pop
建議的示例:
>>> state = []
>>> angle = 90
>>> posx = 10
>>> posy = 15
>>> state.append((angle, posx, posy))
>>> angle = 40
>>> angle, posx, posy = state.pop()
>>> angle
90
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.