Python 学习之小海龟绘图

在 1966 年,Seymour Papert 和 Wally Feurzig 发明了一种专门给儿童学习编程的语言——LOGO语言,它的特色就是通过编程指挥一个小海龟(turtle)在屏幕上绘图。

海龟绘图(Turtle Graphics)后来被移植到各种高级语言中,Python内置了turtle库,基本上100%复制了原始的Turtle Graphics的所有功能。

实例1

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

' 海龟绘图 '

__author__ = 'Kevin Gong'

from turtle import *
from random import *
from math import *

def drawTree(n, l):
    pd()
    t = cos(radians(heading() + 45)) / 8 + 0.25
    pencolor(t, t, t)
    pensize(n / 4)
    forward(l)
    if n > 0:
        b = random() * 15 + 10
        c = random() * 15 + 10
        d = l * (random() * 0.35 + 0.6)
        right(b)
        drawTree(n - 1, d)
        left(b + c)
        drawTree(n - 1, d)
        right(c)
    else:
        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()
speed(0)
tracer(0, 0)
left(90)
pu()
backward(300)
drawTree(13, 100)
done()

效果图

在这里插入图片描述

实例2

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

' 海龟绘图 '

__author__ = 'Kevin Gong'

from turtle import *
from random import *
from math import *

def drawTree(n, l):
    pd()
    # 阴影效果
    t = cos(radians(heading() + 45)) / 8 + 0.25
    pencolor(t, t, t)
    pensize(n / 3)

    # 画树枝
    forward(l)
    if n > 0:
        # 右分支偏转角度
        b = random() * 15 + 10

        # 左分支偏转角度
        c = random() * 15 + 10

        # 下一个分支的长度
        d = l * (random() * 0.35 + 0.6)

        # 右转一定角度,画右分支
        right(b)
        drawTree(n - 1, d)

        # 左转一定角度,画左分支
        left(b + c)
        drawTree(n - 1, d)

        # 转回来
        right(c)
    else:
        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)


            # 画叶子
            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()
speed(0)
tracer(0, 0)
pu()
backward(100)
left(90)
pu()
backward(300)
drawTree(12, 100)
done()

效果图

在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章