Python turtle---海龟绘图

Python turtle---海龟绘图:

  • 概述:
  • 可用的 Turtle 和 Screen 方法概览:
    • Turtle方法:
      • 海龟动作:
        • 移动和绘制:
        • 获取海龟的状态:
        • 设置与度量单位:
      • 画笔控制:
        • 绘图状态:
        • 颜色控制:
        • 填充:
        • 更多绘图控制:
      • 海龟状态:
        • 可见性:
        • 外观:
      • 使用事件:
      • 特殊海龟方法:
    • Screen方法:
      • 窗口控制:
      • 动画控制:
      • 使用屏幕事件:
      • 设置与特殊方法:
      • 输入方法:
      • Screen专有方法:

概述:

海龟绘图很适合用来引导孩子学习编程。 最初来自于 Wally Feurzeig, Seymour Papert 和 Cynthia Solomon 于 1967 年所创造的 Logo 编程语言。
请想象绘图区有一只机器海龟,起始位置在 x-y 平面的 (0, 0) 点。先执行 import turtle,再执行 turtle.forward(15),它将(在屏幕上)朝所面对的 x 轴正方向前进 15 像素,随着它的移动画出一条线段。再执行 turtle.right(25),它将原地右转 25 度。
中文文档

可用的 Turtle 和 Screen 方法概览:

Turtle方法:

海龟动作:

移动和绘制:

方法 参数 说明
turtle.forward(distance)
turtle.fd(distance)
distance:一个数值 (整型或浮点型) 前进:海龟前进 distance 指定的距离,方向为海龟的朝向。
turtle.backward(distance)
turtle.back(distance)
turtle.bk(distaance)
distance:一个数值 (整型或浮点型) 后退:海龟前进 distance 指定的距离,方向为海龟的朝向。
turtle.right(angle)
turtle.rt(angle)
angle:一个数值 (整型或浮点型) 右转:海龟右转 angle 个单位。(单位默认为角度,但可通过 degrees() 和 radians() 函数改变设置。) 角度的正负由海龟模式确定。
turtle.left(angle)
turtle.lt(angle)
angle:一个数值 (整型或浮点型) 左转:海龟左转 angle 个单位。(单位默认为角度,但可通过 degrees() 和 radians() 函数改变设置。) 角度的正负由海龟模式确定。
turtle.goto(x, y=None)
turtle.setpos(x,y=None)
turtle.setposition(x,y=None)
x:一个数值或数值对/向量
y:一个数值或None
前往定位:如果 y 为 None,x 应为一个表示坐标的数值对或 Vec2D 类对象 (例如 pos() 返回的对象).海龟移动到一个绝对坐标。如果画笔已落下将会画线。不改变海龟的朝向。
turtle.setx(x) x:一个数值 (整型或浮点型) 设置x坐标:设置海龟的横坐标为 x,纵坐标保持不变。
turtle.sety(y) y:一个数值 (整型或浮点型) 设置y坐标:设置海龟的纵坐标为 y,横坐标保持不变。
turtle.setheading(to_angle)
turtle.seth(to_angle)
to_angle:一个数值 (整型或浮点型) 设置朝向:设置海龟的朝向为 to_angle
标准模式:0-东,90-北,180-西,270-南
logo模式:0-北,90-东,180-南,270-西
turtle.home() 返回原点:海龟移至初始坐标 (0,0),并设置朝向为初始方向 。
turtle.circle(randius, extent=None, steps=None) randius:半径
extent:夹角
steps:边的数量
画圆:绘制一个 radius 指定半径的圆。圆心在海龟左边 radius 个单位;extent 为一个夹角,用来决定绘制圆的一部分。如未指定 extent*则绘制整个圆。如果 *extent 不是完整圆周,则以当前画笔位置为一个端点绘制圆弧。如果 radius 为正值则朝逆时针方向绘制圆弧,否则朝顺时针方向。最终海龟的朝向会依据 extent 的值而改变。
turtle.dot(size=None,*color) size:一个整型数 >= 1 (如果指定)
color:一个颜色字符串或颜色数值元组
画点:绘制一个直径为 size,颜色为 color 的圆点。如果 size 未指定,则直径取 pensize+4 和 2*pensize 中的较大值。
turtle.stamp() 印章:在海龟当前位置印制一个海龟形状。返回该印章的 stamp_id,印章可以通过调用 clearstamp(stamp_id) 来删除。
turtle.clearstamp(stampid) stampid :一个整型数,必须是之前 stamp() 调用的返回值 清除印章:删除 stampid 指定的印章。
turtle.clearstamps(n=None) n:一个整型数 (或 None) 清除多个印章:删除全部或前/后 n 个海龟印章。如果 n 为 None 则删除全部印章,如果 n > 0 则删除前 n 个印章,否则如果 n < 0 则删除后 n 个印章。
turtle.undo() 撤销:撤消 (或连续撤消) 最近的一个 (或多个) 海龟动作。可撤消的次数由撤消缓冲区的大小决定。
turtle.speed(speed=None) speed:一个 0…10 范围内的整型数或速度字符串
"fastest":0最快
"fast":10快
"normal":6正常
"slow":3慢
"slowest":1最慢
速度:设置海龟移动的速度为 0…10 表示的整型数值。如未指定参数则返回当前速度。

获取海龟的状态:

方法 参数 说明
turtle.position()
turtle.pos()
位置:返回海龟当前的坐标 (x,y) (为 Vec2D 矢量类对象)。
turtle.towards(x,y=None) x:一个数值或数值对/矢量,或一个海龟实例
y:一个数值——如果 x 是一个数值,否则为 None
目标方向:返回从海龟位置到由 (x,y)、矢量或另一海龟所确定位置的连线的夹角。 此数值依赖于海龟的初始朝向,这又取决于 “standard”/“world” 或 “logo” 模式设置。
turtle.xcor() 返回海龟的x坐标
turtle.ycor() 返回海龟的y坐标
turtle.heading() 返回海龟当前的朝向
turtle.distance(x, y=None) x:一个数值或数值对/矢量,或一个海龟实例。
y:一个数值——如果 x 是一个数值,否则为 None
距离:返回从海龟位置到由 (x,y),适量或另一海龟对应位置的单位距离。

设置与度量单位:

方法 参数 说明
turtle.degrees(fullcircle=360.0) fullcircle:一个数值 角度:设置角度的度量单位,即设置一个圆周为多少 “度”。默认值为 360 度。
turtle.radians() 弧度:设置角度的度量单位为弧度。其值等于 degrees(2*math.pi)。

画笔控制:

绘图状态:

方法 参数 说明
turtle.pendown()
turtle.down()
turtle.pd()
画笔落下
turtle.pendup()
turtle.up()
turtle.pu()
画笔抬起
turtle.pensize(width=None)
turtle.width(width=None)
width:一个数值 画笔粗细:设置线条的粗细为 width 或返回该值。如果 resizemode 设为 “auto” 并且 turtleshape 为多边形,该多边形也以同样组细的线条绘制。如未指定参数,则返回当前的 pensize。
turtle.pen(pen=None, **pendict) pen:一个包含部分或全部下列键的字典
pendict:一个或多个以下列键为关键字的关键字参数
画笔
turtle.isdown() 画笔是否落下:如果画笔落下返回 True,如果画笔抬起返回 False。

颜色控制:

方法 参数 说明
turtle.color(*args) color():返回以一对颜色描述字符串或元组表示的当前画笔颜色和填充颜色,两者可分别由 pencolor() 和 fillcolor() 返回。
color(colorstring), color((r,g,b)), color(r,g,b)输入格式与 pencolor() 相同,同时设置填充颜色和画笔颜色为指定的值。
color(colorstring1, colorstring2), color((r1,g1,b1), (r2,g2,b2))相当于 pencolor(colorstring1) 加 fillcolor(colorstring2),使用其他输入格式的方法也与之类似。
返回或设置画笔颜色和填充颜色
turtle.pencolor(*args) 允许以下四种输入格式:
pencolor()
pencolor(colorstring)
pencolor((r, g, b))
pencolor(r, g, b)
返回或设置画笔颜色。
turtle.fillcolor(*args) 允许以下四种输入格式:
fillcolor()
fillcolor(colorstring)
fillcolor((r, g, b))
fillcolor(r, g, b)
返回或设置填充颜色

填充:

方法 参数 说明
turtle.filling() 返回填充状态 (填充为 True,否则为 False)。
turtle.begin_fill() 开始填充:在绘制要填充的形状之前调用。
turtle.end_fill() 结束填充:填充上次调用 begin_fill() 之后绘制的形状

更多绘图控制:

方法 参数 说明
turtle.reset() 重置 :从屏幕中删除海龟的绘图,海龟回到原点并设置所有变量为默认值。
turtle.clear() 清空 :从屏幕中删除指定海龟的绘图。不移动海龟。海龟的状态和位置以及其他海龟的绘图不受影响。
turtle.write(arg, move=False, align=“left”, font=(“Arial”, 8, “normal”)) arg – 要书写到 TurtleScreen 的对象
move – True/False
align – 字符串 “left”, “center” 或 "right"
font – 一个三元组 (fontname, fontsize, fonttype)
书写 :基于 align (“left”, “center” 或 “right”) 并使用给定的字体将文本 —— arg 的字符串表示形式 —— 写到当前海龟位置。 如果 move 为真值,画笔会移至文本的右下角。 默认情况下 move 为 False。

海龟状态:

可见性:

方法 参数 说明
turtle.showturtle() st() 显示海龟
turtle.hideturtle() ht() 隐藏海龟:使海龟不可见。当你绘制复杂图形时这是个好主意,因为隐藏海龟可显著加快绘制速度。
turtle.isvisible() 海龟是否可见:如果海龟显示返回 True,如果海龟隐藏返回 False。

外观:

方法 参数 说明
turtle.shape(name=None) name:一个有效的形状名字符串
"arrow",“turtle”,“circle”,“square”,“triangle”,“classic”
形状
turtle.resizemode(rmode=None) rmode:字符串 “auto”, “user”, “noresize” 其中之一 大小调整模式:设置大小调整模式为以下值之一: “auto”, “user”, “noresize”。如未指定 rmode 则返回当前的大小调整模式。
turtle.shapesize(stretch_wid=None, stretch_len=None, outline=None)
turtle.turtlesize(stretch_wid=None, stretch_len=None, outline=None)
stretch_wid – 正数值
stretch_len – 正数值
outline – 正数值
形状大小:返回或设置画笔的属性 x/y-拉伸因子和/或轮廓。
turtle.shearfactor(shear=None) shear – 数值 (可选) 剪切因子:设置或返回当前的剪切因子。
turtle.settiltangle(angle) angle – 一个数值 设置倾角:旋转海龟形状使其指向 angle 指定的方向,忽略其当前的倾角,不 改变海龟的朝向 (移动方向)。
turtle.tiltangle(angle=None) angle – 一个数值 (可选) 倾角:设置或返回当前的倾角。如果指定 angle 则旋转海龟形状使其指向 angle 指定的方向,忽略其当前的倾角。不 改变海龟的朝向 (移动方向)。如果未指定 angle: 返回当前的倾角,即海龟形状的方向和海龟朝向 (移动方向) 之间的夹角。
turtle.tilt(angle) angle – 一个数值 倾斜:海龟形状自其当前的倾角转动 angle 指定的角度,但 不 改变海龟的朝向 (移动方向)。
turtle.shapetransform(t11=None, t12=None, t21=None, t22=None) t11,t12,t21,t22一个数值(可选) 变形:设置或返回海龟形状的当前变形矩阵。
turtle.get_shapepoly() 获取形状多边形:返回以坐标值对元组表示的当前形状多边形。这可以用于定义一个新形状或一个复合形状的多个组成部分。

使用事件:

方法 参数 说明
turtle.onclick(fun, btn=1, add=None) fun – 一个函数,调用时将传入两个参数表示在画布上点击的坐标
btn – 鼠标按钮编号,默认值为 1 (鼠标左键)
add – True 或 False – 如为 True 则将添加一个新绑定,否则将取代先前的绑定
鼠标单击
turtle.onrelease(fun, btn=1, add=None) fun – 一个函数,调用时将传入两个参数表示在画布上点击的坐标。
btn – 鼠标按钮编号,默认值为 1 (鼠标左键)
add – True 或 False – 如为 True 则将添加一个新绑定,否则将取代先前的绑定
鼠标释放
turtle.ondrag(fun, btn=1, add=None) fun – 一个函数,调用时将传入两个参数表示在画布上点击的坐标。
btn – 鼠标按钮编号,默认值为 1 (鼠标左键)
add – True 或 False – 如为 True 则将添加一个新绑定,否则将取代先前的绑定
鼠标拖动

特殊海龟方法:

方法 参数 说明
turtle.begin_poly() 开始记录多边形 :开始记录多边形的顶点。当前海龟位置为多边形的第一个顶点。
turtle.end_poly() 停止记录多边形:停止记录多边形的顶点。当前海龟位置为多边形的最后一个顶点。它将连线到第一个顶点。
turtle.get_poly() 获取多边形:返回最新记录的多边形。
turtle.clone() 克隆:创建并返回海龟的克隆体,具有相同的位置、朝向和海龟属性。
turtle.getturtle()
turtle. getpen()
返回海龟对象自身。
turtle.getscreen() 获取屏幕
turtle.setundobuffer(size) size – 一个整型数值或 None 设置撤销缓冲区
turtle.undobufferentries() 撤销缓冲区条目数

Screen方法:

窗口控制:

方法 参数 说明
screen.bgcolor(*args) args – 一个颜色字符串或三个取值范围 0…colormode 内的数值或一个取值范围相同的数值3元组设置或返回 TurtleScreen 的背景颜色。
“orange”,"#800080"
背景颜色
screen.bgpic(picname=None) picname – 一个字符串, gif-文件名, “nopic”, 或 None 背景图片:设置背景图片或返回当前背景图片名称。如果 picname 为一个文件名,则将相应图片设为背景。如果 picname 为 “nopic”,则删除当前背景图片。如果 picname 为 None,则返回当前背景图片文件名。
screen.clear()
screen.clearscreen()
清屏:从中删除所有海龟的全部绘图。将已清空的 TurtleScreen 重置为初始状态: 白色背景,无背景片,无事件绑定并启用追踪。
screen.reset()
screen. resetscreen()
重置:重置屏幕上的所有海龟为其初始状态。
screen.screensize(canvwidth=None, canvheight=None, bg=None) canvwidth – 正整型数,以像素表示画布的新宽度值
canvheight – 正整型数,以像素表示画面的新高度值
bg – 颜色字符串或颜色元组,新的背景颜色
屏幕大小
screen.setworldcoordinates(llx, lly, urx, ury) llx – 一个数值, 画布左下角的 x-坐标
lly – 一个数值, 画布左下角的 y-坐标
urx – 一个数值, 画面右上角的 x-坐标
ury – 一个数值, 画布右上角的 y-坐标
设置世界坐标系:设置用户自定义坐标系并在必要时切换模式为 “world”。这会执行一次 screen.reset()。如果 “world” 模式已激活,则所有图形将根据新的坐标系重绘。

动画控制:

方法 参数 说明
screen.delay(delay=None) delay – 正整型数 延时 :设置或返回以毫秒数表示的延迟值 delay。
(这约等于连续两次画布刷新的间隔时间。)
绘图延迟越长,动画速度越慢。
screen.tracer(n=None, delay=None) n – 非负整型数
delay – 非负整型数
追踪:启用/禁用海龟动画并设置刷新图形的延迟时间。
如果指定 n 值,则只有每第 n 次屏幕刷新会实际执行。
(可被用来加速复杂图形的绘制。)
如果调用时不带参数,则返回当前保存的 n 值。
第二个参数设置延迟值 (参见 delay())。
screen.update() 更新:执行一次 TurtleScreen 刷新。在禁用追踪时使用。

使用屏幕事件:

方法 参数 说明
screen.listen(xdummy=None, ydummy=None) 监听:设置焦点到 TurtleScreen (以便接收按键事件)。使用两个 Dummy 参数以便能够传递 listen() 给 onclick 方法。
screen.onkey(fun, key)
screen.onkeyrelease(fun, key)
fun – 一个无参数的函数或 None
key – 一个字符串: 键 (例如 “a”) 或键标 (例如 “space”)
当键盘按下并释放
screen.onkeypress(fun, key=None) fun – 一个无参数的函数或 None
key – 一个字符串: 键 (例如 “a”) 或键标 (例如 “space”)
当键盘按下:绑定 fun 指定的函数到指定键的按下事件。
screen.onclick(fun, btn=1, add=None)
screen.onscreenclick(fun, btn=1, add=None)
fun – 一个函数,调用时将传入两个参数表示在画布上点击的坐标。
btn – 鼠标按钮编号,默认值为 1 (鼠标左键)
add – True 或 False – 如为 True 则将添加一个新绑定,否则将取代先前的绑定
当点击屏幕:绑定 fun 指定的函数到鼠标点击屏幕事件。如果 fun 值为 None,则移除现有的绑定。
screen.ontimer(fun, t=0) fun – 一个无参数的函数
t – 一个数值 >= 0
当达到定时:安装一个计时器,在 t 毫秒后调用 fun 函数。
screen.mainloop()
screen. done()
主循环:开始事件循环 - 调用 Tkinter 的 mainloop 函数。必须作为一个海龟绘图程序的结束语句。如果一个脚本是在以 -n 模式 (无子进程) 启动的 IDLE 中运行时 不可 使用 - 用于实现海龟绘图的交互功能。

设置与特殊方法:

方法 参数 说明
screen.mode(mode=None) mode – 字符串 “standard”, “logo” 或 “world” 其中之一 模式:设置海龟模式 (“standard”, “logo” 或 “world”) 并执行重置。如未指定模式则返回当前的模式。
screen.colormode(cmode=None) cmode – 数值 1.0 或 255 其中之一 颜色模式:返回颜色模式或将其设为 1.0 或 255。构成颜色三元组的 r, g, b 数值必须在 0…cmode 范围之内。
screen.getcanvas() 获取画布:返回此 TurtleScreen 的 Canvas 对象。供了解 Tkinter 的 Canvas 对象内部机理的人士使用。
screen.getshapes() 获取形状:返回所有当前可用海龟形状的列表。
screen.register_shape(name, shape=None)
screen.addshape(name, shape=None)
1.name 为一个 gif 文件的文件名, shape 为 None: 安装相应的图像形状。
2.name 为指定的字符串,shape 为由坐标值对构成的元组: 安装相应的多边形形状。
3. name 为指定的字符串, 为一个 (复合) Shape 类对象: 安装相应的复合形状。
添加形状
screen.turtles() 所有海龟:返回屏幕上的海龟列表。
screen.window_height () 窗口高度:返回海龟窗口的高度。
screen.window_width() 窗口宽度:返回海龟窗口的宽度。

输入方法:

方法 参数 说明
screen.textinput(title, prompt) title – 字符串
prompt – 字符串
文本输入:弹出一个对话框窗口用来输入一个字符串。
screen.numinput(title, prompt, default=None, minval=None, maxval=None) title – 字符串
prompt – 字符串
default – 数值 (可选)
minval – 数值 (可选)
maxval – 数值 (可选)
数字输入:弹出一个对话框窗口用来输入一个数值。title 为对话框窗口的标题,prompt 为一条文本,通常用来描述要输入的数值信息。default: 默认值, minval: 可输入的最小值, maxval: 可输入的最大值。输入数值的必须在指定的 minval … maxval 范围之内,否则将给出一条提示,对话框保持打开等待修改。返回输入的数值。如果对话框被取消则返回 None。

Screen专有方法:

方法 参数 说明
screen.bye() 退出:关闭海龟绘图窗口。
screen.exitonclickk() 当点击时退出 :将 bye() 方法绑定到 Screen 上的鼠标点击事件。
screen.setup(width=_CFG[“width”], height=_CFG[“height”], startx=_CFG[“leftright”], starty=_CFG[“topbottom”]) width – 如为一个整型数值,表示大小为多少像素,如为一个浮点数值,则表示屏幕的占比;默认为屏幕的 50%
height – 如为一个整型数值,表示高度为多少像素,如为一个浮点数值,则表示屏幕的占比;默认为屏幕的 75%
startx – 如为正值,表示初始位置距离屏幕左边缘多少像素,负值表示距离右边缘,None 表示窗口水平居中
starty – 如为正值,表示初始位置距离屏幕上边缘多少像素,负值表示距离下边缘,None 表示窗口垂直居中
设置主窗口的大小和位置。
screen.title(titlestring) titlestring – 一个字符串,显示为海龟绘图窗口的标题栏文本 设置海龟窗口标题为 titlestring 指定的文本。

你可能感兴趣的:(Python)