Tkinter 组件详解(十三):Menu

您所在的位置:网站首页 按钮menu是什么意思 Tkinter 组件详解(十三):Menu

Tkinter 组件详解(十三):Menu

2024-07-12 03:59| 来源: 网络整理| 查看: 265

Menu(菜单)组件用于实现顶级菜单、下拉菜单和弹出菜单。

何时使用 Menu 组件?

Menu 组件通常被用于实现应用程序上的各种菜单,由于该组件是底层代码实现,所以不建议你自行通过按钮和其他组件来实现菜单功能。

用法

创建一个顶级菜单,你需要先创建一个菜单实例,然后使用 add() 方法将命令和其它子菜单添加进去:

import tkinter as tk root = tk.Tk() def callback(): print("~被调用啦~") #创建一个顶级菜单 menubar = tk.Menu(root) menubar.add_command(label = "Hello", command = callback) menubar.add_command(label = "Quit", command = root.quit) #显示菜单 root.config(menu = menubar) root.mainloop()

创建一个下拉菜单(或者其他子菜单),方法也是大同小异,最主要的区别是它们最后需要添加到主菜单上(而不是窗口上):

import tkinter as tk root = tk.Tk() def callback(): print("~被调用了~") # 创建一个顶级菜单 menubar = tk.Menu(root) # 创建一个下拉菜单“文件”,然后将它添加到顶级菜单中 filemenu = tk.Menu(menubar, tearoff=False) filemenu.add_command(label="打开", command=callback) filemenu.add_command(label="保存", command=callback) filemenu.add_separator() filemenu.add_command(label="退出", command=root.quit) menubar.add_cascade(label="文件", menu=filemenu) # 创建另一个下拉菜单“编辑”,然后将它添加到顶级菜单中 editmenu = tk.Menu(menubar, tearoff=False) editmenu.add_command(label="剪切", command=callback) editmenu.add_command(label="拷贝", command=callback) editmenu.add_command(label="粘贴", command=callback) menubar.add_cascade(label="编辑", menu=editmenu) # 显示菜单 root.config(menu=menubar) root.mainloop()

创建一个弹出菜单方法也是一致的,不过需要使用 post() 方法明确的将其显示出来:

import tkinter as tk root = tk.Tk() def callback(): print("~被调用了~") # 创建一个弹出菜单 menu = tk.Menu(root, tearoff=False) menu.add_command(label="撤销", command=callback) menu.add_command(label="重做", command=callback) frame = tk.Frame(root, width=512, height=512) frame.pack() def popup(event): menu.post(event.x_root, event.y_root) # 绑定鼠标右键 frame.bind("", popup) root.mainloop()

参数

Menu(master=None, **options) (class)

master -- 父组件

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

选项含义activebackground设置当 Menu 处于 "active" 状态(通过 state 选项设置状态)的背景色activeborderwidth设置当 Menu 处于 "active" 状态(通过 state 选项设置状态)的边框宽度activeforeground设置当 Menu 处于 "active" 状态(通过 state 选项设置状态)的前景色background设置背景颜色bg跟 background 一样borderwidth指定边框宽度bd跟 borderwidth 一样cursor指定当鼠标在 Menu 上飘过的时候的鼠标样式disabledforeground指定当 Menu 处于 "disabled" 状态的时候的前景色font指定 Menu 中文本的字体foreground设置 Menu 的前景色fg跟 foreground 一样postcommand将此选项与一个方法相关联,当菜单被打开的时候该方法将自动被调用relief1. 指定边框样式 2. 默认值是 "flat" 3. 另外你还可以设置 "sunken","raised","groove" 或 "ridge"selectcolor指定当菜单项显示为单选按钮或多选按钮时选择中标志的颜色tearoff1. 默认情况下菜单可以被“撕下”(点击 IDLE 菜单上边的 --------- 试试) 2. 将该选项设置为 Flase 关闭这一特性tearoffcommand如果你希望当用户“撕下”你的菜单时通知你的程序,那么你可以将该选项与一个方法相关联,那么当用户“撕下”你的菜单时,Tkinter 会带着两个参数去调用你的方法(一个参数是当前窗口的 ID,另一个参数是承载被“撕下”的菜单的窗口 ID)title默认情况下,被“撕下”的菜单标题是其主菜单的名字,不过你也可以通过修改此项的值来修改标题

方法

add(type, **options)-- type 参数指定添加的菜单类型,可以是:"command","cascade","checkbutton","radiobutton" 或 "separator"-- 还可以通过 options 选项设置菜单的属性,下表列举了 options 可以使用的选项和具体含义:

选项含义accelerator1. 显示该菜单项的加速键(快捷键) 2. 例如 accelerator = "Ctrl+N" 3. 该选项仅显示,并没有实现加速键的功能(通过按键绑定实现)activebackground设置当该菜单项处于 "active" 状态(通过 state 选项设置状态)的背景色activeforeground设置当该菜单项处于 "active" 状态(通过 state 选项设置状态)的前景色background设置该菜单项的背景颜色bitmap指定显示到该菜单项上的位图columnbreak从该菜单项开始另起一列显示command将该选项与一个方法相关联,当用户点击该菜单项时将自动调用此方法compound1. 控制菜单项中文本和图像的混合模式 2. 如果该选项设置为 "center",文本显示在图像上(文本重叠图像) 3. 如果该选项设置为 "bottom","left","right" 或 "top",那么图像显示在文本的旁边(如 "bottom",则图像在文本的下方font指定文本的字体foreground设置前景色hidemargin是否显示菜单项旁边的空白image1. 指定菜单项显示的图片 2. 该值应该是 PhotoImage,BitmapImage,或者能兼容的对象label指定菜单项显示的文本menu1. 该选项仅在 cascade 类型的菜单中使用 2. 用于指定它的下级菜单offvalue1. 默认情况下,variable 选项设置为 1 表示选中状态,反之设置为 0 2. 设置 offvalue 的值可以自定义未选中状态的值onvalue1. 默认情况下,variable 选项设置为 1 表示选中状态,反之设置为 0 2. 设置 onvalue 的值可以自定义选中状态的值selectcolor指定当菜单项显示为单选按钮或多选按钮时选择中标志的颜色selectimage如果你在单选按钮或多选按钮菜单中使用图片代替文本,那么设置该选项指定被菜单项被选中时显示的图片state1. 跟 text 选项一起使用,用于指定哪一个字符画下划线(例如用于表示键盘快捷键)underline1. 用于指定在该菜单项的某一个字符处画下划线 2. 例如设置为 1,则说明在该菜单项的第 2 个字符处画下划线value1. 当菜单项为单选按钮时,用于标志该按钮的值 2. 在同一组中的所有按钮应该拥有各不相同的值 3. 通过将该值与 variable 选项的值对比,即可判断用户选中了哪个按钮 4. 如在使用上有不懂具体可以参照 Radiobutton 组件的说明variable1. 当菜单项是单选按钮或多选按钮时,与之关联的变量 2. 如在使用上有不懂具体可以参照:Checkbutton 和 Radiobutton 组件的说明

add_cascade(**options)-- 添加一个父菜单-- 相当于 add("cascade", **options)add_checkbutton(**options)-- 添加一个多选按钮的菜单项-- 相当于 add("checkbutton", **options)add_command(**options)-- 添加一个普通的命令菜单项-- 相当于 add("command", **options)add_radiobutton(**options)-- 添加一个单选按钮的菜单项-- 相当于 add("radiobutton", **options)add_separator(**options)-- 添加一条分割线-- 相当于 add("separator", **options)delete(index1, index2=None)-- 删除 index1 ~ index2(包含)的所有菜单项-- 如果忽略 index2 参数,则删除 index1 指向的菜单项-- 注意:对于一个被“撕下”的菜单,你无法使用该方法entrycget(index, option)-- 获得指定菜单项的某选项的值entryconfig(index, **options)-- 设置指定菜单项的选项-- 选项的参数及具体含义请参考上方 add() 方法entryconfigure(index, **options)-- 跟 entryconfig() 一样index(index)-- 返回与 index 参数相应的选项的序号(例如 e.index("end"))insert(index, itemType, **options)-- 插入指定类型的菜单项到 index 参数指定的位置-- itemType 参数指定添加的菜单类型,可以是:"command","cascade","checkbutton","radiobutton" 或 "separator"-- 选项的参数及具体含义请参考上方 add() 方法insert_cascade(index, **options)-- 在 index 参数指定的位置添加一个父菜单-- 相当于 insert("cascade", **options)insert_checkbutton(index, **options)-- 在 index 参数指定的位置添加一个多选按钮-- 相当于 insert("checkbutton", **options)insert_command(index, **options)-- 在 index 参数指定的位置添加一个普通的命令菜单项-- 相当于 insert("command", **options)insert_radiobutton(index, **options)-- 在 index 参数指定的位置添加一个单选按钮-- 相当于 insert("radiobutton", **options)insert_separator(index, **options)-- 在 index 参数指定的位置添加一条分割线-- 相当于 insert("separator", **options)invoke(index)-- 调用 index 指定的菜单项相关联的方法-- 如果是单选按钮,设置该菜单项为选中状态-- 如果是多选按钮,切换该菜单项的选中状态post(x, y)-- 在指定的位置显示弹出菜单-- 参考上方【用法】中的创建弹窗菜单的例子type(index)-- 获得 index 参数指定菜单项的类型-- 返回值可以是:"command","cascade","checkbutton","radiobutton" 或 "separator"unpost()-- 移除弹出菜单yposition(index)-- 返回 index 参数指定的菜单项的垂直偏移位置-- 该方法的目的是为了让你精确放置相对于当前鼠标的位置弹出菜单



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3