Python Tkinter Menu组件详解

作者:来自江南的你 时间:2021-07-24 06:51:18 

目录
  • 何时使用 Menu 组件?

  • 用法

  • 参数

  • 方法

    • add_cascade(**options)

    • add_checkbutton(**options)

    • add_command(**options)

    • add_radiobutton(**options)

    • add_separator(**options)

    • delete(index1, index2=None)

    • entrycget(index, option)

    • entryconfig(index, **options)

    • entryconfigure(index, **options)

    • index(index)

    • insert(index, itemType, **options)

    • insert_cascade(index, **options)

    • insert_checkbutton(index, **options)

    • insert_command(index, **options)

    • insert_radiobutton(index, **options)

    • insert_separator(index, **options)

    • invoke(index)

    • post(x, y)

    • type(index)

    • unpost()

    • yposition(index)

  • 总结

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

    Python Tkinter Menu组件详解

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


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

    Python Tkinter Menu组件详解

    创建一个弹出菜单方法也是一致的,不过需要使用 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("<Button-3>", 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 参数指定的菜单项的垂直偏移位置

    -- 该方法的目的是为了让你精确放置相对于当前鼠标的位置弹出菜单

    来源:https://blog.csdn.net/qq_41556318/article/details/85273584

    标签:Tkinter,Menu,组件
    0
    投稿

    猜你喜欢

  • Python中Pyspider爬虫框架的基本使用详解

    2021-04-01 06:00:31
  • Sql 语句学习指南第1/2页

    2024-01-25 07:13:01
  • PowerDesigner中如何导入SQL Server数据库

    2024-01-17 08:38:46
  • Python中的heapq模块源码详析

    2023-09-23 12:07:23
  • Python使用ffmpy将amr格式的音频转化为mp3格式的例子

    2021-06-14 13:50:07
  • python组合无重复三位数的实例

    2021-11-18 03:59:13
  • python如何删除文件中重复的字段

    2021-09-19 15:43:12
  • ShardingSphere数据库读写分离算法及测试示例详解

    2024-01-19 06:21:09
  • html风格tooltip效果的实现

    2010-04-08 13:00:00
  • python常用模块详解

    2021-05-24 05:16:55
  • Python内置数据结构列表与元组示例详解

    2021-08-17 21:28:14
  • 使用phpMyAdmin进行mysql数据库备份和还原的方法

    2008-10-13 20:56:00
  • 真正保险的“有属性”检测

    2010-03-28 13:25:00
  • 使用Java实现先查询缓存再查询数据库

    2024-01-14 02:18:05
  • perl用{}修饰变量名的写法分享

    2023-03-18 05:43:00
  • 无序列表 li ul

    2008-07-29 13:00:00
  • PyQt5爬取12306车票信息程序的实现

    2023-05-18 05:03:08
  • 简单谈谈python基本数据类型

    2022-07-25 03:52:46
  • ASP编码问题的深入研究与解决方案(MSDN)

    2007-10-25 11:54:00
  • Python 多继承中的一个诡异现象 既是 Father又是grandfather

    2023-02-06 10:24:34
  • asp之家 网络编程 m.aspxhome.com