Python+Turtle实现绘制勾股树
作者:Leleprogrammer 发布时间:2023-03-04 21:38:36
标签:Python,Turtle,勾股树
这次,我们用Turtle模块结合三角函数,绘制出这样的勾股树:
首先,导入模块
from turtle import *
from math import sin,cos,radians
定义勾股数每次旋转的度数
angle1=70
angle2=90-angle1
定义tree函数,绘制正方形并记录要生成的新的正方形的坐标,计算出新的正方形的度数和边长并绘制,这里采用递归的方式
ln表示边长,mode表示当前正方形是在前一个正方形的左边或右边,h表示朝向,p表示坐标
def tree(ln,mode="left",h=90,p=(0,0)):
pu()
seth(h)
goto(p)
if ln>1:
pd()
for i in range(4):
if i==1 and mode=="left":
pos1=pos()
if i==2 and mode=="left":
pos2=pos()
if i==2 and mode=="right":
pos1=pos()
if i==3 and mode=="right":
pos2=pos()
fd(ln)
right(90)
h=heading()
tree(ln*cos(radians(angle1)),"left",h+angle1 if mode=="left" else h-angle1,pos1)
tree(ln*cos(radians(angle2)),"right",h+90-angle2 if mode=="left" else h-angle2,pos2)
在主程序中设置速度,因为递归很占内存,所以绘制速度会卡顿减缓,所以这里加速1000倍,设置无延迟,笔触颜色为绿色,笔触大小2,抬笔,设置方向,并开始递归,最后隐藏画布并保持窗口显示
speed(0)
tracer(1000)
delay(0)
color("green")
pensize(2)
pu()
seth(90)
tree(70,p=(-100,-300))
ht()
done()
最终代码:
from turtle import *
from math import sin,cos,radians
angle1=45 # 自行修改
angle2=90-angle1
def tree(ln,mode="left",h=90,p=(0,0)):
pu()
seth(h)
goto(p)
if ln>1:
pd()
for i in range(4):
if i==1 and mode=="left":
pos1=pos()
if i==2 and mode=="left":
pos2=pos()
if i==2 and mode=="right":
pos1=pos()
if i==3 and mode=="right":
pos2=pos()
fd(ln)
right(90)
h=heading()
tree(ln*cos(radians(angle1)),"left",h+angle1 if mode=="left" else h-angle1,pos1)
tree(ln*cos(radians(angle2)),"right",h+90-angle2 if mode=="left" else h-angle2,pos2)
speed(0)
tracer(1000)
delay(0)
color("green")
pensize(2)
pu()
seth(90)
tree(70,p=(-100,-300))
ht()
done()
来源:https://blog.csdn.net/leleprogrammer/article/details/125948998
0
投稿
猜你喜欢
- 我就废话不多说了,大家还是直接看代码吧!def iou(y_true, y_pred, label: int): "&
- # 判断三角形类型def triangle(a,b,c): if a>0 and b>0 and c>0: &
- 前言最近找几个老友准备聊天发现几个已经被删除好友名单,做为潜水党多年的我已经不知道成为多少人的黑名单,但是好友列表却依然有不是好友的名单,面
- 函数input()的工作原理函数input()让程序暂停运行,等待用户输入一些文本。获取用户输入后,Python将其存储在一个变量中,以方便
- 主要代码如下: total = application("All
- 不同数据库之间若不能导入导出,那么将是一件可怕的事情,所幸的是一般情况下通过不同的方法和途径,都可以实现,方法有多种,本人提供其中的一个,提
- 先看代码m = nn.Identity(54, unused_argument1=0.1, unused_argument2=False)i
- # set 不支持索引和切片,是一个无需的不重复得到容器# 类似于字典,但是只有key 没有value# 创建集合dic1={}set1={
- 本文实例讲述了Python在字典中将键映射到多个值上的方法。分享给大家供大家参考,具体如下:问题:一个能将键(key)映射到多个值的字典(即
- 本文实例讲述了Python实现获取前100组勾股数的方法。分享给大家供大家参考,具体如下:本来想采用穷举试探的方式来做这个算法,后来发现还是
- 在实际处理数据时,因系统内存有限,我们不可能一次把所有数据都导出进行操作,所以需要批量导出依次操作。为了加快运行,我们会采用多线程的方法进行
- 本文实例为大家分享了python实现矩阵打印的具体代码,供大家参考,具体内容如下之前面试嵌入式软件的一道题,用c实现矩阵打印,考场上并没有写
- Application对象 Application对象是个应用程序级的对象,用来在所有用户间共享信息,并可以在Web应用程序运行期间持久地保
- 在实际工作中,无论是对数据库系统(DBMS),还是对数据库应用系统(DBAS),查询优化一直是一个热门话题。一个成功的数据库应用系统的开发,
- 本文实例讲述了PHP实现将MySQL重复ID二维数组重组为三维数组的方法。分享给大家供大家参考,具体如下:应用场景MYSQL在使用关联查询时
- Python命令行假设你已经安装好了Python, 那么在Linux命令行输入:$python将直接进入python。然后在命令行提示符&g
- 本周的豆知识分享就来深入研究一下window.event对象。请先看看下边的代码片断。 <button id=”btn”&g
- 本文实例为大家分享了Python函数式编程实现登录注册功能的具体代码,供大家参考,具体内容如下代码:def login(username,
- 1、线程池模块引入from concurrent.futures import ThreadPoolExecutor2、使用线程池一个简单的
- 1.建立设计规范的意义 建立设计文档的根本目的