PyQt5 QDockWidget控件應用詳解
更新時間:2020年08月12日 09:58:29 作者:只想整天學習
這篇文章主要介紹了PyQt5 QDockWidget控件應用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
前言
QDockWidget是一個可以??吭赒MainWindow內(nèi)的窗口控件,它可以保持在浮動狀態(tài)或者在指定位置作為子窗口附加到主窗口中,QMainWindow類的主窗口對象保留有一個用于??看翱诘膮^(qū)域,這個區(qū)域在控件的中央周圍
QDoCKWidget類中的常用方法
方法 | 描述 |
---|---|
setWidget() | 在Dock窗口區(qū)域設置QWidget |
setFloating() | 設置Dock窗口是否可以浮動,如果設置為True,則表示可以浮動 |
setAlllowedAreas() | 設置窗口可以??康膮^(qū)域 |
LeftDockWidgetArea:左側(cè)??繀^(qū)域 | |
RightDockWidgetArea:右側(cè)??繀^(qū)域 | |
TopDockWidgetArea:頂部??繀^(qū)域 | |
BottomDockWidgetArea:底部??繀^(qū)域 | |
NoDockWidgetArea:不顯示W(wǎng)idget | |
setFearures() | 設置??看翱诘墓δ軐傩?/td> |
DockWidgetClosable:可關閉 | |
DockWidgetMovable:可移動 | |
DockWidgetFloatable:可漂浮 | |
DockWidgetVerticalTitleBar:在左邊顯示垂直的標簽欄 | |
AllDockWidgetFeatures:具有前三種屬性的所有功能 | |
NoDockWidgetFeatures:無法關閉,不能懸浮,不能移動 |
實例:QDockWidget的使用
import sys from PyQt5.QtCore import * from PyQt5.QtGui import * from PyQt5.QtWidgets import * class DockDemo(QMainWindow): def __init__(self,parent=None): super(DockDemo, self).__init__(parent) #設置水平布局 layout=QHBoxLayout() #實例化菜單欄 bar=self.menuBar() #創(chuàng)建主菜單file,在其中添加子菜單 file=bar.addMenu('File') file.addAction('New') file.addAction('Save') file.addAction('quit') #創(chuàng)建QDockWidget窗口(標題,自身窗口) self.items=QDockWidget('Dockable',self) #實例化列表窗口,添加幾個條目 self.listWidget=QListWidget() self.listWidget.addItem('Item1') self.listWidget.addItem('Item2') self.listWidget.addItem('Item3') self.listWidget.addItem('Item4') #在窗口區(qū)域設置QWidget,添加列表控件 self.items.setWidget(self.listWidget) #設置dock窗口是否可以浮動,True,運行浮動在外面,自動與主界面脫離,F(xiàn)alse,默認浮動主窗口內(nèi),可以手動脫離 self.items.setFloating(False) #設置QTextEdit為中央小控件 self.setCentralWidget(QTextEdit()) #將窗口放置在中央小控件的右側(cè) self.addDockWidget(Qt.RightDockWidgetArea,self.items) self.setLayout(layout) self.setWindowTitle('Dock 例子') if __name__ == '__main__': app=QApplication(sys.argv) demo=DockDemo() demo.show() sys.exit(app.exec_())
不重寫QDockWidget類
import sys from PyQt5.QtCore import * from PyQt5.QtWidgets import QMainWindow, QTextEdit, QDockWidget, QPushButton, QApplication class DockDemo(QMainWindow): def __init__(self): super().__init__() self.docker1=QDockWidget('Docker1', self) self.docker2=QDockWidget('Docker2', self) self.textEdit=QTextEdit() self.setCentralWidget(self.textEdit) self.btn1=QPushButton('btn1') self.btn2=QPushButton('btn2') self.btn1.clicked.connect(self.btn1fun) self.btn2.clicked.connect(self.btn2fun) self.docker1.setWidget(self.btn1) self.docker2.setWidget(self.btn2) self.addDockWidget(Qt.RightDockWidgetArea,self.docker1) self.addDockWidget(Qt.LeftDockWidgetArea, self.docker2) self.setWindowTitle('Dock 例子') self.resize(400, 300) def btn1fun(self): self.textEdit.setText('btn1') self.docker2.setFloating(True)#開啟懸浮狀態(tài) def btn2fun(self): self.textEdit.setText('btn2') self.docker1.setFloating(True) if __name__ == '__main__': app=QApplication(sys.argv) demo=DockDemo() demo.show() sys.exit(app.exec_())
效果:
重寫QDockWidget類
import sys from PyQt5.QtCore import * from PyQt5.QtWidgets import QMainWindow, QTextEdit, QDockWidget, QPushButton, QApplication, QWidget, QVBoxLayout class docker(QDockWidget): def __init__(self, parent): super().__init__(parent) self.btn1 = QPushButton('btn1') self.btn2 = QPushButton('btn2') self.vbox = QVBoxLayout() self.vbox.addWidget(self.btn1) self.vbox.addWidget(self.btn2) self.wgt = QWidget() self.wgt.setLayout(self.vbox) self.setWidget(self.wgt) class DockDemo(QMainWindow): def __init__(self): super().__init__() self.docker = docker(self) self.textEdit = QTextEdit() self.setCentralWidget(self.textEdit) self.docker.btn1.clicked.connect(self.btn1fun) self.docker.btn2.clicked.connect(self.btn2fun) self.addDockWidget(Qt.RightDockWidgetArea, self.docker) self.setWindowTitle('Dock 例子') self.resize(400, 300) def btn1fun(self): self.textEdit.setText('btn1') def btn2fun(self): self.textEdit.setText('btn2') if __name__ == '__main__': app = QApplication(sys.argv) demo = DockDemo() demo.show() sys.exit(app.exec_())
效果:
到此這篇關于PyQt5 QDockWidget控件應用詳解的文章就介紹到這了,更多相關PyQt5 QDockWidget內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章: