python之demo1----改编自turtle.py文件中的demo

时间:2022-02-10 22:01:14
"""
改编自turtle.py自带demo
执行 python -m turtledemo 命令查看系统内置demo的源码 绘制:需要通过import turtle引入绘制图形库turtle库 注意:1.全文中的 turtle.xxx()中的turtle本质是该海龟屏幕上默认的海龟实例对象,他等价于turtle.getturtle()返回的对象实例.即任何turtle.xxx()函数都可以写成turtle.getturtle.xxx()
2.屏幕正中心为(0,0)点
"""
import turtle
import time def demo1():
# 恢复默认位置和默认方向,保留当前海龟箭头图标(此时就是普通箭头)
turtle.reset()
turtle.tracer(True)
# 画笔抬起
turtle.pu()
# 画笔向后100像素
turtle.bk(100)
# 画笔放下
turtle.pd()
# 设置画笔线条粗细为3,同turtle.width(3)
turtle.pensize(3)
# 绘制3个正方形; 填充最后一个(i 从 0 - 2循环3次)
for i in range(3):
print("当前i=", i) if i == 2:
# 最后一个正方形开始填充
turtle.begin_fill() # 写字标识当前再画第几个正方形
turtle.write(i + 1, False, align="right") # 画正方形
draw_square(turtle.getturtle()) if i == 2:
# 绘制完正方形后将pencolor和fillcolor设置成褐红色
turtle.color("maroon")
# 最后一个正方形结束填充
turtle.end_fill() # 每次画完正方形画笔抬起,然后向前移动30像素再放下
turtle.pu()
turtle.fd(30)
turtle.pd() # 设置画笔线条粗细为1,同turtle.width(1)
turtle.pensize(1)
# 将pencolor和fillcolor设置成黑色
turtle.color("black") # move out of the way
turtle.tracer(False)
# 画笔抬起
turtle.pu()
# 右转90度此时方向向下
turtle.rt(90)
# 向前(即向下)移动100像素
turtle.fd(100)
# 右转90度此时方向向左
turtle.rt(90)
# 向前(即向左)移动100像素
turtle.fd(100)
# 右转180度此时方向向右
turtle.rt(180)
# 画笔放下
turtle.pd()
# 绘制一些文本
turtle.write("画楼梯", True)
turtle.write("start", True)
# 将pencolor和fillcolor设置成红色
turtle.color("red")
# 画5个楼梯(从0-4遍历),最后heading()为0.0表示方向向右
for i in range(5):
turtle.fd(20)
turtle.lt(90)
turtle.fd(20)
turtle.rt(90)
turtle.tracer(True)
# 绘制5个填充的楼梯
turtle.begin_fill()
for i in range(5):
turtle.fd(20)
turtle.lt(90)
turtle.fd(20)
turtle.rt(90)
# 完成填充,因为此时的fillcolor为red红色,所以以红色进行填充
turtle.end_fill()
# more text def switchpen(_turtle):
"""
间断效果
:param _turtle: 将被处理的turtle对象
"""
if _turtle.isdown():
_turtle.pu()
else:
_turtle.pd() def draw_square(_turtle):
"""
画边长20像素的正方形
:param _turtle: 将被处理的turtle对象
"""
# 方法1
"""
old = _turtle.heading()
_turtle.setheading(315)
_turtle.circle(15, None, 4)
_turtle.setheading(old)
"""
# 方法2
for _ in range(4):
_turtle.fd(20)
_turtle.lt(90) def demo2():
"""Demo of some new features."""
# 使用最慢速度 0最快,1-10逐渐加快
turtle.speed(1)
# 隐藏画笔(即海龟箭头),同 turtle.hideturtle()。此时只要画笔是按下状态,虽然隐藏了但是还是能绘制图形的
#turtle.ht()
# 显示画笔,同 turtle.showturtle()
#turtle.st()
# 设置画笔线条粗细为3,同turtle.width(3)
turtle.pensize(3)
# 设置海龟箭头当前方向角度(当前模式下海龟箭头当前位置指向(0,0)点的向量角度),turtle.towards(0, 0)其实是当前方向的反方向
turtle.setheading(turtle.towards(0, 0))
# 计算半径(海龟箭头当前位置到(0,0)位置距离的一半)
radius = turtle.distance(0, 0)/2.0
# 海龟箭头右转90度,即以海龟箭头当前位置到(0,0)为直径画
turtle.rt(90)
# 画18次角度为10度的小段圆弧,画笔每按下画一小段就再抬起移动一小段
for _ in range(18):
switchpen(turtle.getturtle())
turtle.circle(radius, 10)
turtle.write("wait a moment...") # 等待2秒
time.sleep(2) # 撤销所有
while turtle.undobufferentries():
turtle.undo()
# 清屏并将画笔位置和方向恢复到初始状态并保持画笔形状不变,即位置到原点(0, 0),因为模式是"standard"方向恢复向右,"standard"/"world"模式方向也恢复到默认的向右,"logo"模式方向恢复到默认的向上
turtle.reset()
# 海龟箭头左转90度
turtle.lt(90)
turtle.colormode(255)
# 定义等边三角形默认的边长
laenge = 10
turtle.pencolor("green")
# 设置画笔线条粗细为3, 同turtle.width(3)
turtle.pensize(3)
# 海龟箭头左转180度
turtle.lt(180)
# i为-2 到15 共遍历18次,之所以i有负数,是因为内循环中turtle.fillcolor(255-15*i, 0, 15*i)中的15*i不能超过255(即colormode的值)
for i in range(-2, 16):
print("当前i=", i)
# 后15次画的图形进行填充,每次填充色不同
if i > 0:
turtle.begin_fill()
turtle.fillcolor(255-15*i, 0, 15*i)
# 画等边三角形
for _ in range(3):
turtle.fd(laenge)
turtle.lt(120)
# 后15次画的图形填充完毕
if i > 0:
turtle.end_fill() # 每画完一个等边三角形,等边三角形的变成增加10像素,并且角度左转15度
laenge += 10
turtle.lt(15) # 达到 慢->快->慢->快 的效果 (速度值>10 则被置为0即最快速度)
turtle.speed((turtle.speed()+1) % 12) # 海龟箭头左转120度
turtle.lt(120)
# 画笔抬起
turtle.pu()
# 向前移动70像素
turtle.fd(70)
# 海龟箭头向右转30度
turtle.rt(30)
# 画笔放下
turtle.pd()
# pencolor设置成红色并且fillcolor设置成黄色
turtle.color("red", "yellow")
# 速度设置成最快
turtle.speed(0)
# 画图形并填充
turtle.begin_fill()
for _ in range(4):
# 绘制1/4圆
turtle.circle(50, 90)
# 右转90度
turtle.rt(90)
# 前移30像素
turtle.fd(30)
# 右转90度
turtle.rt(90)
# 图形填充完毕
turtle.end_fill()
# 海龟箭头左转90度
turtle.lt(90)
# 画笔抬起
turtle.pu()
# 向前移动30像素
turtle.fd(30)
# 画笔放下
turtle.pd()
# 海龟箭头图标设置成海龟
turtle.shape("turtle")
# 获取(默认的)第一个Turtle实例对象
tri = turtle.getturtle() # 下文中的 tri(默认的)第一个Turtle实例对象,可以将所有的tri替换成turtle,比如tri.lt(100) 可改成 turtle.lt(100)
# 设置tri的(海龟箭头和)画笔大小的缩放模式为auto,此模式下(海龟箭头和)画笔随 pensize变化而变化.
tri.resizemode("auto")
# 创建一个新的Turtle实例对象并返回该对象实例
turtle1 = turtle.Turtle()
# 设置turtle1的(海龟箭头和)画笔大小的缩放模式为auto,此模式下(海龟箭头和)画笔随 pensize变化而变化.
turtle1.resizemode("auto")
# turtle1的海龟箭头图标设置成海龟
turtle1.shape("turtle")
turtle1.reset()
turtle1.lt(90)
# turtle1设置画笔速度为0最大速度
turtle1.speed(0)
# turtle1的画笔抬起
turtle1.pu()
# turtle1的画笔移动到坐标点(280, 40)
turtle1.goto(280, 40)
# turtle1的左转30度
turtle1.lt(30)
# turtle1的画笔放下
turtle1.pd()
# turtle1设置画笔速度为6
turtle1.speed(6)
# turtle1的pencolor设置成蓝色并且fillcolor设置成橘黄色
turtle1.color("blue", "orange")
# 设置画笔线条粗细为2, 同turtle.width(2)
turtle1.pensize(2)
# tri设置画笔速度为6
tri.speed(6)
# tri方向指向turtle1当前位置
tri.setheading(tri.towards(turtle1))
count = 1
# 只要tri与turtle1之间距离>4像素进入循环
while tri.distance(turtle1) > 4:
turtle1.fd(3.5)
turtle1.lt(0.6)
tri.setheading(tri.towards(turtle1))
tri.fd(4)
if count % 20 == 0:
# 当前位置拷贝一份turtle1实例的当前海龟箭头图标
turtle1.stamp()
# 当前位置拷贝一份tri实例的当前海龟箭头图标
tri.stamp()
# tri间断效果
switchpen(tri)
# turtle1间断效果
#switchpen(turtle1)
count += 1
tri.write("CAUGHT! ", font=("Arial", 16, "bold"), align="right")
tri.pencolor("black")
tri.pencolor("red") # 等待2秒
time.sleep(2) # 此处的turtle.undobufferentries()等价于turtle.getturtle().undobufferentries()或tri.undobufferentries()表示只要第一个turtle实例可以撤销,就一直撤销,因为tri的操作数量相对于turtle1要多,为了两个对象都撤销完所以用了前者
while turtle.undobufferentries():
# tri对象撤销一步
tri.undo()
# turtle1对象撤销一步
turtle1.undo()
# tri对象向前移动50像素
tri.fd(50)
tri.write(" Click anywhere to exit!", font=("Courier", 12, "bold"))
# 获取海龟屏幕TurtleScreen对象实例
screen = turtle.getscreen()
# 注册点击事件,点击海龟屏幕TurtleScreen任何位置,触发close_window函数
screen.onclick(close_window) def close_window(x, y):
print("点击位置(", x, ",", y, ")")
# 获取当前海龟屏幕TurtleScreen的对象实例
screen = turtle.getscreen()
# 清屏
screen.clearscreen()
# 关闭窗口
screen.bye() def my_main():
demo1()
demo2()
# 保持屏幕,直到点击窗口右上角关闭按钮或调用turtle.bye()方法
turtle.mainloop() if __name__ == '__main__':
my_main()