在PyQt5教程的这一部分中,我们创建了创建状态栏,菜单栏和工具栏。菜单是位于菜单栏中的一组命令。工具栏上有按钮,其中包含应用程序中的一些常用命令 状态栏显示状态信息,通常位于应用程序窗口的底部。

QMainWindow

状态栏

状态栏是用于显示状态信息的小组件。

状态栏是在QMainWindow小部件的帮助下创建的。

self.statusBar().showMessage( 'ready')

要获取状态栏,我们调用类QtGui.QMainWindow的statusBar()方法。方法的第一次调用会创建一个状态栏。后续调用将返回状态栏对象。在showMessage()显示在状态栏的消息。

我现在还没有遇见必须要用sys才能实现的。这次我们用的不是QWidget类了,而是QMainWindow类,因为QWidget没有statusBar()方法,widget的意思是窗口小部件的意思。

不过都需要show方法和QApplication才能显示出来。没有 app.exec_()这个主循环,窗口都是昙花一现。QMainWindow实际是继承于QWidget的。

简单的菜单

菜单栏是GUI应用程序的常见部分。它是位于各种菜单中的一组命令。(Mac OS对菜单栏的处理方式不同。为了获得类似的结果,我们可以添加以下行:menubar.setNativeMenuBar(False)。),windows就不用。

QMainWindow.menubar内部用的其实是QMenuBar类,不过QMenuBar不需要导入,似乎是直接把代码移植过来了。

我实际测试了,其实退出的快捷键是ctrl+q就够了q不需要大写,也就是不需要shift,虽然按shift也可以(一般程序员大写用的都是shift,而不会用大写锁)。看到这个exit是直接退出整个QApplication了,并且这里也写的是直接连接的就是the quit method of the QApplication。

qApp是QApplication的一个实例化对象。我们完全可以直接用QApplication。

还需要说明的一点是triggered虽然没有语法高亮,但是这个在QAcation里面确实是有的。并且QAcation触发没有clicked这个方法。

self.statusBar()就是创建一个状态栏显示exitAct.setStatusTip里面的内容,没有这一句是显示不了里面内容的。

Exit和File前面的&就目前而言可以不加,看不出&的用处。下面来理解一下这个setShorcut,它只是在后面显示一下文字,退出的快捷键是pyqt默认的设置就是ctrl+q呢,还是说是货真价实地改了快捷键呢?现在地快捷键是ctrl+q,按q时不会退出的。

然后把快捷键改为Q。

看来是货真价实地改了快捷键了。

子菜单

子菜单是位于另一个菜单内的菜单。

In the example, we have two menu items; one is located in the File menu and the other one in the File's Import submenu.(在示例中,我们有两个菜单项,一个在文件菜单里,另一个在文件的导入菜单里)

impMenu = QMenu('Import', self)

New menu is created with QMenu.(新的菜单是用QMenu创建的)。

impAct = QAction('Import mail', self)

impMenu.addAction(impAct)

An action is added to the submenu with addAction().(使用addAction()把一个动作加到了子菜单里面)。

下面的gif主要说明的是在代码里键入菜单的先后顺序决定了在菜单里的上下位置。

Check menu

在以下示例中,我们创建了一个可以选中和取消选中的菜单。

我们来试试上面所说的checkable和setchecked的作用。

把setchecked改为False会如何。

看到只是一开始,对号是默认没有勾的,并且这种情况下也可以看到状态栏,不过也仅限于第一次,后面就正常了,只有对号勾选了,才能看见状态栏。再改checkable呢?

看到没有对号勾选了,第一次显示了状态栏,后面就都不可见了。

Context menu

上下文菜单(也称为弹出菜单)是在某些上下文下显示的命令列表。例如,在Opera网页浏览器中,当我们右键单击网页时,我们会得到一个上下文菜单。在这里,我们可以重新加载页面,返回或查看页面源。如果我们右键单击工具栏,我们将获得另一个用于管理工具栏的上下文菜单。其实就和我们在桌面右键弹出菜单是一个道理。

我们点击new和open是没有用的,因为它们没有定义后续的判断操作。contextMenuEvent是QMainWindow的一个内置函数,这个函数名不可以写错的,和上一讲关闭消息框的closeEvent是一样的。

action = cmenu.exec_(self.mapToGlobal(event.pos()))里面的参数没有,context menu也会出来,不过位置就一直在左上角,而不是在鼠标右键的地方。

工具栏

菜单分组我们可以在应用程序中使用的所有命令。工具栏可以快速访问最常用的命令。

exitAct.triggered.connect(qApp.quit)括号里面一定是函数或方法的名字,后面不需要加括号。

不然就会报错。

把它放在一起

在本节的最后一个示例中,我们将创建一个菜单栏,工具栏和状态栏。我们还将创建一个中央小部件。

This code example creates a skeleton of a classic GUI application with a menubar, toolbar, and a statusbar.(这个代码实例创造了一个有菜单栏,工具栏和状态栏的经典GUI应用)

textEdit = QTextEdit() self.setCentralWidget(textEdit)

Here we create a text edit widget. We set it to be the central widget of the QMainWindow. The central widget will occupy all space that is left.(这里创造了一个文本编辑部件,我们把它设为中心部件,中心部件会占据剩下的所有空间。)

后面把btn这个按钮作为中心部件,按钮就覆盖了文本框。

PyQt5中的布局管理

布局管理是我们将小部件放置在应用程序窗口上的方式。我们可以使用绝对定位或布局类来放置小部件。使用布局管理器管理布局是组织窗口小部件的首选方式。

绝对定位

程序员以像素为单位指定每个小部件的位置和大小。当您使用绝对定位时,我们必须了解以下限制:

  • The size and the position of a widget do not change if we resize a window

    (如果我们改变窗口的大小,窗口部件的大小和位置不可以改变)

  • Applications might look different on various platforms(应用在不同的平台可能看起来不同)

  • Changing fonts in our application might spoil the layout(改变字体在应用中可能会破坏布局)

  • If we decide to change our layout, we must completely redo our layout, which is tedious and time consuming(如果我们决定改变我们的布局,我们必须完全重做布局,这是繁琐和耗时的)

以下示例将小部件放在绝对坐标中。

效果就是这样的。

我们使用该move()方法来定位我们的小部件。在我们的例子中,这些是标签。我们通过提供x和y坐标来定位它们。坐标系的开头位于左上角。x值从左到右增长。y值从上到下增长。

lbl1 = QLabel('Zetcode',self)

lbl1.move(15,10)

标签小部件位于x=15和 y=10

盒子布局

QHBoxLayout并且QVBoxLayout是水平和垂直排列小部件的基本布局类。

想象一下,我们想在右下角放置两个按钮。要创建这样的布局,我们使用一个水平和一个垂直框。为了创建必要的空间,我们添加了一个伸展因子。

self.setLayout(vbox)这句还是很重要的,没有它,按钮是显示不出来的,因为        okButton = QPushButton("OK")

cancelButton = QPushButton("Cancel")

hbox = QHBoxLayout()

hbox.addStretch(1)

hbox.addWidget(okButton)

hbox.addWidget(cancelButton)

vbox = QVBoxLayout()

vbox.addStretch(1)

vbox.addLayout(hbox)

这些按钮是添加在布局里面的。

我们看到无论你怎么拉伸,这两个按钮都在右下角,按钮的绝对位置会随着拉伸改变,因为绝对位置是相对于左上角的坐标嘛。和第一讲的

我们对比一下。

这个Button按钮的绝对位置不会随着伸缩而改变,把窗口向左拉,按钮跟着动还是要保持绝对位置不变,还是因为绝对位置是以左上角为原点或者说参考的。我们来研究一下伸缩因子到底干嘛用的。首先这里面传的参数必须是整数。

不然会报错。

不过在python里面。

这个里面的参数是负的貌似也每什么影响啊,但是如果把vbox的addStrech给注释了,发现按钮仍然会跟着伸缩改变绝对位置,但是位置是在垂直的中间,而不是下面,这个v是vertical,垂直的的意思。

把垂直布局的代码注释掉,效果和注释掉addStrech是一样的,然后我们把水平布局,h是herizonal的意思的addStrech注释掉,看到按钮出现在垂直的中间位置,这个没变,但是水平是贯穿整个窗口的,怎么伸缩都是。

QMainWindow好像是有自己的布局的,重新布局的是没有用的。

QGridLayout

QGridLayout是最通用的布局类。它将空间划分为行和列。

效果:

我们来复习里面用到的一些知识,主要集中在

positions = [(i,j) for i in range(5) for j in range(4)]

for position, name in zip(positions, names):

if name == '':

continue

button = QPushButton(name)

grid.addWidget(button, *position)

这一段里面。首先positions的产生用的是列表推导式,列表里面的元素是元组。

元组没有推导式,那种形式叫做生成器,可以用next方法,for i in positions其实里面是调用了next方法的。这块是迭代器的内容。 关于zip,我们直接看几个例子。

zip的第一个参数必须支持迭代。然后就是把对应位置的元素打包成一个元组,元组的小括号有时候可以不写,这里就可以不写。    grid.addWidget(button, *position)这个*是什么意思呢?

*就相当于是把最外面的括号,无论是哪种括号,都去掉。在我们这个代码实例中,*postion就会出来两个int,符合addWidget的参数格式(可能两个int之间可以用空格隔开,不过下面看到不是这样的,不知道*是个什么机制,反正传参数就是可以传)。

好像是自动加上了,一样。

集合其实也有推导式,然后就是addWidget不传位置参数的话,默认会排一列。

Review example(复习示例)

窗口小部件可以跨越网格中的多个列或行。在下一个例子中,我们将说明这一点

LineEdit,顾名思义就是只能写一行文本的编辑器。TextEdit就没有限制必须是一行文本。

间隔必须要传参数。

可以传负的

grid.addWidget(reviewEdit, 3, 1, 5, 1)的第三个参数是跨越行数,第四个是跨越列数,值得指出的是每一个矩阵单元的大小是不一样的,不然的话review的宽应该是上面的两倍,但是明显不是的。

有的位置参数可以不传,有默认参数,LineEdit传四个参数看起来很乱。

截止目前,我们还是可以不导入sys模块,  app = QApplication()甚至可以传一个空的列表,只要是列表都可以,别的类型目前来看是不行的。

PyQt5学习Ⅱ(菜单,工具栏和布局管理)相关推荐

  1. qt checkbox 选中事件_Qt学习笔记3(布局管理)

    界面组件布局: Qt 的界面设计使用了布局(Layout)功能.所谓布局,就是界面上组件的排列方式,使用布局可以使组件有规则地分布,并且随着窗体大小变化自动地调整大小和相对位置. 界面组件的层次关系. ...

  2. QT入门学习之UI设计布局管理

    1. QT Designer 可视化UI设计及布局管理 创建一个Qt Widget Application项目demo2.在创建窗体时选择基类QDialog,生成的类命名为QWDialog,并选择生成 ...

  3. Java学习之面板与布局管理器

    - 面板 - 流布局管理器 - 网格布局管理器 - 边界布局管理器 今天我们先创建一个窗体,再创建一个容器,容器使用的是一个3行1列的网格布局管理器,然后我们在容器中添加不同布局的面板来看一下效果 1 ...

  4. python pyside简单布局_PySide2/PyQt5的4种基础布局管理

    在上一篇文章中,我们介绍了Qt for Python中主窗口控件MainWindow()的基本使用. 主窗口控件就像是房屋中的户型和结构,是一个图形界面程序最原始的荒地.在开辟了一个荒地之后,我们继续 ...

  5. Qt学习(九)—— 布局管理器

    目录 水平/垂直/网格布局 水平布局 垂直布局 网格布局 addWidget() addStretch() 没有布局的界面不仅不美观,窗口中的内容也难以对窗口的大小进行自适应,因此我们还需要学习Qt中 ...

  6. Python 小白从零开始 PyQt5 项目实战(5)布局管理

    本系列面向 Python 小白,从零开始实战解说应用 QtDesigner 进行 PyQt5 的项目实战. 什么叫从零开始?从软件安装.环境配置开始.不跳过一个细节,不漏掉一行代码,不省略一个例图. ...

  7. 菜单工具栏wxPython菜单与工具栏基础示例

    这两天一直在学习菜单工具栏之类的问题,上午正好有机会和大家讨论一下. 1.基本的api介绍 Package wx :: Class Menu Type Menu Method Summary Menu ...

  8. python布局管理_PyQt5每天必学之布局管理

    这篇文章主要为大家详细介绍了PyQt5每天必学之布局管理的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 在GUI编程中有一个不容忽视的部分,那就是布局管理.布局管理掌控着我们的控件在应用 ...

  9. 窗口管理器 实现_「42」Python布局管理器(三):place实现组件的精确与灵活布局...

    已经学习了两类布局管理器: Pack布局管理器:按照垂直或者水平的方向自然排布: Grid布局管理器:采用表格结构组织组件,组件位置受限表格形式. 两类管理器都属于那种很古板的布局方式,不能适应需要相 ...

最新文章

  1. 内核模式下的字符串操作
  2. XMPP文件传输(XEP-0096协议说明)
  3. Android、iOS平台RTMP/RTSP播放器实现实时音量调节
  4. mysql got signal 11_求助 mysqld got signal 11 解决办法
  5. LeetCode题目总结-滑窗法
  6. 大战设计模式【19】—— 享元模式
  7. 女生做产品经理好吗_你是一名合格的产品经理吗?
  8. cvs的console输出含义
  9. python画圆形螺旋线_中秋节到了,送你一个Python做的Crossin牌“月饼”
  10. 科大讯飞 asr 实时语音转写 rtasr 基于Netty编写的websocket client SDK
  11. 测试用例设计方法_场景法(游戏向)
  12. 在苹果Mac上怎样更改AirDrop名称?
  13. 人事经理常问的面试问题及答案
  14. 机器学习笔记 - 单位矩阵和逆矩阵
  15. 企业QQ屏蔽联系人后双方收不到信息
  16. python调用OpenCV和IOSAutoTouch实现硬件级免越狱自动化
  17. 重磅:第十二届中国西部国际资本论坛盛大举办,分布式存储行业备受瞩目!
  18. HACK彩虹易支付超完整源码+内附11个模板
  19. ie6浏览器下border边框线出现断裂问题解决方法
  20. pythonifelse简化_简化“if…elif..else”条件

热门文章

  1. 【Edge游览器设置全局Dark模式】
  2. 【优化布局】基于遗传算法求解物流多配送中心选址matlab代码
  3. U3D《真正的大冒险》(下)精讲教学
  4. 软件测试|RDBMS是什么意思,你搞懂了吗?
  5. TLS1.3抓包分析(2)——ServerHello
  6. JAVA知识梳理(日常整理)
  7. flex4兼容flex3
  8. 阿里妈妈牟娜:定向广告新一代点击率预估主模型——深度兴趣演化网络
  9. fftw的Windows版安装及遇到的问题
  10. 关于累加偶数奇数的c语言程序,C语言程序求1—100之间的奇数和和偶数和