亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PyQt5 關(guān)于Qt Designer的初步應(yīng)用和打包過(guò)程詳解

 更新時(shí)間:2021年09月26日 09:30:35   作者:氫鍵H-H  
Qt Designer中的操作方式十分靈活,其通過(guò)拖拽的方式放置控件可以隨時(shí)查看控件效果。這篇文章主要介紹了PyQt5 關(guān)于Qt Designer的初步應(yīng)用和打包,需要的朋友可以參考下

Qt Designer的介紹

在PyQt中編寫UI界面可以直接通過(guò)代碼來(lái)實(shí)現(xiàn),也可以通過(guò)Qt Designer來(lái)完成。Qt Designer的設(shè)計(jì)符合MVC的架構(gòu),其實(shí)現(xiàn)了視圖和邏輯的分離,從而實(shí)現(xiàn)了開發(fā)的便捷。Qt Designer中的操作方式十分靈活,其通過(guò)拖拽的方式放置控件可以隨時(shí)查看控件效果。Qt Designer生成的.ui文件(實(shí)質(zhì)上是XML格式的文件)也可以通過(guò)pyuic5工具轉(zhuǎn)換成.py文件。 Qt Designer隨PyQt5-tools包一起安裝,其安裝路徑在 “Python安裝路徑\Lib\site-packages\pyqt5-tools”下。若要啟動(dòng)Qt Designer可以直接到上述目錄下,雙擊designer.exe打開Qt Designer;或?qū)⑸鲜雎窂郊尤氕h(huán)境變量,在命令行輸入designer打開;或在PyCharm中將其配置為外部工具打開。下面以PyCharm為例,講述PyCharm中Qt Designer的配置方法。

機(jī)器人開發(fā)之路總會(huì)有很多的艱難險(xiǎn)阻,但雖然辛苦,還是選擇了那種滾燙的人生。很幸運(yùn),獲得了機(jī)器人開發(fā)領(lǐng)域優(yōu)質(zhì)創(chuàng)作者身份認(rèn)證。征途漫漫,惟有奮斗,共勉!

1. 緣由

開發(fā)過(guò)程中,難免需要自己手動(dòng)開發(fā)一些交互工具簡(jiǎn)單的如自動(dòng)化腳本復(fù)雜一點(diǎn)的呢就是帶界面交互的應(yīng)用軟件了

QT呢就是一款很受歡迎的圖形用戶界面應(yīng)用程序開發(fā)框架只寵Python的搬運(yùn)工,就需要Python和Qt庫(kù)融合的工具,它就是 PyQt5

在PyQt中編寫UI界面可以直接通過(guò)代碼來(lái)實(shí)現(xiàn),也可以通過(guò)Qt Designer來(lái)完成其實(shí)現(xiàn)了視圖和邏輯的分離,從而實(shí)現(xiàn)了開發(fā)的便捷

2. 搭建

2.1. 安裝

若未安裝pyqt5,則需先安裝:

$ pip3 install pyqt5

然后安裝常用工具:

$ pip3 install pyqt5-tools pyinstaller

pyqt5和pyinstaller有版本對(duì)應(yīng)關(guān)系,推薦同時(shí)期安裝,如果版本偏差,會(huì)導(dǎo)致pyinstaller打包一直失敗。

2.2. 打開

找到 Qt Designer 應(yīng)用程序啟動(dòng)文件,這邊的地址是對(duì)應(yīng)Python目錄下的 \Lib\site-packages\qt5_applications\Qt\bin\designer.exe

在這里插入圖片描述 

可以添加桌面快捷方式方便后續(xù)打開

打開 designer.exe

在這里插入圖片描述 

創(chuàng)建新的Form給出了5個(gè)模板,但實(shí)際上只有3種不同類型的模板,分別是Dialog、Main Window和Widget

  • Main Window 主界面

一個(gè)窗口是父/子的頂部,通常顯示標(biāo)題欄和邊框。底層窗口系統(tǒng)(Windows、KDE、GNOME等)將為窗口提供策略,如標(biāo)題欄/邊框樣式、布局和焦點(diǎn)等。

  • Widget 小部件

屏幕上的一個(gè)矩形區(qū)域,用于顯示和用戶交互,包括按鈕、滑塊、視圖、對(duì)話框和窗口等。所有窗口小部件將在屏幕上顯示某些內(nèi)容,許多窗口小部件也將接受來(lái)自鍵盤或鼠標(biāo)的用戶輸入。

  • Dialog 對(duì)話框

通常是臨時(shí)的,可以設(shè)置不同的標(biāo)題欄外觀,主要用于通知或收集輸入窗口,并且底部或右側(cè)通常具有OK、Cancel等按鈕。

這里選擇創(chuàng)建一個(gè)Main Window

在這里插入圖片描述

在QT Designer界面里分為5個(gè)區(qū)域,正中間區(qū)域是軟件設(shè)計(jì)的界面,左右兩側(cè)是功能區(qū)域,功能區(qū)域的說(shuō)明如下:

  • Widget Box:控件區(qū),軟件的功能控件都在此區(qū)域生成,可以拉拽控件到模板上實(shí)現(xiàn)可視化軟件設(shè)計(jì)。
  • 對(duì)象查看器:軟件的目錄結(jié)構(gòu),顯示模板中所有控件的類型,能幫助設(shè)計(jì)者快速找到控件。
  • 屬性編輯器:控件屬性區(qū),主要修改控件的屬性。
  • 信號(hào)/槽編輯器:對(duì)象間的通信機(jī)制。如單擊按鈕(信號(hào) Signal)時(shí)候所觸發(fā)的事件(槽 Slot)。

2.3. 設(shè)計(jì)

拉拽個(gè)按鈕控件,并保存為csdn.ui

在這里插入圖片描述

2.4. 轉(zhuǎn)換

打開剛剛保存的ui文件,可以發(fā)現(xiàn)其實(shí)也就是XML文件

在這里插入圖片描述

現(xiàn)在需要通過(guò)工具轉(zhuǎn)換成py文件

$ pyuic5 源文件.ui -o 目標(biāo)文件.py

即:

$ pyuic5 .\csdn.ui -o .\csdn.py

推薦作為py腳本,方便后續(xù)或批量轉(zhuǎn)換

在這里插入圖片描述

3. 效果

3.1. 引用

創(chuàng)建一個(gè)邏輯文件logic.py

import sys
from PyQt5.QtWidgets import QApplication, QMainWindow
from csdn import Ui_MainWindow


class MyWindow(QMainWindow, Ui_MainWindow):
    def __init__(self):
        super(MyWindow, self).__init__()
        self.setupUi(self)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    myWin = MyWindow()
    myWin.show()
    sys.exit(app.exec_())

通過(guò)上述代碼,繼承了Ui_MainWindow類,使用其構(gòu)造方法構(gòu)造主窗口并定義了程序的入口,通過(guò)創(chuàng)建QApplication對(duì)象來(lái)創(chuàng)建Qt窗口

3.2. 啟動(dòng)

啟動(dòng)logic.py文件

在這里插入圖片描述

3.3. 打包

可以通過(guò)pyinstaller進(jìn)行打包

普通

$ pyinstaller -w logic.py

在dist文件夾內(nèi)生成工程文件夾 logic,尋找logic.exe文件啟動(dòng)

在這里插入圖片描述

整合

$ pyinstaller -F -w logic.py

在dist文件夾內(nèi)生成logic.exe整合文件,點(diǎn)擊啟動(dòng)(啟動(dòng)較久)

在這里插入圖片描述

配置信息在執(zhí)行以上兩種打包時(shí)候,會(huì)產(chǎn)生.spec配置文件,可以通過(guò)調(diào)整配置文件執(zhí)行打包

$ pyinstaller logic.spec

3.4. 觸發(fā)

使用connect()方法將信號(hào)與槽函數(shù)綁定在一起當(dāng)信號(hào)發(fā)射時(shí),連接槽函數(shù)將會(huì)自動(dòng)執(zhí)行

如把點(diǎn)擊pushButton按鈕作為一個(gè)信號(hào)

class MyWindow(QMainWindow, Ui_MainWindow):
    def __init__(self):
        super(MyWindow, self).__init__()
        self.setupUi(self)
        # 將pushButton信號(hào)與槽函數(shù)touch_button綁定
        self.pushButton.clicked.connect(self.touch_button)

    def touch_button(self):
        print('點(diǎn)擊按鈕了')

此時(shí)點(diǎn)擊按鈕,可看到終端顯示提示了

在這里插入圖片描述

到此這篇關(guān)于PyQt5 關(guān)于Qt Designer的初步應(yīng)用和打包的文章就介紹到這了,更多相關(guān)Qt Designer應(yīng)用打包內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論