软件测试|超好用超简单的Python GUI库——tkinter(十六)

前言

我们在使用各种软件时,菜单是我们最常用的功能之一,菜单以可视化的方式将一系列的“功能选项卡”进行分组,并在每个分组下又“隐藏”了许多其他的“选项卡”。当打开菜单时,这些选项卡就会“显式”的呈现出来,方便用户进行选择,比如我们常用的QQ音乐播放器,如下图:

在这里插入图片描述

tkinter同样给我们提供了一个创建菜单的控件,Menu控件,帮助我们实现菜单的功能。

Menu(菜单)控件

菜单控件(Menu)可以充分地节省有限的窗口区域,让我们的界面更加简洁优雅,避免臃肿、混乱。

Tkinter Menu 控件提供了三种类型的菜单,分别是:topleve(主目录菜单)、pull-down(下拉式菜单)、pop-up(弹出式菜单,或称快捷式菜单)。

创建菜单

方法说明
add_cascade(**options)添加一个父菜单,将一个指定的子菜单,通过 menu 参数与父菜单连接,从而创建一个下拉菜单
add_checkbutton(**options)添加一个多选按钮的菜单项
add_command(**options)添加一个普通的命令菜单项
add_radiobutton(**options)添加一个单选按钮的菜单项
add_separator(**options)添加一条分割线
add(add(itemType, options))添加菜单项,此处 itemType 参数可以是以下几种:“command”、“cascade”,“checkbutton”、“radiobutton”、“separator” 五种,并使用 options 选项来设置菜单其他属性。

菜单项操作

方法说明
delete(index1, index2=None)1. 删除 index1 ~ index2(包含)的所有菜单项
2. 如果忽略 index2 参数,则删除 index1 指向的菜单项
entrycget(index, option)获得指定菜单项的某选项的值
entryconfig(index, **options)设置指定菜单项的选项
index(index)返回与 index 参数相应的选项的序号
insert(index, itemType, **options)插入指定类型的菜单项到 index 参数指定的位置,类型可以是:“command”,“cascade”,“checkbutton”,"radiobutton"或 “separator” 中的一个,或者也可以使用 insert_类型() 形式来,比如 insert_cascade(index, **options)…等
invoke(index)调用 index 指定的菜单项相关联的方法
post(x, y)在指定的位置显示弹出菜单
type(index)获得 index 参数指定菜单项的类型
unpost()移除弹出菜单
yposition(index)返回 index 参数指定的菜单项的垂直偏移位置

options参数介绍

属性说明
accelerator1. 设置菜单项的快捷键,快捷键会显示在菜单项目的右边,比如 accelerator = “Ctrl+O” 表示打开;
2. 注意,此选项并不会自动将快捷键与菜单项连接在一起,必须通过按键绑定来实现
command选择菜单项时执行的 callback 函数
label定义菜单项内的文字
menu此属性与 add_cascade() 方法一起使用,用来新增菜单项的子菜单项
selectcolor指定当菜单项显示为单选按钮或多选按钮时选择中标志的颜色
state定义菜单项的状态,可以是 normal、active 或 disabled
onvalue/offvalue1. 默认情况下,variable 选项设置为 1 表示选中状态,反之设置为 0,设置 offvalue/onvalue 的值可以自定义未选中状态的值
tearoff1. 如果此选项为 True,在菜单项的上面就会显示一个可选择的分隔线;
2. 注意:分隔线会将此菜单项分离出来成为一个新的窗口
underline设置菜单项中哪一个字符要有下画线
value1. 设置按钮菜单项的值
2. 在同一组中的所有按钮应该拥有各不相同的值
3. 通过将该值与 variable 选项的值对比,即可判断用户选中了哪个按钮
variable当菜单项是单选按钮或多选按钮时,与之关联的变量

示例

下面我们通过几个示例来介绍上述属性以及方法的使用:

创建主目录菜单

主目录菜单也称之为“顶级菜单”,下拉菜单等其他子菜单的都需要建立在“顶级菜单”的基础之上,下面示例创建了一个类似于“记事本”界面的程序,代码如下:

from tkinter import *
import tkinter . messagebox
#创建主窗口
win = Tk()
win.config(bg='#87CEEB')
win.title("拜仁慕尼黑")
win.geometry('450x350+300+200')

# 绑定一个执行函数,当点击菜单项的时候会显示一个消息对话框
def menuCommand() :
    tkinter.messagebox.showinfo("拜仁慕尼黑","你正在使用拜仁慕尼黑")
# 创建一个主目录菜单,也被称为顶级菜单
main_menu = Menu (win)
#新增命令菜单项,使用 add_command() 实现
main_menu.add_command (label="关于球队",command=menuCommand)
main_menu.add_command (label="球员",command=menuCommand)
main_menu.add_command (label="教练",command=menuCommand)
main_menu.add_command (label="欧冠",command=menuCommand)
main_menu.add_command (label="德甲联赛",command=menuCommand)
#显示菜单
win.config (menu=main_menu)
win.mainloop()

运行程序,结果如下图:

在这里插入图片描述

创建下拉菜单

下拉菜单时主菜单的重要组成部分,也是用户选择相关命令的重要交互界面,下拉菜单的创建方式也非常简单,不过需要我们注意,下拉菜单是建立的主菜单(即顶级菜单)的基础之上的,并非主窗口之上,这一点千万不要搞混,否则创建下拉菜单会失败。

#创建一个下拉式菜单
from tkinter import *
import tkinter .messagebox
#创建主窗口
win = Tk()
win.config(bg='#87CEEB')
win.title("拜仁慕尼黑")
win.geometry('450x350+300+200')

#创建一个执行函数,点击下拉菜单中命令时执行
def menuCommand() :
    tkinter .messagebox .showinfo("拜仁慕尼黑", "您正在使用拜仁慕尼黑")
#创建主目录菜单(顶级菜单)
mainmenu = Menu (win)
#在顶级菜单上新增"文件"菜单的子菜单,同时不添加分割线
filemenu = Menu (mainmenu, tearoff=False)
#新增"文件"菜单的菜单项,并使用 accelerator 设置菜单项的快捷键
filemenu.add_command (label="前锋",command=menuCommand,accelerator="Ctrl+N")
filemenu.add_command (label="中场",command=menuCommand, accelerator="Ctrl+O")
filemenu.add_command (label="后卫",command=menuCommand, accelerator="Ctrl+S")
filemenu.add_command (label="守门员",command=menuCommand, accelerator="Ctrl+G")
# 添加一条分割线
filemenu.add_separator ()
filemenu.add_command (label="退出",command=win. quit)
#在主目录菜单上新增"文件"选项,并通过menu参数与下拉菜单绑定
mainmenu.add_cascade (label="球员",menu=filemenu)
# 将主菜单设置在窗口上
win.config (menu=mainmenu)
# 绑定键盘事件,按下键盘上的相应的键时都会触发执行函数
win.bind ("<Control-n>",menuCommand)
win. bind ("<Control-N>", menuCommand)
win.bind ("<Control-o>",menuCommand)
win. bind ("<Control-O>", menuCommand)
win. bind ("<Control-s>", menuCommand)
win.bind ("<Control-S>",menuCommand)
win. bind ("<Control-g>", menuCommand)
win.bind ("<Control-G>",menuCommand)
# 显示主窗口
win.mainloop()

运行程序,结果如下:

在这里插入图片描述

创建弹出式菜单

弹出式菜单栏,也称为快捷式菜单栏,比如通过点击鼠标右键弹出一个菜单栏,其中包含一些常用的选项卡,如复制、粘贴等,代码如下:

import tkinter as tk

root = tk.Tk()
root.config(bg='#8DB6CD')
root.title("拜仁慕尼黑")
root.geometry('400x300')



def func():
    print('您通过弹出菜单执行了命令')


# 创建一个弹出菜单
menu = tk.Menu(root, tearoff=False)
menu.add_command(label="球员", command=func)
menu.add_command(label="球队", command=func)
menu.add_command(label="欧冠", command=func)
menu.add_command(label="联赛", command=func)


# 定义事件函数
def command(event):
    # 使用 post()在指定的位置显示弹出菜单
    menu.post(event.x_root, event.y_root)


# 绑定鼠标右键,这是鼠标绑定事件
# <Button-3>表示点击鼠标的右键,1 表示左键,2表示点击中间的滑轮
root.bind("<Button-3>", command)
root.mainloop()

运行程序,结果如下:

在这里插入图片描述

菜单按钮控件

Menubutton(菜单按钮控件)是一个与 Menu 控件相关联的按钮,当我们按下按钮的时候下拉菜单就会自动弹出。通过 Menubutton 创建的菜单按钮可以自由地放置在窗口中的任意位置,从而提高了GUI 界面的灵活性,代码如下:

from tkinter import *
win=Tk()
win.config(bg='#87CEEB')
win.title("拜仁慕尼黑")
win.geometry('450x350+300+200')

#创建一个菜单按钮
menubtn=Menubutton(win, text='点击进行选择', relief='sunk')
# 设置位置(布局)
menubtn.grid(padx=195, pady=105)
#添加菜单,使用 tearoff 参数不显示分割线
filemenu=Menu(menubtn,tearoff = False)
filemenu.add_command(label='球员')
filemenu.add_command(label='球队')
filemenu.add_command(label='欧冠')
filemenu.add_command(label='联赛')
# 显示菜单,将菜单命令绑定在菜单按钮对象上
menubtn.config(menu=filemenu)
win.mainloop()

运行程序,结果如下:
在这里插入图片描述

总结

本文主要介绍了tkinter菜单控件的使用,菜单控件可以使我们的程序更有层次感,更加符合用户使用习惯,后续我们将介绍tkinter滚动条控件的使用。

更多技术文章

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的偶来说,还是不够人性化。TK也有一个工具叫GUI Builder,不过它使用Layout布局,不够直观,而且用起来很不爽。。 至于PyQt/wxPythonGUI,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀, 而且不够环保,不够低碳,要带一个很大的,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过我经过多次实验后发现导入Python自带的标准TTK主题,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的PythonGUI界面,支持2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 当然除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可,不到20M,小巧玲珑。 代码已经在Github上托管,更新的版本可以在这上面找到,需求也可以在上面提: https://github.com/cdhigh/Visual-Tkinter-for-Python

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值