找回密码
 立即注册

扫一扫,访问微社区

QQ登录

只需一步,快速开始

查看: 3853|回复: 2

[资源与教程] python画一颗樱花树(不同品种)

0

主题

0

帖子

0

积分

贫民

积分
0
熊派叔叔 发表于 2021-1-9 17:18:39 | 显示全部楼层 |阅读模式
本帖最后由 熊派叔叔 于 2021-1-9 17:20 编辑

动态生成樱花
代码:
import turtle as T
import random
import time

# 画樱花的躯干(60,t)
def Tree(branch, t):
    time.sleep(0.0005)
    if branch > 3:
        if 8 <= branch <= 12:
            if random.randint(0, 2) == 0:
                t.color('snow')  # 白
            else:
                t.color('lightcoral')  # 淡珊瑚色
            t.pensize(branch / 3)
        elif branch < 8:
            if random.randint(0, 1) == 0:
                t.color('snow')
            else:
                t.color('lightcoral')  # 淡珊瑚色
            t.pensize(branch / 2)
        else:
            t.color('sienna')  # 赭(zhě)色
            t.pensize(branch / 10)  # 6
        t.forward(branch)
        a = 1.5 * random.random()
        t.right(20 * a)
        b = 1.5 * random.random()
        Tree(branch - 10 * b, t)
        t.left(40 * a)
        Tree(branch - 10 * b, t)
        t.right(20 * a)
        t.up()
        t.backward(branch)
        t.down()

# 掉落的花瓣
def Petal(m, t):
    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)

# 绘图区域
t = T.Turtle()
# 画布大小
w = T.Screen()
t.hideturtle()  # 隐藏画笔
t.getscreen().tracer(5, 0)
w.screensize(bg='wheat')  # wheat小麦
t.left(90)
t.up()
t.backward(150)
t.down()
t.color('sienna')

# 画樱花的躯干
Tree(60, t)
# 掉落的花瓣
Petal(200, t)
w.exitonclick()

飘落效果效果:
实现代码:
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)

    if n>0:
        b = random()*15+10
        c = random()*15+10
        d = l*(random()*0.25+0.7)

        right(b)
        tree(n-1,d)

        left(b+c)
        tree(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)

        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)#速度 1-10
tracer(0,0)
pu()
backward(100)
left(90)
pu()
backward(300)
tree(12,100)
done()

文章转载自派生社区:https://bbs.266.la/forum.php?mod=viewthread&tid=827
Python学习交流群:1047602540

回复

使用道具 举报

0

主题

1

帖子

1

积分

贫民

积分
1
zpwang 发表于 2021-3-21 19:38:45 | 显示全部楼层
谢谢!刚要学习python了。好好参考一下。
回复 支持 反对

使用道具 举报

0

主题

2

帖子

2

积分

贫民

积分
2
史诗 发表于 2021-3-22 13:09:25 | 显示全部楼层
{:6_169:
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表