PyQt QMainWindow的使用示例
QMainWindow繼承自QWidget
QMainWindow相當于程序的主界面,內(nèi)置了menu和toolBar。
使用 Qt Designer 可以很方便地添加menu選項。
對于較大型的界面,用Qt Designer比較方便。.ui文件就像Android中使用xml一樣。
畫出的ui文件可以用PyQt中的PyUIC轉換成py文件。轉換后的py文件中有一個class。
新建一個繼承自QMainWindow的類,來調(diào)用生成的這個類。
主窗口關閉時,會調(diào)用closeEvent(self, *args, **kwargs),可復寫這個方法,加上一些關閉時的操作。
比如終止子線程,關閉數(shù)據(jù)庫接口,釋放資源等等操作。
PyQt5 手寫 QMainWindow 示例
Win7 PyCharm Python3.5.1 PyQt5
手寫一個main window,主要使用了菜單欄、文本編輯框、工具欄和狀態(tài)欄
|-- main.py |-- res | `-- sword.png `-- ui `-- app_main_window.py
main.py主文件
import sys from PyQt5.QtWidgets import QApplication from ui.app_main_window import AppMainWindow if __name__ == '__main__': app = QApplication(sys.argv) window = AppMainWindow() window.show() sys.exit(app.exec_())
app_main_window.py窗口實現(xiàn)文件
from PyQt5.QtCore import QCoreApplication from PyQt5.QtGui import QIcon from PyQt5.QtWidgets import QAction from PyQt5.QtWidgets import QMainWindow from PyQt5.QtWidgets import QTextEdit class AppMainWindow(QMainWindow): """ 菜單欄、文本編輯框、工具欄和狀態(tài)欄 """ def __init__(self): super().__init__() self.init_ui() def init_ui(self): # 菜單欄 self.statusBar().showMessage('Main window is ready') self.setGeometry(500, 500, 450, 220) self.setMinimumSize(150, 120) self.setWindowTitle('MainWindow') # 文本編輯框 text_edit = QTextEdit() self.setCentralWidget(text_edit) # 填充剩下的位置 # 定義退出動作 exit_action = QAction(QIcon('res/sword.png'), 'Exit', self) exit_action.setShortcut('Ctrl+Q') exit_action.setStatusTip('Exit App') # 鼠標指向選項時在窗口狀態(tài)欄出現(xiàn)的提示 # exit_action.triggered.connect(QCoreApplication.instance().quit) exit_action.triggered.connect(self.close) # 關閉app # 定義菜單欄,添加一個選項 menu_bar = self.menuBar() file_menu = menu_bar.addMenu('&File') file_menu.addAction(exit_action) # 定義工具欄,添加一個退出動作 toolbar = self.addToolBar('&Exit') toolbar.addAction(exit_action)
有的時候PyCharm給的代碼提示不完全。網(wǎng)上說PyCharm配合vim插件來使用能帶來很好的體驗。
生成的界面中,工具欄可以自由的拖動,可以放在上下左右4個地方。
同樣的代碼,可以很方便地移植到PyQt4中。
使用designer畫出來的界面
Ubuntu
使用designer繪制好界面后,講ui文件轉換成py代碼。
import sys from PyQt5.QtWidgets import QMainWindow, QApplication from ui_main_window import Ui_UAppMainWindow class RustMainWindow(QMainWindow): """主界面類""" def __init__(self): super(RustMainWindow, self).__init__() self.ma = Ui_UAppMainWindow() # designer畫的界面 self.ma.setupUi(self) if __name__ == "__main__": app = QApplication(sys.argv) main_window = RustMainWindow() main_window.show() sys.exit(app.exec_())
復寫__init__初始化方法時需要調(diào)用父類方法
PyQt4手寫窗口代碼
和上面那個功能類似。
import sys from PyQt4.QtGui import QMainWindow, QTextEdit, QAction, QIcon, QApplication class AppMainWindow(QMainWindow): def __init__(self): super(AppMainWindow, self).__init__() self.init_ui() def init_ui(self): self.statusBar().showMessage('Main window is ready') self.setGeometry(500, 500, 450, 220) self.setMinimumSize(150, 120) self.setWindowTitle('MainWindow') text_edit = QTextEdit() self.setCentralWidget(text_edit) exit_action = QAction(QIcon('res/ic_s1.png'), 'Exit', self) exit_action.setShortcut('Ctrl+Q') exit_action.setStatusTip('Exit App') exit_action.triggered.connect(self.close) menu_bar = self.menuBar() file_menu = menu_bar.addMenu('&File') file_menu.addAction(exit_action) toolbar = self.addToolBar('&Exit') toolbar.addAction(exit_action) if __name__ == '__main__': app = QApplication(sys.argv) window = AppMainWindow() window.show() sys.exit(app.exec_())
可以看出,PyQt4 和 5 的代碼基本上是通用的。復寫__init__的方法不同。
以上就是PyQt QMainWindow的使用示例的詳細內(nèi)容,更多關于PyQt QMainWindow的使用的資料請關注腳本之家其它相關文章!
相關文章
Python安裝Numpy出現(xiàn)異常信息簡單解決辦法
在安裝Python的Numpy包時,可能會遇到路徑警告或包源超時的問題,首先,如果出現(xiàn)包源超時,可以嘗試更換為國內(nèi)的鏡像源,如清華大學鏡像源,其次,如果在安裝完成后提示將某個路徑添加到PATH環(huán)境變量,按照提示操作即可消除異常,需要的朋友可以參考下2024-09-09python中的torch常用tensor處理函數(shù)示例詳解
這篇文章主要介紹了python中的torch常用tensor處理函數(shù),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07