PyQt 如何創(chuàng)建自定義QWidget
開發(fā)環(huán)境
Win7 PyCharm Python3.5.1 PyQt5
主要文件:
|-- main.py |-- res | `-- fish.jpg `-- ui `-- app_widget.py
main.py
import sys from PyQt5.QtWidgets import QApplication from ui.app_widget import AppQWidget if __name__ == '__main__': app = QApplication(sys.argv) w = AppQWidget() w.show() sys.exit(app.exec_())
app_main_window.py
自定義了一個(gè)居中顯示的窗口,關(guān)閉時(shí)彈確認(rèn)框
from PyQt5.QtCore import QCoreApplication
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import QWidget, QPushButton, QDesktopWidget, QMessageBox
class AppQWidget(QWidget):
"""
A custom QWidget by Rust Fisher
"""
def __init__(self):
super().__init__()
self.init_ui()
def init_ui(self):
# self.setGeometry(300, 300, 400, 200) # 相當(dāng)于move和resize
self.resize(300, 200)
self.move_to_center()
self.setWindowTitle('Demo1')
self.setWindowIcon(QIcon('res/fish.jpg'))
btn1 = QPushButton('Quit', self)
btn1.setToolTip('Click to quit')
btn1.resize(btn1.sizeHint())
btn1.move(200, 150)
btn1.clicked.connect(QCoreApplication.instance().quit) # cannot locate function connect
def closeEvent(self, event):
reply = QMessageBox.question(self, 'Message',
'Are you sure to quit now?',
QMessageBox.Yes | QMessageBox.No,
QMessageBox.No)
if reply == QMessageBox.Yes:
event.accept()
else:
event.ignore()
def move_to_center(self):
qr = self.frameGeometry()
cp = QDesktopWidget().availableGeometry().center() # got center info here
qr.moveCenter(cp)
self.move(qr.topLeft()) # 應(yīng)用窗口的左上方的點(diǎn)到qr矩形的左上方的點(diǎn),因此居中顯示在我們的屏幕上
Tips
多控件可以存在list中
存在一起,需要對整體操作時(shí)直接遍歷列表
# 同組的控件可以存在同一個(gè)list中 self.cb_list = [ self.ma.i2cCB, self.ma.mipiCB, self.ma.eepromCB, self.ma.tem_sensorCB, self.ma.lensCB, self.ma.vcmCB, self.ma.mirrorCB, self.ma.mirrorCaliCB, ] self.test_count_et_list = [ self.ma.i2cCountEt, self.ma.mipiCountEt, self.ma.eepromCountEt, self.ma.tem_sensorCountEt, self.ma.lensCountEt, self.ma.vcmCountEt, self.ma.mirrorCountEt, self.ma.mirrorCaliCountEt, ] # 需要操作某組控件時(shí) 直接遍歷列表 def _click_test_item_cb(self): """ Update [choose all checkbox] by all test item state """ choose_all = True for cb in self.cb_list: choose_all = choose_all & cb.isChecked() self.ma.selecteAllCB.setChecked(choose_all)
QApplication與QWidget
QApplication是一個(gè)單例,在QWidget中可以通過QApplication.instance()獲取到對象
實(shí)際上在實(shí)例化QApplication前就使用QtGui.QWidget()是會(huì)報(bào)錯(cuò)的
>>> QtGui.QWidget() QWidget: Must construct a QApplication before a QPaintDevice
參考 How QApplication() and QWidget() objects are connected in PySide/PyQt?
在我們自定義的QMainWindow中,也可以直接獲取到QApplication的實(shí)例。
class RustMainWindow(QMainWindow): """ This is the main class """ def _trigger_english(self): print "Change to English", QApplication.instance() # Change to English <PyQt4.QtGui.QApplication object at 0x02ABE3A0>
注意widget持有外部對象引用的問題
如果在程序啟動(dòng)的地方將引用交給widget,退出時(shí)會(huì)造成應(yīng)用無法關(guān)閉的問題(類似內(nèi)存泄漏)。
if __name__ == '__main__': app = QApplication(sys.argv) # 這里把a(bǔ)pp交給了MainWindow,MainWindow關(guān)閉時(shí)是無法正常退出應(yīng)用的 main_d = RustMainWindow(app) # 不建議這么做 main_d.show() sys.exit(app.exec_())
以上就是PyQt 如何創(chuàng)建自定義QWidget的詳細(xì)內(nèi)容,更多關(guān)于PyQt 創(chuàng)建自定義QWidget的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Linux下遠(yuǎn)程連接Jupyter+pyspark部署教程
這篇文章主要為大家詳細(xì)介紹了Linux下遠(yuǎn)程連接Jupyter+pyspark部署教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-06-06
如何使用django的MTV開發(fā)模式返回一個(gè)網(wǎng)頁
這篇文章主要介紹了如何使用django的MTV開發(fā)模式返回一個(gè)網(wǎng)頁,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
TensorFlow2基本操作之 張量排序 填充與復(fù)制 查找與替換
這篇文章主要介紹了TensorFlow2基本操作之 張量排序 填充與復(fù)制 查找與替換,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
使用IPython下的Net-SNMP來管理類UNIX系統(tǒng)的教程
這篇文章主要介紹了使用IPython下的Net-SNMP來管理類UNIX系統(tǒng)的教程,本文來自于IBM官方網(wǎng)站技術(shù)文檔,需要的朋友可以參考下2015-04-04
Python Numpy 控制臺(tái)完全輸出ndarray的實(shí)現(xiàn)
這篇文章主要介紹了Python Numpy 控制臺(tái)完全輸出ndarray的實(shí)現(xiàn)方式,希望給大家做個(gè)參考,一起跟隨小編過來看看吧2020-02-02
百分百成功的全網(wǎng)最簡約sklearn環(huán)境配置教程
這篇文章主要介紹了百分百成功的全網(wǎng)最簡約sklearn環(huán)境配置教程,圖文全流程講解包簡單易懂,百分百成功,需要的朋友可以參考下2023-03-03
Python設(shè)計(jì)模式行為型責(zé)任鏈模式
這篇文章主要介紹了Python設(shè)計(jì)模式行為型責(zé)任鏈模式,責(zé)任鏈模式將能處理請求的對象連成一條鏈,并沿著這條鏈傳遞該請求,直到有一個(gè)對象處理請求為止,避免請求的發(fā)送者和接收者之間的耦合關(guān)系,下圍繞改內(nèi)容介紹具有一點(diǎn)的參考價(jià)值,需要的朋友可以參考下2022-02-02
pycharm 主題theme設(shè)置調(diào)整仿sublime的方法
今天小編就為大家分享一篇pycharm 主題theme設(shè)置調(diào)整仿sublime的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05

