python教程系列(四.2、TKinter基础部件)

python教程系列(四.2、TKinter基础部件)_第1张图片

文章目录

    • 组件概念
    • 组件布局

组件概念

一个窗口中任意内容都可以称之为一个组件

tkinter的组件包含以下几种:

按钮组件

Button              按钮组件
RadioButton         单选框组件
CheckButton         选择按钮组件
Listbox             列表框组件

文本输入框组件

Entry               单行文本框组件
Text                多行文本框组件

标签组件

Label               标签组件,可以显示图片和文字
Message             标签组件,可以根据内容将文字换行

菜单组件

Menu                菜单组件
MenuButton          菜单按钮组件,可以使用Menu代替

滚动条组件

scale               滑块组件
Scrollbar           滚动条组件

其他组件

Canvas              画布组件
Frame               框架组件,将多个组件编组
Toplevel            创建子窗口容器组件

创建简单的窗口

import tkinter

#生成主窗口对象
root = tkinter.Tk()

#保持主窗口一直消息循环中。。
root.mainloop()

带有组件的窗口

import tkinter

#生成主窗口对象
root = tkinter.Tk()

#创建标签 并且添加到主窗口中
label = tkinter.Label(root,text = '爷来了')
label.pack()

#创建按钮,并且添加到主窗口中

btn1 = tkinter.Button(root,text = '按钮1')
btn1.pack()

btn2 = tkinter.Button(root,text = '按钮2')
btn2.pack()

#保持主窗口一直消息循环中。。
root.mainloop()


组件布局

组件布局一共三种方式:

pack()      按照方位布局
place()     按照坐标布局
grid()      按照网格布局

1.pack布局方法

所有的Tkinter组件都包含专用的几何管理方法,这些方法是用来组织和管理整个父配件区中子配件的布局的。Tkinter提供了截然不同的三种几何管理类:pack、grid和place。

pack几何管理采用块的方式组织配件,在快速生成界面设计中广泛采用,若干组件简单的布局,采用pack的代码量最少。pack几何管理程序根据组件创建生成的顺序将组件添加到父组件中去。通过设置相同的锚点(anchor)可以将一组配件紧挨一个地方放置,如果不指定任何选项,默认在父窗体中自顶向下添加组件。

pack()布局的通用公式为:

组件对象.pack(设置, …)

名称 描述 取值范围
expand 当值为“yes”时,side选项无效。组件显示在父配件中心位置;若fill选项为”both”,则填充父组件的剩余空间。 “yes”, 自然数, “no”, 0 (默认值为“no”或0)
fill 填充x(y)方向上的空间,当属性side=”top”或”bottom”时,填充x方向;当属性side=”left”或”right”时,填充”y”方向;当expand选项为”yes”时,填充父组件的剩余空间。 “x”, “y”, “both”(默认值为待选)
ipadx, ipady 组件内部在x(y)方向上填充的空间大小,默认单位为像素,可选单位为c(厘米)、m(毫米)、i(英寸)、p(打印机的点,即1/27英寸),用法为在值后加以上一个后缀既可。 非负浮点数(默认值为0.0)
padx, pady 组件外部在x(y)方向上填充的空间大小,默认单位为像素,可选单位为c(厘米)、m(毫米)、i(英寸)、p(打印机的点,即1/27英寸),用法为在值后加以上一个后缀既可。 非负浮点数(默认值为0.0)
side 定义停靠在父组件的哪一边上。 “top”, “bottom”, “left”, “right”(默认为”top”)
before 将本组件于所选组建对象之前pack,类似于先创建本组件再创建选定组件。 已经pack后的组件对象
after 将本组件于所选组建对象之后pack,类似于先创建选定组件再本组件。 已经pack后的组件对象
in_ 将本组件作为所选组建对象的子组件,类似于指定本组件的master为选定组件。 已经pack后的组件对象
anchor 相对于摆放组件的位置的对齐方式,左对齐”w”,右对齐”e”,顶对齐”n”,底对齐”s” “n”, “s”, “w”, “e”, “nw”, “sw”, “se”, “ne”, “center”(默认为” center”)

注:以上选项中可以看出expand、fill和side是相互影响的。

pack类提供了下列函数:

函数名 描述
slaves() 以列表方式返回本组件的所有子组件对象。
propagate(boolean) 设置为True表示父组件的几何大小由子组件决定(默认值),反之则无关。
info() 返回pack提供的选项所对应得值。
forget() Unpack组件,将组件隐藏并且忽略原有设置,对象依旧存在,可以用pack(option, …),将其显示。
location(x, y) x, y为以像素为单位的点,函数返回此点是否在单元格中,在哪个单元格中。返回单元格行列坐标,(-1, -1)表示不在其中。
size() 返回组件所包含的单元格,揭示组件大小。

2.grid布局方法

grid几何管理采用类似表格的结构组织配件,使用起来非常灵活,用其设计对话框和带有滚动条的窗体效果最好。grid采 用行列确定位置,行列交汇处为一个单元格。每一列中,列宽由这一列中最宽的单元格确定。每一行中,行高由这一行中最高的单元格决定。组件并不是充满整个单 元格的,你可以指定单元格中剩余空间的使用。你可以空出这些空间,也可以在水平或竖直或两个方向上填满这些空间。你可以连接若干个单元格为一个更大空间, 这一操作被称作跨越。创建的单元格必须相临。

grid()布局的通用公式为:

组件对象.grid(option, …)

grid类提供了下列设置属性:

名称 描述 取值范围
column 组件所置单元格的列号。 自然数(起始默认值为0,而后累加)
columnspan 从组件所置单元格算起在列方向上的跨度。 自然数(起始默认值为0)
ipadx, ipady 组件内部在x(y)方向上填充的空间大小,默认单位为像素,可选单位为c(厘米)、m(毫米)、i(英寸)、p(打印机的点,即1/27英寸),用法为在值后加以上一个后缀既可。 非负浮点数(默认值为0.0)
padx, pady 组件外部在x(y)方向上填充的空间大小,默认单位为像素,可选单位为c(厘米)、m(毫米)、i(英寸)、p(打印机的点,即1/27英寸),用法为在值后加以上一个后缀既可。 非负浮点数(默认值为0.0)
row 组件所置单元格的行号。 自然数(起始默认值为0,而后累加)
rowspan 从组件所置单元格算起在行方向上的跨度。 自然数(起始默认值为0)
in_ 将本组件作为所选组建对象的子组件,类似于指定本组件的master为选定组件。 已经pack后的组件对象
sticky 组件紧靠所在单元格的某一边角。 “n”, “s”, “w”, “e”, “nw”, “sw”, “se”, “ne”, “center”(默认为” center”)

grid类提供了下列函数:

函数名 描述
slaves() 以列表方式返回本组件的所有子组件对象。
propagate(boolean) 设置为True表示父组件的几何大小由子组件决定(默认值),反之则无关。
info() 返回pack提供的选项所对应得值。
forget() Unpack组件,将组件隐藏并且忽略原有设置,对象依旧存在,可以用pack(option, …),将其显示。
grid_remove ()

3.place布局方法

这个的几何管理器组织放置在一个特定的位置,在他们的父widget部件.

place()布局的通用公式为:

组件对象.place(option, …)

名称 描述 取值范围
anchor 描述 相对于摆放组件的坐标的位置,请参阅:可能是N,E,S,W,东北,西北,东南或西南,罗盘方向指示的widget的角落,双方默认是净重(部件上左上角)
height 以像素为单位的高度. (绝对布局专用) 像素
width 以像素为单位的宽度. (绝对布局专用) 像素
relheight 组件相对于窗口的的高度 (相对布局专用) 0~1
relwidth 组件相对于窗口的的宽度 (相对布局专用) 0~1
relx 水平偏移为0.0和1.0之间浮动,父widget的一小部分的高度和宽度. (相对布局专用) 0~1
rely 垂直偏移为0.0和1.0之间浮动,父widget的一小部分的高度和宽度. (相对布局专用) 0~1
x 组件距离左上角的x坐标 (绝对布局专用) 像素
y 组件距离左上角的y坐标 (绝对布局专用) 像素

place类提供了下列函数(使用组件实例对象调用):

函数名 描述
place_slaves() 以列表方式返回本组件的所有子组件对象。
place_configure(option=value) 给pack布局管理器设置属性,使用属性(option)= 取值(value)方式设置
propagate(boolean) 设置为True表示父组件的几何大小由子组件决定(默认值),反之则无关。
place_info() 返回pack提供的选项所对应得值。
grid_forget() Unpack组件,将组件隐藏并且忽略原有设置,对象依旧存在,可以用pack(option, …),将其显示。
location(x, y) x, y为以像素为单位的点,函数返回此点是否在单元格中,在哪个单元格中。返回单元格行列坐标,(-1, -1)表示不在其中
size() 返回组件所包含的单元格,揭示组件大小。

组件1 按钮(button)

用于定义gui界面中的按钮组件,

tkinter.Button(用于存放的父组件,属性参数...)

具备以下属性:

anchor              设置按钮中文字的对其方式,相对于按钮的中心位置
background(bg)      设置按钮的背景颜色
foreground(fg)      设置按钮的前景色(文字的颜色)
borderwidth(bd)     设置按钮边框宽度
cursor              设置鼠标在按钮上的样式
command             设定按钮点击时触发的函数
bitmap              设置按钮上显示的位图
font                设置按钮上文本的字体
width               设置按钮的宽度  (字符个数)
height              设置按钮的高度  (字符个数)
state               设置按钮的状态
text                设置按钮上的文字
image               设置按钮上的图片

组件2 文本框(Entry)和多行文本(Text)

用于定义页面中文本的单行输入框

#单行文本
tkinter.Entry(用于存放的父组件,属性参数...)
#多行文本
tkinter.Text(用于存放的父组件,属性参数...)

具备以下属性:

background(bg)          设置文本框的背景色
foreground(bg   )       设置文本框的前景色
borderwidth(bd)         设置文本输入框的边框
font                    设置文本框中的字体
width                   设置文本框的宽度(字符个数)
height                  设置文本框的高度(字符个数),仅限于text
state                   设置文本框的状态
selectbackground        选中文字时文本框的背景色
selectforeground        选中文字时文字的颜色
show                    指定文本框显示的字符,若为*,则表示为密码框

textvariable    设置文本对应的变量,可以通过修改变量改变文字显示,必须使用tkinter.IntVar() 或者tkinter.StringVar()产生的变量  entry可以使用

组件3 标签(Lebal)

标签用语在页面中显示文字或者图片

tkinter.Label(用于存放的父组件,属性参数...)

具备以下属性:

anchor          设置文本相对于标签中心的位置
background      设置标签的背景色
foreground      设置标签的前景色
borderwidth     设置标签的边框宽度
width               设置标签的宽度(字符个数)
height              设置标签的高度(字符个数)
text                设置标签中文本内容
font                设置标签中文字的字体类型
bitmap              设置标签的现实的位图
image               设置标签中显示的图片
justify         是设置标签中多行文本的对其方式
textvariable    设置文本对应的变量,可以通过修改变量改变文字显示,必须使用tkinter.IntVar() 或者tkinter.StringVar()产生的变量

组件4 菜单(Menu)

菜单用语在界面中设置菜单,和多级子菜单 在tkinter中,菜单组件的添加与其他组件有所不同。 菜单需要使用所创建的主窗口的 config方法添加到窗口中。

这个小工具的目标是,让我们来创建我们的应用程序,可以通过使用各种菜单。核心功能,提供的方式来创建三个菜单类型:弹出式,顶层,和下拉.

thinter.Menu(用于存放的父组件,属性参数...)

具有以下属性

activebackground        背景颜色,当它在鼠标下时将出现在选择上。

activeborderwidth       指定在鼠标下方选择的边框的宽度。默认值为1像素。

activeforeground        当它在鼠标下方时,将出现在选择上的前景色。

background(bg)          用于不在鼠标下的选择的背景颜色。

borderwidth(bd)         围绕所有选择的边框的宽度。默认值为1。

cursor                  当鼠标在选项上方时出现的光标,但仅当菜单已被关闭时显示。

disabledforeground      状态为DISABLED的项目的文本颜色。

font                    设置文本的字体

foreground(fd)          用于不在鼠标下的选择的前景色。

postcommand             您可以将此选项设置为过程,并且每当有人启动此菜单时,将调用该过程。

relief                  菜单的默认3-D效果为relief = RAISED。

image                   在这个menubutton上显示一个图像。

selectcolor             指定在检查按钮和单选按钮中显示的颜色。

tearoff                 通常情况下,菜单可以被拆除,如果设置tearoff = 0,菜单将不会有撕纸功能,并且从0位置开始添加选择。

title                   通常,撕下菜单窗口的标题将与导致此菜单的menubutton或级联文本相同。如果要更改该窗口的标题,请将标题选项设置为该字符串。

具有以下方法

add_command(选项)         在菜单中添加一个菜单项。
add_radiobutton(选项)     创建单选按钮菜单项。
add_checkbutton(选项)     创建一个检查按钮菜单项。
add_cascade(选项)         通过将给定的菜单与父菜单相关联来创建新的分层菜单
add_separator()          在菜单中添加分隔线。
add(类型,选项)            在菜单中添加一个特定类型的菜单项。
delete(startindex [,endindex])  删除从startindex到endindex的菜单项。
entryconfig(index,options)      允许您修改由索引标识的菜单项,并更改其选项。
index(item)                 返回给定菜单项标签的索引号。
insert_separator(index)     在index指定的位置插入一个新的分隔符。
invoke(index)               调用与位置索引选择相关联的命令回调。如果一个检查按钮,其状态在设置和清除之间切换; 如果一个单选按钮,那个选择是设置的。
type(index)             返回由index指定的选项的类型:“cascade”,“checkbutton”,“command”,“radiobutton”,“separator”或“tearoff”。

万能实例:

from  tkinter import *
root = Tk()
#定义点击菜单触发的方法
def hello():
    print("hello!")

#创建总菜单
menubar = Menu(root)

# 创建一个下拉菜单,并且加入文件菜单
filemenu = Menu(menubar)

#创建下来菜单的选项
filemenu.add_command(label="Open", command=hello)
filemenu.add_command(label="Save", command=hello)
#创建下拉菜单的分割线
filemenu.add_separator()
filemenu.add_command(label="Exit", command=root.quit)

#将文件菜单作为下拉菜单添加到总菜单中,并且将命名为File
menubar.add_cascade(label="File", menu=filemenu)



# 显示总菜单
root.config(menu=menubar)
root.mainloop()

组件5 单选框(Radiobutton)与复选框(Checkbutton)

thinter.Radiobutton(用于存放的父组件,属性参数...)
thinter.Checkbutton(用于存放的父组件,属性参数...)

具有以下属性

anchor              设置组件中文字的对其方式
background(bg)      指定组件的背景色。    
borderwidth(bd)     指定组件边框的宽度。    
bitmap              指定组件中的位图。    
font                指定组件中文本的字体。    
foreground(fg)      指定组件的前 
height              指定组件的高度。    
image               指定组件中的图片。    
justify             指定组件中多行文本的对齐方式。    
text                指定组件中的文本,可以 使用“\ n” 表示换行。    
value               指定组件被选中后
variable            指定组件所关联的变量。  需要使用tkinter. IntVar()或者tkinter. StringVar()创建的值 
width               指定组件的宽度。

组件6 消息对话框(messagebox)

用于界面提示成功,失败,警告等相关信息提示框

tkinter。messageBox.FunctionName(title, message [, options])

参数:
FunctionName: 这是相应的消息框函数的名称.

title: 这是在一个消息框,标题栏显示的文本.

message: 这是要显示的文字作为消息.

options: 选项有替代的选择,你可以用它来定制一个标准的消息框。一些可以使用的选项是默认和家长。默认选项是用来指定默认的按钮,如中止,重试,或忽略在消息框中。父选项是用来指定要显示的消息框上的顶层窗口.

你可以使用以下功能之一对话方块:

showinfo()          显示信息对话框
showwarning()           提示警告对话框
showerror ()            显示错误对话
askquestion()           问题对话框
askokcancel()           确定还是取消对话框
askyesno ()         是不是对话框
askretrycancel ()   重试或者取消对话框

除了上述6个标准消息框外,还可以使用tkinter.messagebox._show函数创建其他类型 的消息框。tkinter.messagebox._show函数的控制参数如下。

  default   指定消息框的按钮。 
  icon      指定消息框的图标。  
  message   指定消息框所显示的消息。 
  parent    指定消息框的父组件。 
  title     指定消息框的标题。 
  type      指定消息框的类型。

组件7 Frame 框架

thinter.Menu(用于存放的父组件,属性参数...)

具有以下属性

background(bg)      正常的背景颜色显示在标签和指示器后面。
borderwidth(bd)     指标周围边界的大小。默认值为2像素。
cursor              如果将此选项设置为光标名称(箭头,点等),则鼠标光标将在检查按钮上方更改为该模式。
height              新框架的垂直尺寸。
highlightbackground 当框架没有焦点时,焦点的颜色突出显示。
highlightcolor      当框架具有焦点时,焦点突出显示的颜色。
highlightthickness  焦点亮点的厚度。
relief              使用默认值,relief = FLAT,检查按钮不会从背景中脱颖而出。您可以将此选项设置为任何其他样式
width               checkbutton的默认宽度取决于所显示的图像或文字的大小。您可以设置此选项的字符数和checkbutton的,总是有许多字符的空间。

**组件7 Toplevel **

顶层部件的工作,直接由窗口管理器管理的窗口。

thinter.Toplevel ( option, ... )

具有以下属性

background(bg)      窗口的背景颜色。
borderwidth(bd)     边框宽度(以像素为单位)默认为0。
cursor              当鼠标在此窗口中时出现的光标。
class_              通常,文本窗口小部件中选择的文本将导出为窗口管理器中的选择。如果您不想要该行为,请设置exportselection = 0。
font                插入窗口小部件的文本的默认字体。
froeground(fg)      在窗口小部件中用于文本(和位图)的颜色。您可以更改标记区域的颜色; 这个选项只是默认值。
height              窗口高度
relief              通常,顶级窗口将不会有三维边框。要获得阴影边框,请将bd选项设置为较大的默认值为零,并将relief选项设置为其中一个常量。
width               所需的窗口宽度。

具有以下方法

deiconify()     在使用iconify或提取方法后显示窗口。
frame()         返回系统特定的窗口标识符。
group(window)   将窗口添加到给定窗口管理的窗口组中。
iconify()       将窗口转换为图标,而不会破坏它。
协议(名称,函数)   将函数注册为将为给定协议调用的回调函数。
iconify()       将窗口转换为图标,而不会破坏它。
state()         返回窗口的当前状态。可能的值是正常的,标志性的,撤销的和图标。
transient([master])当没有给出参数时,将窗口转换为给定主机或窗口的父级的临时(瞬态)窗口。
withdraw()      从屏幕中删除窗口,而不会破坏它。
maxsize(width,height)   定义此窗口的最大大小。
minsize(width,height)   定义此窗口的最小大小。
positionfrom(who)       定义位置控制器。
resizable(width,height) 定义resize标志,用于控制窗口是否可以调整大小。
sizefrom(who)       定义大小控制器。
title(string)       定义窗口标题。

python教程系列(四.2、TKinter基础部件)_第2张图片

你可能感兴趣的:(python3课程)