乌龟和Transcrypt画一棵树

时间:2016-10-02 23:20:55

标签: python 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()

我想在浏览器中运行它以获得此效果:

image 不要担心树上的文字,是在抛光;) 我在Skulpt中运行它,也许你听说过它,你上面的效果。 现在我想在Transcrypt中运行它并将其与Skulpt和Brython进行比较。

正如你在这里看到的: http://www.transcrypt.org/live/turtle_site/turtle_site.html

Transcrypt不知何故可以用乌龟画画。

此代码中的哪些更改与Transcrypt一起使用?

你能帮我解决这个问题吗?

1 个答案:

答案 0 :(得分:3)

首先:您需要对代码进行一些修改,因为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 

使用Transcrypt

安装pip
pip install transcrypt

将Python编译为JavaScript

transcrypt turtle_tree.py

您获得的文件夹__javascript__包含文件turtle_tree.js(以及turtle_tree.min.jsturtle_tree.mod.js,但您现在不需要它)

您需要加载turtle_tree.js<div id="__turtlegraph__">的HTML文件才能显示结果。

<强> 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秒(或更短)内绘制。

enter image description here