代码详解

(一)绘制画幕

首先绘制画幕,命令说明如下:

screensize(width, height, bg=color):设置画幕大小及颜色

setup(p1, p2):设置画幕大小,当 p1、p2 为小数时表示屏幕占比;当 p1、p2 为整数时表示像素

tracer(speed):设置绘制速度,speed越大表示绘制速度越快

def get_screen(width, height, color, speed):

# 创建画幕

screen_obj = turtle.Screen()

# 画布大小:(width, height),颜色:color

screen_obj.screensize(width, height, bg=color)

screen_obj.setup(1.0, 1.0)

# speed倍加速

screen_obj.tracer(speed)

return screen_obj

(二)绘制落花

在确定落花数量的情况下,我们首先要评估落花的范围,这里通过两句语句来约束落花的范围(落花数量越多,当然地落花范围也就越大):

# 有正有负就可以让画笔往二个方向走

x = flower - 4 * flower * random()

# 花瓣整体宽度(-10, 10)

y = 10 - 20 * random()

然后我们来讲讲 turtle 常用的几个命令吧:

首先,我们得明确,对于 turtle 画布来说,其为一个 xOy 的平面,画布中心为原点 O ;对于 turtle 画笔来说,其有一个初始方向,指向 x 轴正方向。

penup():起笔(可以想象成画画的时候沾墨之后提笔)

forward():向前移动

backward():向后移动

left(degree):逆时针旋转 degree 度

right(degree):顺时针旋转 degree 度

pendown():落笔

pencolor(color):笔墨颜色为 color

circle(r):画一个半径为 r 的圆

代码如下:

def draw_petal(turtle_obj, flower):

# 绘制掉落的花瓣

for i in range(int(flower / 2)):

# 有正有负就可以让画笔往二个方向走

x = flower - 2 * flower * random()

# 花瓣整体宽度(-10, 10)

y = 10 - 20 * random()

# 提笔,向前y,左转90,走x,落笔

turtle_obj.penup()

turtle_obj.forward(y)

turtle_obj.left(90)

turtle_obj.forward(x)

turtle_obj.pendown()

# 珊瑚色

turtle_obj.pencolor("lightcoral")

# 画圆

turtle_obj.circle(1)

# 回到起点

# 提笔,后退x,右转90,后退y,落笔

turtle_obj.penup()

turtle_obj.backward(x)

turtle_obj.right(90)

turtle_obj.backward(y)

turtle_obj.pendown()

(三)绘制树枝与花瓣

读者会发现,在 drwa_tree 方法中,又出现了两次 drwa_tree 方法,这是一个递归的方法,可以简单理解为一棵树最下面的树枝最少且最粗,越往上树枝数量增加但是变细了。Axitrader代理申请http://www.kaifx.cn/broker/ax...,如果读者看不懂如下代码的话,可以查看《Turtle(python)画分形树理解递归》[3]文章。

def draw_tree(turtle_obj, branch, tree_color):

# 设置一个最小分支长度

min_branch = 4

if branch > min_branch:

if branch < 8:

# 以0.5的概率,向左、右分支

if randint(0, 1) == 0:

# 左为白色

turtle_obj.pencolor("snow")

else:

# 右为珊瑚色

turtle_obj.pencolor("lightcoral")

# 枝干

turtle_obj.pensize(branch / 2)

elif 8 <= branch <= 16:

# 以0.33的概率,分为左、中、右分支

if randint(0, 2) == 0:

# 左为白色

turtle_obj.pencolor("snow")

else:

# 中、右为珊瑚色

turtle_obj.pencolor("lightcoral")

# 树枝

turtle_obj.pensize(branch / 4)

else:

# 褐色

turtle_obj.pencolor(tree_color)

# 细枝

turtle_obj.pensize(branch / 10)

# 最开始的树干长度

turtle_obj.forward(branch)

# 随机度数因子

a = 1.5 * random()

# 顺时针旋转随机角度(0~30度)

turtle_obj.right(20 * a)

# 随机长度因子

b = 1.5 * random()

# 往右画,直到画不动为止

draw_tree(turtle_obj, branch - 10 * b, tree_color)

# 左转随机角度

turtle_obj.left(40 * a)

# 往左画,直到画不动位置

draw_tree(turtle_obj, branch - 10 * b, tree_color)

# 右转一定角度

turtle_obj.right(20 * a)

# 提笔

turtle_obj.penup()

# 递归结束回到起点

turtle_obj.backward(branch)

turtle_obj.pendown()

(四)绘制多棵树

这部分代码的前半部分是用来约束树根的位置的,为了使树可以在图像中显示地较为完成,较大的树根应该更靠近于画幕底端,且不能太靠近两边,其余部分代码就很容易理解了。

def trees(tree_num):

# 颜色

color = ["brown", "tan", "black"]

for j in range(tree_num):

# 树干颜色

tree_color = color[randint(0, len(color) - 1)]

# 画笔大小

pensize = randint(2, 5)

# 前进像素

forward = ((-1) ** pensize) * pensize * randint(20, 50)

# 后退像素

if pensize <= 3:

backward = ((-1) ** pensize) * (5 - pensize) * randint(10, 15)

else:

backward = pensize * randint(45, 50)

# 创建画笔

turtle_obj = turtle.Turtle()

# 画笔粗细

turtle_obj.pensize(pensize)

# 提笔,向前forward,左转90,backward,落笔

turtle_obj.penup()

turtle_obj.forward(forward)

turtle_obj.left(90)

turtle_obj.backward(backward)

turtle_obj.pendown()

# 画笔颜色:褐色

turtle_obj.pencolor(tree_color)

# 枝干粗细

branch = pensize * 15

# 落花数

flowers = branch

# 第j棵树

draw_tree(turtle_obj, branch, tree_color)

# 花瓣

draw_petal(turtle_obj, flowers)

二、完整代码

(一)完整代码

给出完整代码:

import turtle

from random import random

from random import randint

def draw_petal(turtle_obj, flower):

# 绘制掉落的花瓣

for i in range(int(flower)):

# 有正有负就可以让画笔往二个方向走

x = flower - 4 * flower * random()

# 花瓣整体宽度(-10, 10)

y = 10 - 20 * random()

# 提笔,向前y,左转90,走x,落笔

turtle_obj.penup()

turtle_obj.forward(y)

turtle_obj.left(90)

turtle_obj.forward(x)

turtle_obj.pendown()

# 珊瑚色

turtle_obj.pencolor("lightcoral")

# 画圆

turtle_obj.circle(1)

# 回到起点

# 提笔,后退x,右转90,后退y,落笔

turtle_obj.penup()

turtle_obj.backward(x)

turtle_obj.right(90)

turtle_obj.backward(y)

turtle_obj.pendown()

# 画树枝部分

def draw_tree(turtle_obj, branch, tree_color):

# 设置一个最小分支长度

min_branch = 4

if branch > min_branch:

if branch < 8:

# 以0.5的概率,向左、右分支

if randint(0, 1) == 0:

# 左为白色

turtle_obj.pencolor("snow")

else:

# 右为珊瑚色

turtle_obj.pencolor("lightcoral")

# 枝干

turtle_obj.pensize(branch / 2)

elif 8 <= branch <= 16:

# 以0.33的概率,分为左、中、右分支

if randint(0, 2) == 0:

# 左为白色

turtle_obj.pencolor("snow")

else:

# 中、右为珊瑚色

turtle_obj.pencolor("lightcoral")

# 树枝

turtle_obj.pensize(branch / 4)

else:

# 褐色

turtle_obj.pencolor(tree_color)

# 细枝

turtle_obj.pensize(branch / 10)

# 最开始的树干长度

turtle_obj.forward(branch)

# 随机度数因子

a = 1.5 * random()

# 顺时针旋转随机角度(0~30度)

turtle_obj.right(20 * a)

# 随机长度因子

b = 1.5 * random()

# 往右画,直到画不动为止

draw_tree(turtle_obj, branch - 10 * b, tree_color)

# 左转随机角度

turtle_obj.left(40 * a)

# 往左画,直到画不动位置

draw_tree(turtle_obj, branch - 10 * b, tree_color)

# 右转一定角度

turtle_obj.right(20 * a)

# 提笔

turtle_obj.penup()

# 递归结束回到起点

turtle_obj.backward(branch)

turtle_obj.pendown()

def get_screen(width, height, color, speed):

# 创建画幕

screen_obj = turtle.Screen()

# 画布大小:(width, height),颜色:color

screen_obj.screensize(width, height, bg=color)

screen_obj.setup(1.0, 1.0)

# speed倍加速

screen_obj.tracer(speed)

return screen_obj

def trees(tree_num):

# 颜色

color = ["brown", "tan", "black"]

for j in range(tree_num):

# 树干颜色

tree_color = color[randint(0, len(color) - 1)]

# 画笔大小

pensize = randint(2, 5)

# 前进像素

forward = ((-1) ** pensize) * pensize * randint(20, 50)

# 后退像素

if pensize <= 3:

backward = ((-1) ** pensize) * (5 - pensize) * randint(10, 15)

else:

backward = pensize * randint(45, 50)

# 创建画笔

turtle_obj = turtle.Turtle()

# 画笔粗细

turtle_obj.pensize(pensize)

# 提笔,向前forward,左转90,backward,落笔

turtle_obj.penup()

turtle_obj.forward(forward)

turtle_obj.left(90)

turtle_obj.backward(backward)

turtle_obj.pendown()

# 画笔颜色:褐色

turtle_obj.pencolor(tree_color)

# 枝干粗细

branch = pensize * 15

# 落花数

flowers = branch

# 第j棵树

draw_tree(turtle_obj, branch, tree_color)

# 花瓣

draw_petal(turtle_obj, flowers)

if __name__ == "__main__":

# 创建画幕

my_screen_width = 800

my_screen_height = 600

my_screen_color = "wheat"

my_screen_speed = 5

my_screen_obj = get_screen(my_screen_width, my_screen_height,

my_screen_color, my_screen_speed)

# 樱花树

# 棵数

my_tree_num = 5

trees(my_tree_num)

# 点击关闭画布

my_screen_obj.exitonclick()

python代码画樱花落花-Python:绘制樱花树相关推荐

  1. python代码画樱花教程-python画樱花树代码 具体代码介绍

    1.python画樱花树代码为: import turtle as T import random import time 2.# 画樱花的躯干(60,t) def Tree(branch, t): ...

  2. python代码画樱花落花-表白小程序:python代码#8211;樱花树(Turtle库)

    import turtle from random import random from random import randint def draw_petal(turtle_obj, flower ...

  3. python代码画樱花主要特色,手机python代码画樱花

    如何通过代码敲出樱花开放? 通过代码敲出樱花开放可以用Matlab或者C语言进行,主要是编写相关程序. 作为具有地标意义的武大樱花,虽然在今年疫情防控期间暂停对外开放,但坐在家中的你,照样可以欣赏到樱 ...

  4. python代码画樱花带图片_用python画一颗樱花树(不同品种) 实现代码:

    原博文 2019-12-31 14:56 − 动态生成樱花效果图(这个是动态的): 实现代码: 1 import turtle as T 2 import random 3 import time 4 ...

  5. python代码画樱花-python画樱花树代码 具体代码介绍

    1.python画樱花树代码为: import turtle as T import random import time 2.# 画樱花的躯干(60,t) def Tree(branch, t): ...

  6. python代码画樱花-你用代码写作业,他用Python让樱花绽放,美哭了!

    在中国冠状病毒已然开始退却,但是周边邻邦与地区并不轻松,大洋彼岸欧美国家的病情开始漫延,Sars2-Covid-9出现变种,疫情此消彼涨,人们在焦虑中不断平静,因为人们终将胜利,世界终将复归美好. 不 ...

  7. python代码画樱花-Python:绘制樱花树

    代码详解 (一)绘制画幕 首先绘制画幕,命令说明如下: screensize(width, height, bg=color):设置画幕大小及颜色 setup(p1, p2):设置画幕大小,当 p1. ...

  8. python代码画樱花带图片_python编程——pygame画樱花树

    先来看看效果: 是不是很好看呢?现在我们来编程吧. import pygame,random#首先导入pygame.random模块 pygame.init() screen = pygame.dis ...

  9. python代码画樱花-如何用Python代码实现樱花树效果

    from turtle import from random import from math import * def tree(n,l): pd()#下笔 #阴影效果 t = cos(radian ...

最新文章

  1. 硬盘显示容量和实际容量不符合_为啥我买的64G U盘实际只有57G?聊聊存储市场的“不足量”现象...
  2. 添加lombok插件
  3. 15道谷歌面试题及答案
  4. 常考数据结构与算法:设计getMin功能的栈
  5. 关于Strut2内置Json插件的使用
  6. CV之detectron2:detectron2安装过程记录
  7. 设定printf在终端输出的颜色
  8. shell 多行注释
  9. oracle与sqlserver差异,Oracle与SQLServer的SQL语法差异总结
  10. python检验阿姆斯特朗数_python 之九九乘法表,润年,奇偶数,阿姆斯特朗数判断分享...
  11. 泛型算法(二十三)之排列算法
  12. ​【文末有福利】《信条》中的物理学-时间机器存在吗?
  13. 怎样在fastboot 里面加入新的命令
  14. ruby宝石区块链最新消息_Ruby宝石| Ruby工具
  15. 如何解决分布式系统数据事务一致性问题(HBase加Solr)
  16. MySQL-快速入门(1)基本数据库、表操作语句
  17. 高分辨率:遥感卫星影像
  18. 开发转测试,需要哪些必备测试技能?
  19. C语言+EasyX库实现--绘制彩虹
  20. QQ2009SP5和SP6后台会疯狂的访问qqlogo.qq.com:80

热门文章

  1. Error: [$injector:unpr] Unknown provider: $scopeProvider - $scope -错误解决方案
  2. 汉字转拼音 - 输入汉字获取其拼音
  3. 数字功放-耐福NTP功放芯片详细性能概述
  4. HFSS构建天线对称阵子
  5. ACM-ICPC 知识点 经验
  6. 不等距双杆模型_对磁场中双杆模型问题的解析(精)
  7. 每个互联网人才都应该知道的SQL注入
  8. 大数据思维导图锦集(原创吐血整理,不定期更新)
  9. 【计算机网络】4-41假定网络中的路由器B的路由表有如下的项目(这三列分别表示“目的网络”、“距离”和“下一跳路由器”):
  10. HDU 2015 偶数求和