python界面设计实例qt_Python+PyQt架构:使用设计师编写界面程序入门示例

PyQt是Qt界面库在Python下的绑定,为在Python语言下编写GUI界面程序提供了极大的便利。对于界面程序的设计,可以使用代码构建,也可以借助于其提供的设计师(Qt Designer)工具来构建。

下面给出一个在Python语言中使用PyQt界面库及设计师工具编写界面程序的入门例子。

例子说明

该例运行界面如下图所示,包括了常用软件界面必备的几个区域部分:菜单栏、工具栏、状态栏及主窗口显示区域,其中,主窗口显示区域使用水平及垂直分割条控件以左一右二的形式分为了三个窗口部分。

u=1056367763,1128029813&fm=173&app=49&f=JPEG?w=539&h=365&s=4010CD380B4E7D4B027540DB0200D0B3

工具栏的显示样式可通过菜单设置为“仅显示图标”或“显示图标和文字”两种样式。另外,通过点击工具栏上窗口视图的下拉菜单可设置右面两个窗口的显示或隐藏状态。

下面看下怎么在设计师(Qt Designer)中来实现这个界面程序的设计。

前提条件

假定你使用的IDE是PyCharm,并且已经配置了如下图所示三个常用工具:

u=550491003,1572813152&fm=173&app=49&f=JPEG?w=554&h=331&s=A842D51017584DC8544164DE030080B2

具体的配置方法可参考前面的文章:

这三个常用工具都可以在PyCharm的右键菜单中操作,功能简要说明如下:

Qt Designer:可以在PyCharm中开发环境中快速打开设计师(Qt Designer)工具。

PyUIC:将Qt Designer设计的“.ui”界面文件转换成“.py”文件。

Rcc2Py:将Qt Designer设计中用到的资源文件“.qrc”文件转换成“.py”文件。

软件界面使用设计师(Qt Designer)工具的设计过程

1、新建UI文件

打开设计师,新建一个窗体,模板选择为Main Window,如下图所示,并保存为“Main.ui”文件:

u=990412452,879962122&fm=173&app=49&f=JPEG?w=513&h=472&s=C800C418518F714D46F41CD9020030B2

2、新建资源文件

在设计师的资源浏览器中新建一个资源文件保存名称为“MyRes.qrc”,将本例界面中用到的图标等资源文件添加到该文件中,如下图所示(前缀设置为空,图标文件保存在当前程序所在目录的img子文件夹下):

u=3290745626,1758106121&fm=173&app=49&f=JPEG?w=518&h=257&s=44104530174855494CFD5CDF030080B2

3、在动作编辑器编辑各种action

菜单栏、工具栏上的大部分功能都可以通过动作编辑器完成,可以设置每个action的名称、文本、快捷键、是否可选、工具提示等信息,本例中动作编辑完成后如下图所示:

u=1277997904,603117884&fm=173&app=49&f=JPEG?w=640&h=247&s=CD40CD18DD79480B0E7574CA0300D0B3

4、菜单栏设计

通过拖放前面创建的action,可在设计师中完成菜单栏的设计,对于本例,设计完成后文件、选项-工具栏样式及选项-窗口视图菜单项分别如下图所示:

u=413234887,667681914&fm=173&app=49&f=JPEG?w=640&h=108&s=C852C518CD66572056F44CC80300C0B3

5、工具栏设计

同菜单栏设计过程类似通过拖放前面创建的action完成工具栏的设计,本例中工具栏编辑完成后如下图所示:

u=3481438532,1495077320&fm=173&app=49&f=JPEG?w=530&h=57

需要说明的是,本例工具栏还包括一个带下拉菜单的QToolButton控件,在设计师中不能直接将其放到工具栏区域中,后面需在代码中手动创建该控件。

6、状态栏设计

本例状态栏比较简单,只在状态栏中添加一个QLabel控件作一个简单的信息显示即可。同样,在设计师中不能直接将QLabel控件放到状态栏区域中,后面需在代码中手动创建该控件。

7、主显示区域设计

本例中,主显示区域分为左一右二的三个窗口,使用分割条进行布局。为简单起见,本例使用三个“Plain Text Edit”控件作为显示窗口。在设计师中拖放三个状态栏“Plain Text Edit”控件到主窗口区域中,分别命名为leftWnd、rightWnd1和rightWnd2,同时,在属性编辑器设置三个控件的plainText属性分别为左窗口、右窗口1、右窗口2。然后选中rightWnd1和rightWnd2,在设计师中选择“使用分裂器垂直布局”,完成右面两个窗口的垂直布局。然后再选中这个垂直布局和leftWnd窗口,在设计师中选择“使用分裂器水平布局”,这样使用水平分割条完成了整个界面左、右两部分的水平布局。如下图所示:

u=3147184218,2757679127&fm=173&app=49&f=JPEG?w=540&h=407&s=5010C538432E650B1A7584CB0200C0B3

8、信号/槽的设计

在设计师的信号/槽编辑器中可完成信号与槽函数的关联,对于本例,将动作actExit关联到主窗口的关闭事件中,这样,在工具栏中点击退出按钮时,可退出该程序,如下图所示:

u=2776784000,1128705001&fm=173&app=49&f=JPEG?w=455&h=138&s=4C42D510D1786820405931D30300D0B2

至此,在设计师中完成了整个界面的设计,保存文件。该界面中涉及到的所有界面对象元素如下图所示:

u=1400319917,3689223037&fm=173&app=49&f=JPEG?w=451&h=546&s=C900C51259BFD0CE5CD5A0DB030080B1

界面文件至Python文件的转换

在设计师中界面设计完成后,我们得到了两个文件:“Main.ui”界面文件和“MyRes.qrc”资源文件,需将这两个文件转换为Python能够识别的文件,这就用到了前面提到的已经集成好的两个工具“PyUIC”和“Rcc2Py”。

在PyCharm开发环境中,选中这两个文件,在右键菜单中分别选择“PyQt4-->PyUIC”和“PyQt4-->Rcc2Py”即可完成这两个文件的转换。

转换完成后,生成了两个新的文件,分别为界面文件“Ui_Main.py”和资源文件“MyRes_rc.py”。

其中,“Ui_Main.py”文件中主要定义了一个界面布局类“Ui_MainWindow”,在该类中,会自动导入“MyRes_rc.py”的内容。

主程序“Main.py”的编写

在PyCharm开发环境中新建一个Python文件“Main.py”。其调用界面文件的主要思路为:

定义一个类MainWindow,继承自QMainWindow和Ui_MainWindow类,在该类中实现设计师中不能完成的界面元素,如本例中工具栏上的下拉菜单按钮和状态栏上的label控件等,实现信号与槽函数的关联,完成槽函数的实现。

MainWindow类的具体实现代码如下图所示:

u=564846548,4217851609&fm=173&app=49&f=JPEG?w=640&h=679&s=BA87A54CD2B7866F4E50540A000070C0

对上述代码说明如下:

第16-45行,类的初始化函数。

第20-36行,添加设计师中不能完成的界面元素,详细请参考注释。

第38-40行,实现两个动作与槽函数的关联,用以设置工具栏的样式和右边两个窗口是否可见。

第42-45行,设置主分割条mainSplitter的左右两边的比例,并将其设置为主窗口的中心部件。

第47-57行,两个槽函数的具体实现。

程序的完整测试代码如下图所示:

u=2521098976,650582574&fm=173&app=49&f=JPEG?w=628&h=389&s=BA85E1481AA4B16C0CFDC50F0000E0C3

程序运行后,即可看到本文开头的提到的界面运行图。

备注

本例开发环境配置:Python2.7 + PyQt4。

如果你觉得这篇文章对你有用的话,抖抖小手点个赞吧。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以回答你的问题。对于Python软件页面制作入门使用PyQt架构可以非常方便地实现界面程序。以下是一个入门示例,介绍如何使用PyQt设计师创建简单的界面程序。 1. 安装PyQt 首先,你需要安装PyQt。你可以使用pip进行安装: ``` pip install pyqt5 ``` 2. 创建一个界面程序 PyQt提供了Qt Designer,一个强大的可视化工具,可以帮助你创建和编辑界面。你可以使用Qt Designer来创建一个简单的界面程序。 在Qt Designer中,你可以添加各种控件,例如按钮、标签和文本框等。在这个示例中,我们将添加一个标签和一个按钮。 3. 将界面程序导出到Python文件 完成界面程序的设计后,你需要将其导出到Python代码中。在Qt Designer中,你可以选择“文件”>“导出”,然后选择“Python代码”作为导出类型。然后,你可以将导出的代码保存到一个.py文件中。 4. 编写Python代码 使用PyQt编写Python代码,将界面程序与功能代码相结合。在这个示例中,我们将在按钮单击时显示一个消息框。 ```python import sys from PyQt5.QtWidgets import QApplication, QMainWindow, QMessageBox from ui_mainwindow import Ui_MainWindow class MainWindow(QMainWindow): def __init__(self): super().__init__() self.ui = Ui_MainWindow() self.ui.setupUi(self) self.ui.pushButton.clicked.connect(self.show_message_box) def show_message_box(self): QMessageBox.information(self, "提示", "你单击了按钮!") if __name__ == "__main__": app = QApplication(sys.argv) window = MainWindow() window.show() sys.exit(app.exec_()) ``` 在这个示例中,我们首先导入QApplication、QMainWindow和QMessageBox类,以及从Qt Designer导出的UI类。 接下来,我们创建一个MainWindow类,继承自QMainWindow,并在其中初始化UI界面。我们还使用connect()函数将按钮的单击事件连接到一个名为show_message_box()的函数上。 最后,我们创建一个QApplication实例,并将MainWindow实例显示出来。在应用程序退出时,我们调用sys.exit()函数。 5. 运行程序 现在,你可以运行程序并测试它是否能正常工作。在命令行中,进入包含你的Python文件的目录,并输入以下命令: ``` python main.py ``` 你应该能够看到一个包含一个标签和一个按钮的窗口。当你单击按钮时,应该会显示一个消息框。 这就是如何使用PyQtQt Designer创建简单的界面程序入门示例。希望这对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值