這篇文章將為大家詳細(xì)講解有關(guān)PyQt5項(xiàng)目中無邊框后窗口出現(xiàn)移動(dòng)問題如何解決,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
創(chuàng)新互聯(lián)主要從事網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)銅山,10年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18980820575第一步:判斷鼠標(biāo)左鍵是否被按下,如果按下則將flag設(shè)為True并獲取當(dāng)前的位置
第二步:判斷鼠標(biāo)是否移動(dòng)并且左鍵被按下,若移動(dòng)了計(jì)算移動(dòng)的距離在移動(dòng)窗口
第三步:若鼠標(biāo)釋放了則將flag設(shè)為False
def mousePressEvent(self, event): if event.button()==Qt.LeftButton: self.m_flag=True self.m_Position=event.globalPos()-self.pos() #獲取鼠標(biāo)相對(duì)窗口的位置 event.accept() self.setCursor(QCursor(Qt.OpenHandCursor)) #更改鼠標(biāo)圖標(biāo) def mouseMoveEvent(self, QMouseEvent): if Qt.LeftButton and self.m_flag: self.move(QMouseEvent.globalPos()-self.m_Position)#更改窗口位置 QMouseEvent.accept() def mouseReleaseEvent(self, QMouseEvent): self.m_flag=False self.setCursor(QCursor(Qt.ArrowCursor))
最后最小化和關(guān)閉可以設(shè)置兩個(gè)按鈕,通過點(diǎn)擊按鈕來觸發(fā)
@pyqtSlot() def on_pushButton_clicked(self): """ 關(guān)閉窗口 """ self.close() @pyqtSlot() def on_pushButton_2_clicked(self): """ 最小化窗口 """ self.showMinimized()
ps :設(shè)置無邊框和背景透明
# 設(shè)置窗體無邊框 # self.setWindowFlags(Qt.FramelessWindowHint) # 設(shè)置背景透明 # self.setAttribute(Qt.WA_TranslucentBackground)
效果圖
win10自帶的錄屏只能錄當(dāng)前軟件那個(gè)區(qū)域。。。。。。。
就這樣吧~
補(bǔ)充:pyqt5_控件_自定義無邊框窗體拖動(dòng)
我就廢話不多說了,大家還是直接看代碼吧~
from PyQt5.QtWidgets import * from PyQt5.QtCore import * from PyQt5.QtGui import * import sys class Example(QWidget): _startPos = None _endPos = None _isTracking = False def __init__(self): super().__init__() self._initUI() def _initUI(self): self.setFixedSize(QSize(400, 400)) self.setWindowFlags(Qt.FramelessWindowHint) # 無邊框 self.show() def mouseMoveEvent(self, e: QMouseEvent): # 重寫移動(dòng)事件 self._endPos = e.pos() - self._startPos self.move(self.pos() + self._endPos) def mousePressEvent(self, e: QMouseEvent): if e.button() == Qt.LeftButton: self._isTracking = True self._startPos = QPoint(e.x(), e.y()) def mouseReleaseEvent(self, e: QMouseEvent): if e.button() == Qt.LeftButton: self._isTracking = False self._startPos = None self._endPos = None if __name__ == '__main__': app = QApplication(sys.argv) ex = Example() sys.exit(app.exec_())
關(guān)于PyQt5項(xiàng)目中無邊框后窗口出現(xiàn)移動(dòng)問題如何解決就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。