Menu
Menu(菜单)组件用于实现顶级菜单、下拉菜单和弹出菜单。
Menu 组件通常被用于实现应用程序上的各种菜单,由于该组件是底层代码实现,所以不建议你自行通过按钮和其他组件来实现菜单功能。
代码
创建一个顶级菜单,你需要先创建一个菜单实例,然后使用 add() 方法将命令和其它子菜单添加进去:
from tkinter import *
root = Tk()
menubar = Menu(root)
def copy():
print('复制')
def paste():
print('粘贴')
menubar.add_command(label='复制', command=copy)
menubar.add_command(label='粘贴', command=paste)
root.config(menu=menubar)
root.mainloop()
创建其他类型的菜单:
from tkinter import *
root = Tk()
def copy():
print('复制')
menubar = Menu(root)
# 点击主菜单,弹出子菜单
# tearoff不设置False 会显示虚线,点击虚线弹出第二个弹框
filemenu = Menu(menubar, tearoff=False)
filemenu.add_command(label='打开', command=copy)
filemenu.add_command(label='保存', command=copy)
filemenu.add_separator() # 分割线
filemenu.add_command(label='退出', command=root.quit())
menubar.add_cascade(label='文件', menu=filemenu)
editmenu = Menu(menubar, tearoff=False)
editmenu.add_command(label='复制', command=copy)
editmenu.add_command(label='剪切', command=copy)
editmenu.add_command(label='粘贴', command=root.quit())
menubar.add_cascade(label='编辑', menu=editmenu)
# 添加checkbutton
openVar = IntVar()
saveVar = IntVar()
quitVar = IntVar()
checkMenu = Menu(menubar, tearoff=False)
checkMenu.add_checkbutton(label='销量', command=copy, variable=openVar)
checkMenu.add_checkbutton(label='人气', command=copy, variable=saveVar)
checkMenu.add_checkbutton(label='价格', command=copy, variable=quitVar)
menubar.add_cascade(label='checkbutton', menu=checkMenu)
# radiobutton
radioVar = IntVar()
radiokMenu = Menu(menubar, tearoff=False)
radiokMenu.add_radiobutton(label='销量', command=copy, variable=radioVar, value=1)
radiokMenu.add_radiobutton(label='人气', command=copy, variable=radioVar, value=2)
radiokMenu.add_radiobutton(label='价格', command=copy, variable=radioVar, value=3)
menubar.add_cascade(label='radiobutton', menu=radiokMenu)
# 按钮菜单
mb = Menubutton(root, text='Menubutton', relief=RAISED)
mb.pack()
buttonmenu = Menu(mb, tearoff=False)
buttonmenu.add_command(label='打开', command=copy)
buttonmenu.add_command(label='保存', command=copy)
buttonmenu.add_command(label='退出', command=root.quit)
mb.config(menu=buttonmenu)
# 选择菜单
variable = StringVar()
variable.set('one')
OPTINOS = ['one', 'two', 'three', 'four']
# optionmenu = OptionMenu(root, variable, 'one', 'two', 'three', 'four')
optionmenu = variable(root, variable, *OPTINOS)
optionmenu.pack()
# 点击右键弹出菜单
menubar2 = Menu(root, tearoff=0)
menubar2.add_command(label='撤销', command=copy)
menubar2.add_command(label='重做', command=copy)
frame = Frame(root, width=512, height=512)
frame.pack()
def popup(event):
menubar2.post(event.x_root, event.y_root)
frame.bind('<Button-3>', popup)
root.config(menu=menubar)
# 获取variable选中的值
def get():
print(variable.get())
Button(text='按钮', command=get).pack()
mainloop()
参数
activebackground
设置当 Menu 处于 "active" 状态(通过 state 选项设置状态)的背景色
activeborderwidth
设置当 Menu 处于 "active" 状态(通过 state 选项设置状态)的边框宽度
activeforeground
设置当 Menu 处于 "active" 状态(通过 state 选项设置状态)的前景色
background
设置背景颜色
borderwidth
指定边框宽度
cursor
指定当鼠标在 Menu 上飘过的时候的鼠标样式
disabledforeground
指定当 Menu 处于 "disabled" 状态的时候的前景色
font
指定 Menu 中文本的字体
foreground
设置 Menu 的前景色
postcommand
将此选项与一个方法相关联,当菜单被打开的时候该方法将自动被调用
relief
1.指定边框样式
2.默认值是 "flat"
3.另外你还可以设置 "sunken","raised","groove" 或 "ridge"
selectcolor
指定当菜单项显示为单选按钮或多选按钮时选择中标志的颜色
tearoff
1.默认情况下菜单可以被“撕下”(点击 IDLE 菜单上边的 --------- 试试)
2.将该选项设置为 Flase 关闭这一特性
tearoffcommand
如果你希望当用户“撕下”你的菜单时通知你的程序,那么你可以将该选项与一个方法相关联,那么当用户“撕下”你的菜单时,Tkinter 会带着两个参数去调用你的方法(一个参数是当前窗口的 ID,另一个参数是承载被“撕下”的菜单的窗口 ID)
title
默认情况下,被“撕下”的菜单标题是其主菜单的名字,不过你也可以通过修改此项的值来修改标题
方法
add(type, **options)
-- type 参数指定添加的菜单类型,可以是:"command","cascade","checkbutton","radiobutton" 或 "separator"
-- 还可以通过 options 选项设置菜单的属性,下表列举了 options 可以使用的选项和具体含义:
accelerator
1.显示该菜单项的加速键(快捷键)
2.例如 accelerator = "Ctrl+N"
3.该选项仅显示,并没有实现加速键的功能(通过按键绑定实现)
activebackground
设置当该菜单项处于 "active" 状态(通过 state 选项设置状态)的背景色
activeforeground
设置当该菜单项处于 "active" 状态(通过 state 选项设置状态)的前景色
background
设置该菜单项的背景颜色
bitmap
指定显示到该菜单项上的位图
columnbreak
从该菜单项开始另起一列显示
command
将该选项与一个方法相关联,当用户点击该菜单项时将自动调用此方法
compound
1.控制菜单项中文本和图像的混合模式
2.如果该选项设置为 "center",文本显示在图像上(文本重叠图像)
3.如果该选项设置为 "bottom","left","right" 或 "top",那么图像显示在文本的旁边(如 "bottom",则图像在文本的下方
font 指定文本的字体
foreground
设置前景色
hidemargin
是否显示菜单项旁边的空白
image
1.指定菜单项显示的图片
2.该值应该是 PhotoImage,BitmapImage,或者能兼容的对象
label
指定菜单项显示的文本
menu
1.该选项仅在 cascade 类型的菜单中使用
2.用于指定它的下级菜单
offvalue
1.默认情况下,variable 选项设置为 1 表示选中状态,反之设置为 0
2.设置 offvalue 的值可以自定义未选中状态的值
onvalue
1.默认情况下,variable 选项设置为 1 表示选中状态,反之设置为 0
2.设置 onvalue 的值可以自定义选中状态的值
selectcolor
指定当菜单项显示为单选按钮或多选按钮时选择中标志的颜色
selectimage
如果你在单选按钮或多选按钮菜单中使用图片代替文本,那么设置该选项指定被菜单项被选中时显示的图片
state
跟 text 选项一起使用,用于指定哪一个字符画下划线(例如用于表示键盘快捷键)
underline
1.用于指定在该菜单项的某一个字符处画下划线
2.例如设置为 1,则说明在该菜单项的第 2 个字符处画下划线
value
1.当菜单项为单选按钮时,用于标志该按钮的值
2.在同一组中的所有按钮应该拥有各不相同的值
3.通过将该值与 variable 选项的值对比,即可判断用户选中了哪个按钮
4.如在使用上有不懂具体可以参照 Radiobutton 组件的说明
variable
1.当菜单项是单选按钮或多选按钮时,与之关联的变量
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 参数指定的菜单项的垂直偏移位置
-- 该方法的目的是为了让你精确放置相对于当前鼠标的位置弹出菜单