PyQt4教程 – 03 PyQt4中的菜单和工具栏

本文介绍如何使用PyQt创建包含菜单栏、工具栏和状态栏的主应用程序窗体。通过具体示例代码展示了各组件的基本用法及如何集成。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原作:ZetCode
翻译:单手拍掌
欢迎转载,转载时请保留完整的版权说明

主窗体

QMainWindow类提供了一个主应用程序窗体,这就能够创建一个具有状态栏、工具栏和菜单栏的经典应用框架。

状态栏

状态栏是一个显示状态信息的部件。

#!/usr/bin/python
# statusbar.py
import sys
from PyQt4 import QtGui

class MainWindow(QtGui.QMainWindow):
    def __init__(self):
        QtGui.QMainWindow.__init__(self)
        self.resize(250, 150)
        self.setWindowTitle('statusbar')

        self.statusBar().showMessage('Ready')

app = QtGui.QApplication(sys.argv)
main = MainWindow()
main.show()
sys.exit(app.exec_())

 self.statusBar().showMessage('Ready')

为了获得状态栏,我们调用了QApplication类statusBar()方法。showMessage()在状态栏上显示信息。

Menubar

菜单栏是GUI应用程序的最明显部分之一,它是一个各组命令放置的地方。在控制台应用程序中,你必须记住所有这些神秘的命令,而在这里绝大多数命令按逻辑分组。这种标准使用方式,能大量减少学习使用新应用程序的时间花费。

#!/usr/bin/python

# menubar.py 

import sys
from PyQt4 import QtGui, QtCore

class MainWindow(QtGui.QMainWindow):
    def __init__(self):
        QtGui.QMainWindow.__init__(self)

        self.resize(250, 150)
        self.setWindowTitle('menubar')

        exit = QtGui.QAction(QtGui.QIcon('icons/exit.png'), 'Exit', self)
        exit.setShortcut('Ctrl+Q')
        exit.setStatusTip('Exit application')
        self.connect(exit, QtCore.SIGNAL('triggered()'), QtCore.SLOT('close()'))

        self.statusBar()

        menubar = self.menuBar()
        file = menubar.addMenu('&File')
        file.addAction(exit)

app = QtGui.QApplication(sys.argv)
main = MainWindow()
main.show()
sys.exit(app.exec_())

 menubar = self.menuBar()
 file = menubar.addMenu('&File')
 file.addAction(exit)

首先,我们用QMainWindow类的menuBar()方法创建一个菜单,然后用AddMenu()方法增加一个菜单,最后插入动作对象到文件菜单。

工具栏

菜单把应用程序中所有命令分组,工具栏则提供最常用命令的快速访问。

#!/usr/bin/python

# toolbar.py 

import sys
from PyQt4 import QtGui, QtCore

class MainWindow(QtGui.QMainWindow):
    def __init__(self):
        QtGui.QMainWindow.__init__(self)

        self.resize(250, 150)
        self.setWindowTitle('toolbar')

        self.exit = QtGui.QAction(QtGui.QIcon('icons/exit.png'), 'Exit', self)
        self.exit.setShortcut('Ctrl+Q')
        self.connect(self.exit, QtCore.SIGNAL('triggered()'), QtCore.SLOT('close()'))
SLOT('close()'))
        self.toolbar = self.addToolBar('Exit')
        self.toolbar.addAction(self.exit)


app = QtGui.QApplication(sys.argv)
main = MainWindow()
main.show()
sys.exit(app.exec_())
 self.exit = QtGui.QAction(QtGui.QIcon('icons/exit.png'), 'Exit', self)
 self.exit.setShortcut('Ctrl+Q')

GUI应用程序用命令控制,这些命令可以从菜单、关联菜单、工具栏和快捷方式启动。PyQt引入的actions简化了开发。一个action对象可以有菜单文字,一个图标,快捷方式,状态文字,“这是什么?”文字和工具提示。在我们的例子,我们定义了一个有图标、工具提示和快捷方式的action对象。

 self.connect(self.exit, QtCore.SIGNAL('triggered()'), QtCore.SLOT('close()'))

在这里,我们连接action的triggered()信号到预定义close()插槽上。

 self.toolbar = self.addToolBar('Exit')
 self.toolbar.addAction(self.exit)

在这里,我们创建一个工具栏并将为其增加了一个action对象。


工具栏
图:toolbar
 

将其组合在一起

在本节的最后一个例子,我们将创建同时具有一个菜单栏,工具栏和状态栏应用程序,我们同时还将建立一个主要部件。

#!/usr/bin/python

# mainwindow.py 

import sys
from PyQt4 import QtGui, QtCore

class MainWindow(QtGui.QMainWindow):
    def __init__(self):
        QtGui.QMainWindow.__init__(self)

        self.resize(350, 250)
        self.setWindowTitle('mainwindow')

        textEdit = QtGui.QTextEdit()        self.setCentralWidget(textEdit)

        exit = QtGui.QAction(QtGui.QIcon('icons/exit.png'), 'Exit', self)
        exit.setShortcut('Ctrl+Q')
        exit.setStatusTip('Exit application')
        self.connect(exit, QtCore.SIGNAL('triggered()'), QtCore.SLOT('close()'))

        self.statusBar()

        menubar = self.menuBar()
        file = menubar.addMenu('&File')
        file.addAction(exit)

        toolbar = self.addToolBar('Exit')
        toolbar.addAction(exit)


app = QtGui.QApplication(sys.argv)
main = MainWindow()
main.show()

sys.exit(app.exec_())

 textEdit = QtGui.QTextEdit()
 self.setCentralWidget(textEdit)

在这里,我们创建一个文本编辑部件,并将其设置为QMainWindow的主要部件,主要部件将占据所有剩下的空间。


主窗口
图:mainwindow
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值