Python-Tk(根窗口)和 Toplevel(顶级窗口)的方法汇总

Python013

Python-Tk(根窗口)和 Toplevel(顶级窗口)的方法汇总,第1张

下边这一系列方法用于与窗口管理器进行交互。他们可以被 Tk(根窗口)进行调用,同样也适用于 Toplevel(顶级窗口)。

注:并非所有操作系统均完全支持下方所有方法的实现。

aspect(minNumer=None, minDenom=None, maxNumer=None, maxDenom=None)

-- 控制该窗口的宽高比(width:height)

-- 宽高比限制在:minNumer / minDenom ~ maxNumer / maxDenom

-- 如果忽略参数,则返回一个 4 元组表示当前的限制(如果有的话)

attributes(*args)

-- 设置和获取窗口属性

-- 如果你只给出选项名,将返回当前窗口该选项的值

-- 注意:以下选项不支持关键字参数,你需要在选项前添加横杠(-)并用字符串的方式表示,用逗号(,)隔开选项和值。

-- 例如你希望设置窗口的透明度为 50%,你应该使用 attribute("-alpha", 0.5) 代替 attribute(alpha=0.5)

-- 下方表格列举了 args 可以使用各个选项的具体含义及用法:

选项 含义

alpha 1.(Windows,Mac)控制窗口的透明度

colormapwindows(*wlist)

-- 设置和获取 WM_COLORMAP_WINDOWS 属性

-- 该属性仅支持 X 窗口系统的窗口管理器,其他系统均忽略

command(value=None)

-- 设置和获取 WM_COMMAND 属性

-- 该属性仅支持 X 窗口系统的窗口管理器,其他系统均忽略

deiconify()

-- 显示窗口

-- 默认情况下新创建的窗口都会显示在屏幕上,但使用 iconify() 或 withdraw() 方法可以在屏幕上移除窗口

focusmodel(model=None)

-- 设置和获取焦点模式

frame()

-- 返回一个字符串表示当前系统特征

-- 对于类 Unix 系统,返回值是 X 窗口标识符

-- 对于 Windows 系统,返回值是 HWND 强制转换为长整形的结果

geometry(geometry=None)

-- 设置和获取窗口的尺寸

-- geometry 参数的格式为:"%dx%d%+d%+d" % (width, height, xoffset, yoffset)

grid(baseWidth=None, baseHeight=None, widthInc=None, heightInc=None)

-- 通知窗口管理器该窗口将以网格的形式重新调整尺寸

-- baseWidth 和 baseHeight 指定 Tk_GeometryRequest 要求的网格单元数

-- widthInc 和 heightInc 指定网格单元的宽度和高度(像素)

group(window=None)

-- 将窗口添加到窗口群中

-- window 参数指定控制窗口群的主窗口

-- 如果忽略该参数,将返回当前窗口群的主窗口

iconbitmap(bitmap=None, default=None)

-- 设置和获取窗口的图标

-- 例如 root.iconbitmap(bitmap="Python.ico")

-- default 参数可以用于指定由该窗口创建的子窗口的默认图标

iconify()

-- 将窗口图标化(最小化)

-- 需要重新显示窗口,使用 deiconify() 方法

-- 该方法会使得 state() 返回 "iconic"

iconmask(bitmap=None)

-- 设置和获取位图掩码

iconname(newName=None)

-- 设置和获取当窗口图标化(最小化)时的图标名字

iconposition(x=None, y=None)

-- 设置和获取当窗口图标化(最小化)时的图标位置

iconwindow(pathName=None)

-- 设置和获取当窗口图标化(最小化)时的组件窗口

-- 该方法会使得 state() 返回 "icon"

maxsize(width=None, height=None)

-- 设置和获取该窗口的最大尺寸

minsize(width=None, height=None)

-- 设置和获取该窗口的最小尺寸

overrideredirect(boolean=None)

-- 如果参数为 True,该窗口忽略所有的小部件(也就是说该窗口将没有传统的标题栏、边框等部件)

positionfrom(who=None)

-- 指定窗口位置由“谁”决定

-- 如果 who 参数是 "user",窗口位置由用户决定

-- 如果 who 参数是 "program",窗口位置由系统决定

protocol(name=None, func=None)

-- 将回调函数 func 与相应的规则 name 绑定

-- name 参数可以是 "WM_DELETE_WINDOW":窗口被关闭的时候

-- name 参数可以是 "WM_SAVE_YOURSELF":窗口被保存的时候

-- name 参数可以是 "WM_TAKE_FOCUS":窗口获得焦点的时候

resizable(width=None, height=None)

-- 指定是否可以改变该窗口的尺寸

-- width 为 True 说明允许调整窗口的水平尺寸

-- height 为 True 说明允许调整窗口的垂直尺寸

sizefrom(who=None)

-- 指定窗口尺寸由“谁”决定

-- 如果 who 参数是 "user",窗口位置由用户决定

-- 如果 who 参数是 "program",窗口位置由系统决定

state(newstate=None)

-- 设置和获得当前窗口的状态

-- newstate 的值可以是 "normal","iconic"(见 iconify),"withdrawn"(见 withdraw),"icon"(见 iconwindow)和 "zoomed"(放大,Windows 特有)

title(string=None)

-- 设置窗口的标题

transient(master=None)

-- 指定为 master 的临时窗口

withdraw()

-- 将窗口从屏幕上移除(并没有销毁)

-- 需要重新显示窗口,使用 deiconify() 方法

-- 该方法会使得 state() 返回 "withdrawn"

wm_aspect(minNumer=None, minDenom=None, maxNumer=None, maxDenom=None)

-- 见上方 aspect()

wm_attributes(*args)

-- 见上方 attributes()

wm_client(name=None)

-- 见上方 client()

wm_colormapwindows(*wlist)

-- 见上方 colormapwindows()

wm_command(value=None)

-- 见上方 command()

wm_deiconify()

-- 见上方 deiconify()

wm_focusmodel(model=None)

-- 见上方 focusmodel()

wm_frame()

-- 见上方 frame()

wm_geometry(geometry=None)

-- 见上方 geometry()

wm_grid(baseWidth=None, baseHeight=None, widthInc=None, heightInc=None)

-- 见上方 grid()

wm_group(window=None)

-- 见上方 group()

wm_iconbitmap(bitmap=None, default=None)

-- 见上方 iconbitmap()

wm_iconify()

-- 见上方 iconify()

wm_iconmask(bitmap=None)

-- 见上方 iconmask()

wm_iconname(newName=None)

-- 见上方 iconname()

wm_iconposition(x=None, y=None)

-- 见上方 iconposition()

wm_iconwindow(pathName=None)

-- 见上方 iconwindow()

wm_maxsize(width=None, height=None)

-- 见上方 maxsize()

wm_minsize(width=None, height=None)

-- 见上方 minsize()

wm_overrideredirect(boolean=None)

-- 见上方 overrideredirect()

wm_positionfrom(who=None)

-- 见上方 positionfrom()

wm_protocol(name=None, func=None)

-- 见上方 protocol()

wm_resizable(width=None, height=None)

-- 见上方 resizable()

wm_sizefrom(who=None)

-- 见上方 sizefrom()

wm_state(newstate=None)

-- 见上方 state()

wm_title(string=None)

-- 见上方 title()

wm_transient(master=None)

-- 见上方 transient()

wm_withdraw()

-- 见上方 withdraw()

Tkinter 是使用 python 进行窗口视窗设计的模块。Tkinter模块("Tk 接口")是Python的标准Tk GUI工具包的接口。作为 python 特定的GUI界面,是一个图像的窗口,tkinter是python 自带的,可以编辑的GUI界面,我们可以用GUI 实现很多直观的功能,比如想开发一个计算器,如果只是一个程序输入,输出窗口的话,是没用用户体验的。所有开发一个图像化的小窗口,就是必要的。

对于稍有GUI编程经验的人来说,Python的Tkinter界面库是非常简单的。python的GUI库非常多,选择Tkinter,一是最为简单,二是自带库,不需下载安装,随时使用,三则是从需求出发,Python作为一种脚本语言,一种胶水语言,一般不会用它来开发复杂的桌面应用,它并不具备这方面的优势,使用Python,可以把它作为一个灵活的工具,而不是作为主要开发语言,那么在工作中,需要制作一个小工具,肯定是需要有界面的,不仅自己用,也能分享别人使用,在这种需求下,Tkinter是足够胜任的!