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

  • Post author:
  • Post category:其他


下边这一系列方法用于与窗口管理器进行交互。他们可以被 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)控制窗口的透明度

2. 1.0 表示不透明,0.0 表示完全透明

3. 该选项并不支持所有的系统,对于不支持的系统,Tkinter 绘制一个不透明(1.0)的窗口
disabled (Windows)禁用整个窗口(这时候你只能从任务管理器中关闭它)
fullscreen (Windows,Mac)如果设置为 True,则全屏显示窗口
modified (Mac)如果设置为 True,该窗口被标记为改动过
titlepath (Mac)设置窗口代理图标的路径
toolwindow (Windows)如果设置为 True,该窗口采用工具窗口的样式
topmost (Windows,Mac)如果设置为 True,该窗口将永远置于顶层


client(name=None)


— 设置和获取 WM_CLIENT_MACHINE 属性

— 如果要删除 WM_CLIENT_MACHINE 属性,赋值为空字符串即可

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


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()



版权声明:本文为qq_41556318原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。