程序员就只能简简单单的用手里的代码来实现自己最直接的想法。————-鲁迅表示这句话他没说过—————————————————————————————————————————————
在家上网课贼无聊,于是复习以前的知识点,瞥到之前用递归实现的科赫曲线,突然来了一点头绪,上博客转转,却看到一堆大佬画的樱花树,实属牛逼,就是感觉教学不是很详细,于是我研究了一下,写下我所理解的关于树的画法,下面有些思想还是借鉴大佬们的。
私信小编01即可获取大量Python学习资料
————————————————————————————————————————————–
在这里我们是要用到turtle函数库,用法可以参考我关注的博主教程:turtle库的使用
这里如果有不懂递归的朋友也可以参考这位博主的解析:递归思路
效果图:
一种颜色的花朵的树:
这是很多大佬的原思想图,我做了一点改进。
画这棵树分为二部分,画整体和画落下的花瓣:
画落下的花瓣:
这里用到了随机函数库random,确保每次画叶子的位置不同,形成那种真实感:
import turtle as t
for i in range(150): # 循环150次 绘制 掉落的花瓣
a = 250 - 500 * random.random() # 花瓣整体长度,有正有负就可以让海龟往二个方向走
b = 10 - 20 * random.random() # 花瓣整体宽度,正负道理一致,数值可以根据实际输入
t.penup() # 抬笔向前随机走b个宽度,左转90,随机走a个长度,落笔,跟我画一个小圈圈
t.fd(b)
t.left(90)
t.fd(a)
t.pendown()
t.pencolor("lightcoral") # 珊瑚色
t.circle(1)
t.penup() # 跟我左边抬个笔,后退个a的长度,右边转个90,后退个b的宽度,这样可以
t.backward(a) # 让海龟回到和刚出发位置差不多的水平线上,所以上面的b设置最好小一点
t.right(90)
t.backward(b)
画树枝部分:
这里用到了二叉树的递归思想:
我就小小的画了一个很正的二叉树给你们看看效果就行
这样的树就是很端正,但是实话就是不好看,我们给出代码:
import turtle as t
brance = 60 # 枝条 总度
def draw_tree1(brance):
if brance > 10: # 条件满足先画右边
t.fd(brance) # 绘制最开始的树干
t.right(30) # 然后右转30,第一个右分支
draw_tree1(brance / 1.5) # 继续画右边的 走不动了往左边转60 和下面一样用到了递归
t.left(60) # 然后左转60 进入向左绘制
draw_tree1(brance / 1.5) # 继续画左边的,走不动了右转30回到最后一步的之前那个节点
t.right(30)
# 给最后二个树枝画上雪白的叶子
if brance / 1.5 <= 10: # 这个条件可以根据实际设置
t.pencolor("snow")
else:
t.pencolor("Tan") # 褐色
t.backward(brance) # 当递归条件不满足的时候,后退一个节点
思考什么因素让这棵树如此端正,因为每次向左向右的角度固定,向前衍生的枝条长度也是固定
那我们可以想到用随机函数库random来实现每次的操作不一致,就能产生不一样的效果
画一种颜色的树:
代码:
import turtle as t
brance = 70
def draw_tree(brance): # 画树枝部分 分支量
if brance > 4: # 设置一个最小分支量 可以自己改
if 8 <= brance <= 16: # 分支量在这个范围内,画笔大小缩小四倍,画中等细小的树枝
t.pencolor("lightcoral") # 珊瑚色
t.pensize(brance / 4)
elif brance < 8: # 分支量在这个范围内,画笔大小缩小二倍 , 画细小的树枝
t.pencolor("lightcoral") # 珊瑚色
t.pensize(brance / 2)
else: # 其他范围内,我们让程序画树干部分
t.pencolor("Tan") # 褐色
t.pensize(brance / 10) # 缩小支柱
t.fd(brance) # 最开始的树干部分
a = 1.5 * random.random() # 随机度数因子
t.right(20 * a) #右转随机角度
b = 1.5 * random.random() # 随机长度因子
draw_tree(brance - 10 * b) # 往右画,直到画不动为止,然后左转随机度数
t.left(40 * a) # 左转随机角度
draw_tree(brance - 10 * b) # 往左画,直到画不动位置,然后右转随机度数
t.right(20 * a) # 右转一定角度
t.penup()
t.backward(brance) # 递归结束回到上一个节点
t.pendown()
这样我们就实现了一棵只有一种颜色花朵的树
画二种颜色的树:
如何绘制二种颜色的树呢?我们只需要在每一个分支范围内进行一次判断,如果条件为真,那我们改颜色,反之,我们不改颜色:
代码如下:
if 8 <= brance <= 16:
if random.randint(0, 2) == 0: #这里随机三个数 三分之一概论 改颜色
t.pencolor("snow") # 因为这个范围还是画中等细小树枝
else:
t.pencolor("lightcoral") # 珊瑚色
t.pensize(brance / 4)
elif brance < 8:
if random.randint(0, 1) == 0: # 这里随机两二个树,二分之一
t.pencolor("snow") # 因为这里画很细小的树枝 概论小点
else:
t.pencolor("lightcoral") # 珊瑚色
t.pensize(brance / 2)
else:
t.pencolor("Tan") # 褐色
t.pensize(brance / 10) # 缩小分支量
大致代码基本都给出了,这里说明一下,如果想绘制二棵以上,只要在主程序下面先运行一棵,然后修改一下起点位置,重新调用一下二个函数就行,里面的值最好设置小一点,可以有个层次感。
主程序:
import turtle as T
import random
t = T.Turtle()
w = T.Screen()
w.screensize(bg='wheat') # 画布颜色小麦色 个人觉得还是这个最搭配
t.getscreen().tracer(5, 0) # 返回正在绘制的对象 并且加速5倍
t.pensize(5)
t.left(90)
t.penup()
t.backward(250)
t.pendown()
t.pencolor("Tan") # 褐色
draw_tree(70) # 第一颗桃花,支柱设置70
petel(250) # 花瓣250
w.exitonclick() # 点击关闭画布