用 Transcrypt 龟并画一棵树
Turtle and draw a tree with Transcrypt
今天我想用 Transcrypt 在浏览器中画一棵树。
我在 Python 中有代码,可以在 Skulpt 中使用:
import random
import turtle
def tree(size, myTurtle):
myTurtle.pensize(size / 20)
if size < random.randint(1,2) * 20:
myTurtle.color("green")
else:
myTurtle.color("brown")
if size > 5:
myTurtle.forward(size)
myTurtle.left(25)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.right(50)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.left(25)
myTurtle.penup()
myTurtle.backward(size)
myTurtle.pendown()
window = turtle.Screen()
window.setup(800,600)
window.bgcolor("white")
myTurtle = turtle.Turtle()
myTurtle.color("brown", "blue")
myTurtle.left(90)
myTurtle.speed(0)
myTurtle.penup()
myTurtle.setpos(0, -250)
myTurtle.pendown()
我想在浏览器中运行它以获得这种效果:
不要担心树上的文字,它是波兰文的;)
我运行这个在Skulpt,也许你听说过,上面有效果。
现在我想 运行 在 Transcrypt 中将其与 Skulpt 和 Brython 进行比较。
如您所见:
http://www.transcrypt.org/live/turtle_site/turtle_site.html
Transcrypt 可以用 turtle 绘制。
为了使用 Transcrypt,这段代码有什么变化?
你能帮我解决这个问题吗?
首先:您需要对代码进行一些修改,因为 Transcrypt
中的某些函数具有不同的名称或不存在。您必须添加 turtle.done()
才能显示结果。
turtle_tree.py
import random
import turtle
def tree(size, myTurtle):
myTurtle.pensize(size / 20)
if size < random.randint(1,2) * 20:
myTurtle.color("green")
else:
myTurtle.color("brown")
if size > 5:
myTurtle.forward(size)
myTurtle.left(25)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.right(50)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.left(25)
myTurtle.up() # penup()
myTurtle.back(size) # backward(size)
myTurtle.down() # pendown()
#window = turtle.Screen() # doesn't exists
#window.setup(800,600) # doesn't exists
#window.bgcolor("white") # doesn't exists
myTurtle = turtle.Turtle()
myTurtle.color("brown", "blue")
myTurtle.left(90)
myTurtle.speed(0)
myTurtle.up() # penup()
myTurtle.goto(0, 250) # setpos(0, -250)
myTurtle.down() # pendown()
tree(135, myTurtle)
myTurtle.done() # display
使用 pip
安装 Transcrypt
pip install transcrypt
将Python编译成JavaScript
transcrypt turtle_tree.py
您获得文件夹 __javascript__
和文件 turtle_tree.js
(和 turtle_tree.min.js
、turtle_tree.mod.js
,但您现在不需要它)
您需要 HTML 文件加载 turtle_tree.js
并具有 <div id="__turtlegraph__">
来显示结果。
turtle_tree.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>Turtle Tree</title>
<style>
#__turtlegraph__ {
height: 600px;
width: 800px;
}
</style>
</head>
<body>
<div id="__turtlegraph__"></div>
<script src='turtle_tree.js'></script>
</body>
</html>
将HTML文件放入__javascript__
文件夹,然后在浏览器中打开。
在 Python 3.5.2 / Linux Mint 17.3 / Firefox 48.0 上测试 - 绘制时间为 1 秒(或更短)。
今天我想用 Transcrypt 在浏览器中画一棵树。 我在 Python 中有代码,可以在 Skulpt 中使用:
import random
import turtle
def tree(size, myTurtle):
myTurtle.pensize(size / 20)
if size < random.randint(1,2) * 20:
myTurtle.color("green")
else:
myTurtle.color("brown")
if size > 5:
myTurtle.forward(size)
myTurtle.left(25)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.right(50)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.left(25)
myTurtle.penup()
myTurtle.backward(size)
myTurtle.pendown()
window = turtle.Screen()
window.setup(800,600)
window.bgcolor("white")
myTurtle = turtle.Turtle()
myTurtle.color("brown", "blue")
myTurtle.left(90)
myTurtle.speed(0)
myTurtle.penup()
myTurtle.setpos(0, -250)
myTurtle.pendown()
我想在浏览器中运行它以获得这种效果:
如您所见: http://www.transcrypt.org/live/turtle_site/turtle_site.html
Transcrypt 可以用 turtle 绘制。
为了使用 Transcrypt,这段代码有什么变化?
你能帮我解决这个问题吗?
首先:您需要对代码进行一些修改,因为 Transcrypt
中的某些函数具有不同的名称或不存在。您必须添加 turtle.done()
才能显示结果。
turtle_tree.py
import random
import turtle
def tree(size, myTurtle):
myTurtle.pensize(size / 20)
if size < random.randint(1,2) * 20:
myTurtle.color("green")
else:
myTurtle.color("brown")
if size > 5:
myTurtle.forward(size)
myTurtle.left(25)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.right(50)
tree(size - random.randint(10, 20), myTurtle)
myTurtle.left(25)
myTurtle.up() # penup()
myTurtle.back(size) # backward(size)
myTurtle.down() # pendown()
#window = turtle.Screen() # doesn't exists
#window.setup(800,600) # doesn't exists
#window.bgcolor("white") # doesn't exists
myTurtle = turtle.Turtle()
myTurtle.color("brown", "blue")
myTurtle.left(90)
myTurtle.speed(0)
myTurtle.up() # penup()
myTurtle.goto(0, 250) # setpos(0, -250)
myTurtle.down() # pendown()
tree(135, myTurtle)
myTurtle.done() # display
使用 pip
Transcrypt
pip install transcrypt
将Python编译成JavaScript
transcrypt turtle_tree.py
您获得文件夹 __javascript__
和文件 turtle_tree.js
(和 turtle_tree.min.js
、turtle_tree.mod.js
,但您现在不需要它)
您需要 HTML 文件加载 turtle_tree.js
并具有 <div id="__turtlegraph__">
来显示结果。
turtle_tree.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>Turtle Tree</title>
<style>
#__turtlegraph__ {
height: 600px;
width: 800px;
}
</style>
</head>
<body>
<div id="__turtlegraph__"></div>
<script src='turtle_tree.js'></script>
</body>
</html>
将HTML文件放入__javascript__
文件夹,然后在浏览器中打开。
在 Python 3.5.2 / Linux Mint 17.3 / Firefox 48.0 上测试 - 绘制时间为 1 秒(或更短)。