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 指定的文本。 |