文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python 的Tkinter包系列之三:Canvas(画布)

2023-10-24 22:55

关注

Python Tkinter包系列之三:Canvas(画布)

Tkinter 的Canvas(画布)控件具有两个功能,首先它可以用来绘制各种图形(图片),比如直线、弧形、椭圆形、多边形和矩形等,也可以在上面放置图片(graphics)、文本、小部件(widgets)或框架( frames)。

8. The Canvas widget (tkdocs.com)

绘制在画布控件上的图形,称之为“画布对象”。每一个画布对象都有一个“唯一身份ID”,这是 Tkinter 自动为其创建的,从而方便控制和操作这些画布对象。

画布坐标系:以画布的左上角作为坐标原点,右下角的坐标为距离x轴和Y轴的两个最大值。

要创建画布对象的构造函数【注:构造函数(constructor),是一种特殊的方法。主要用来在创建对象时初始化对象】语法:

tk.Canvas(parent, option=value, ...)

返回画布控件(widget:控件、组件、部件)。其中:

parent  -- 控件,表示将菜单将建立在哪一个父对象上。

**options -- 选项,下方详细列举了各个选项的具体含义和用法:

Option(选项)   描述

Bd   表示该边界的宽度,默认的宽度是 2,单位像素。

bg     它代表了画布的背景颜色。

confine  它被设置为使画布unscrollable以外的滚动区域。

cursor   在画布上设置光标为箭头、圆、点等。

height   它代表了画布在垂直方向上的大小。

Highlightcolor  设置当获得焦点时突出显示的颜色。

relief    表示边框的类型,可能的值包括SUNKEN、RAISED、GROOVE 、RIDGE。

scrollregion  表示为包含画布区域的坐标的元组。

width  设置画布的宽度,单位为像素。

xscrollincrement  如果它被设置为正值,画布只放置到该值的倍数。

xscrollcommand  如果画布是可滚动的,那么这个属性应该是水平滚动条的.set()方法。

yscrollincrement  像xscrollincrement一样工作,但是控制垂直移动。

yscrollcommand  如果画布是可滚动的,这个属性应该是垂直滚动条的.set()方法。

创建画布源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()

程序运行效果:

Canvas 还提供了如下方法来绘制各种图形。

create_line():绘制直线,语法格式:

create_line(x0, y0, x1, y1, ..., xn, yn, option, ...)

这条线穿过一系列点(x0,y0),(x1,y1),…(xn,yn)。Option(选项)包括:

下列是常用的options用法。

(1)arrow:默认是没有箭头,使用arrow=tk.FIRST在起始线末端有箭头,arrow=LAST在最后一条线末端有箭头,使用arrow=tk.BOTH在两端有箭头。

(2)arrowshape:使用元组(d1, d2, d3)代表箭头,默认是(8,10,3)。

(3)capstyle:这是线条终点的样式,默认是BUTT,也可以选择PROJECTING、ROUND。

(4)dash:建立虚线,使用元组储存数字数据,第一个数字是实线,第二个数字是空白,如此循环当所有元组数字用完又重新开始。例如,dash=(5,3)产生5像素实线,3像素空白,如此循环。再如,dash=(8,1,1,1)产生8像素实线和点的线条,dash=(5,)产生5像素实线5像素空白。

(5)dashoffset:与dash一样产生虚线,但是一开始数字是空白的宽度。

(6)fill:设置线条颜色。

(7)joinstyle:线条相交的设置,默认是ROUND,也可以选择BEVEL、MITER。

(8)stipple:绘制位图(Bitmap)线条。

(9)width:线条宽度。

使用create_line()方法的示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()# 绘制直线line1 = cv.create_line(14,65,66,65,fill="red")# 绘制折线line2 = cv.create_line(20,70,50,80,60,150,fill="green")# 显示主窗口win.mainloop()

程序运行效果:

create_arc方法绘制弧,语法格式:

create_arc(x0, y0, x1, y1, option, ...)

点(x0,y0)是椭圆所在矩形的左上角,(x1,y1)是右下角。如果这个矩形是正方形,你会得到一个圆。

下列是常用的options用法。

(1)dash:建立虚线,与create_line( )相同。

(2)dashoffset:与dash一样产生虚线,但是一开始数字是空白的宽度。

(3)extent:如果要绘制圆形extent值是359,如果写成360会视为0°。如果extent介于1~359,则是绘制这个角度的圆弧。

(4)fill:填充圆弧颜色。

(5)outline:设置圆弧线条颜色。

(6)start:圆弧起点位置。

(7)stipple:绘制位图圆弧。

(8)style:有三种格式——ARC表示绘制圆弧、CHORD表示绘制弦、PIESLICE表示绘制扇形。

(9)width:圆弧线条宽度。

使用create_arc方法的示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()# 绘制圆弧arc1 = cv.create_arc(20, 10, 110, 110, extent=90, style=ARC)# 绘制弦arc2 = cv.create_arc(210, 10, 310, 110, extent=180, style=CHORD)# 绘制扇形arc3 = cv.create_arc(50,50,160,160, extent=60, style=PIESLICE)# 绘制圆arc3 = cv.create_arc(100,100,260,260,extent=359, style=ARC)# 显示主窗口win.mainloop()

程序运行效果:

create_image方法在Canvas对象内插入图像文件,语法格式:

create_image(x, y, option, ...)

(x,y)是图像左上角的位置,常用的options(选项):

(1)anchor:位图是相对于点(x,y)定位的。默认值为anchor= CENTER,表示位图位于(x,y)位置的中心。锚定(anchor)常数如下图所示:

(2)image参数 image 定义图片的来源,必须是 tkinter 模块的 BitmapImage 类或 PhotoImage 类的实例变量。

下面使用create_ image方法的例子

请准备一张图片,名为TestUse.png,为方便将其和下面的示例源码文件放到同一文件夹中。

使用create_ image方法的示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()#加载图片显示img = PhotoImage(file="TestUse.png")C_I =cv.create_image(200,150,anchor=CENTER,image= img)# 显示主窗口win.mainloop()

程序运行效果:

create_bitmap方法在Canvas对象内插入位图文件,语法格式:

create_bitmap (x, y, option, ...)

(x,y)是图像左上角的位置,常用的options(选项):

(1)anchor:默认是anchor=CENTER。 

(2) bitmap 参数定义的标准位图如下:

从左到右是'error', 'gray75', 'gray50', 'gray25', 'gray12', 'hourglass', 'info', 'questhead', 'question', 和 'warning'. 或 question。可以直接使用 XBM(X Bitmap)格式的文件,在 XBM 文件名称前添加一个 @ 符号,如 bitmap=@hello.xbm

【在线免费转换您的png文件为xbm文件XBM转换器 — Convertio

下面使用create_ ibitmap方法的例子

请准备一张图片,名为TestUse. xbm,为方便将其和下面的示例源码文件放到同一文件夹中。

使用create_ ibitmap方法的示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()#加载图片显示C_B =cv.create_bitmap(40, 40,anchor=CENTER,bitmap="warning") #显示warning标准位图C_B2 =cv.create_bitmap(140, 140,anchor=CENTER,bitmap="@TestUse.xbm")#显示TestUse.xbm# 显示主窗口win.mainloop()

程序运行效果:

create_oval方法绘制椭圆,语法格式:

create_oval(x0, y0, x1, y1, option, ...)

椭圆,包括特殊情况下的圆。所占用的矩形区域由左上角的坐标(x0,y0)和右下角外的点的坐标(x1,y1)定义。option(选项)在此就不多说了。

使用create_oval方法的示例源码

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()#绘制椭圆,填满颜色是绿色,外围颜色是红色。C_O =cv.create_oval(80,20,320,180,fill="green",outline="red")            # 显示主窗口win.mainloop()

程序运行效果:

create_rectangle() 方法绘制矩形,语法格式:

create_rectangle(x0, y0, x1, y1, option, ...)

为矩形指定为两点:(x0,y0)是左上角,(x1,y1)是像素在右下角外面的位置。

下面给出绘制矩形示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()#绘制矩形C_O =cv.create_rectangle(30,40,280,210)       # 显示主窗口win.mainloop()

程序运行效果:

create_polygon方法绘制多边形,语法格式:

create_polygon(x0, y0, x1, y1, ..., option, ...)

由一系列顶点(x0,y0),(x1,y1),…(xn,yn)决定多边形轮廓。

下面给出绘制多边形示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()#绘制三角形C_P =cv.create_polygon(10,10,70,80,60,30)C_P2 =cv.create_polygon(110,20,170,90,160,50,fill="white",outline="black")#绘制六边形C_P2 =cv.create_polygon(290,114,316,114,330,130,310,146,284,146,270,130)# 显示主窗口win.mainloop()

程序运行效果:

create_text方法输出文字,语法格式:

create_text(x, y, option, ...)

(x,y)是文字字符串输出的中心坐标,常用的options(选项):

(1)anchor:默认是anchor=CENTER。

(2)fill:文字颜色。

(3)font:字形的使用。

(4)justify:当输出多行时,默认是靠左LEFT。

(5)stipple:绘制位图线条的文字,默认是“”表示实线。

(6)text:输出的文字。

下面给出输出文字示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()#输出文字myStr = "welcome 欢迎"C_T1 = cv.create_text(200, 30, text=myStr)C_T2 = cv.create_text(200, 50, text=myStr, fill='blue')C_T3 = cv.create_text(200, 90, text=myStr, fill='red',                    font=('隶书',20))# 显示主窗口win.mainloop()

程序运行效果:

create_window方法绘制窗口,语法格式:

create_window(x, y, option, ...)

在指定位置(x, y)创建一个窗口控件,窗口是一个矩形区域,可以使用画布窗口(canvas window)对象将任何Tkinter的 widget(组件、小部件、控件)放置到画布上。常用的options(选项):

(1)anchor  窗口相对于点(x,y)定位的。默认值为anchor= CENTER,表示窗口位于(x,y)位置的中心。锚定(anchor)常数可见前面。

(2)height 为窗口保留的区域的高度。如果省略,窗口大小将适合所包含小部件的高度。

(3)width 为窗口保留的区域的宽度。如果省略,窗口大小将适合所包含小部件的宽度。

(4)window  使用window=w,其中w是要放置在画布上的widget(组件、小部件、控件)。

使用create_window方法示例源码:

from tkinter import *# 创建窗口win= Tk()win.title("创建画布")win.geometry("600x400")# 定义移动函数def move_img():    # 定义移动坐标    cv.move(image1,50,30)# 创建Canvascv= Canvas(win,width=400,height=300,bg="white")# 设置画布放置布局cv.pack()# 使用 PhotoImage()来加载图片img = PhotoImage (file="TestUse.png")image1=cv.create_image(30,150,image = img,anchor =W)# 将按钮放置在画布中btn=Button(cv,text="点击移动画布",bg="#8A8A8A",activebackground="#7CCD7C",command=move_img)# 在指定位置创建一个窗口控件,tags来添加标签cv.create_window(340,260,height=30,width=80,window=btn)# 显示主窗口win.mainloop()

程序运行效果:

你可点击上图中的按钮试试。

来源地址:https://blog.csdn.net/cnds123/article/details/127344534

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯