一文詳解PyQt5中實現不規(guī)則窗口的顯示
更新時間:2022年12月01日 14:08:52 作者:SongYuLong的博客
這篇文章主要為大家詳細介紹了Python?PyQt5中實現不規(guī)則窗口的顯示的相關資料,文中的示例代碼講解詳細,具有一定的借鑒價值,需要的可以參考一下
PyQt5 不規(guī)則窗口的顯示
| 函數 | 描述 |
|---|---|
| setMask(self, QBitmap) setMask(self, QRegion) | setMask()的作用是為調用它的控件增加一個遮罩,遮住所選區(qū)域以外的部分,使之看起來是透明的。它的參數可以為QBitmap或QRegion對象。 |
| paintEvent(self, QPaintEvent) | 通過重載paintEvent()函數繪制窗口背景 |
QPixmap和QBitmap繪圖的效果對比
import sys
from PyQt5.QtWidgets import QApplication, QWidget
from PyQt5.QtGui import QPixmap, QPainter, QBitmap
class MyForm(QWidget):
def __init__(self, parent=None):
super(MyForm, self).__init__(parent)
self.setWindowTitle("不規(guī)則窗口的實現例子")
def paintEvent(self, event):
painter = QPainter(self)
painter.drawPixmap(0, 0, 280, 390, QPixmap(r"./pyqt5/images/dog.jpg"))
painter.drawPixmap(300, 0, 280, 390, QBitmap(r"./pyqt5/images/dog.jpg"))
if __name__ == "__main__":
app = QApplication(sys.argv)
form = MyForm()
form.show()
sys.exit(app.exec_())

不可以拖動的不規(guī)則窗口
import sys
from PyQt5.QtWidgets import QApplication, QWidget
from PyQt5.QtGui import QPixmap, QPainter, QBitmap
class WinForm(QWidget):
def __init__(self, parent=None):
super(WinForm, self).__init__(parent)
self.setWindowTitle("不規(guī)則窗口的實現例子")
self.pix = QBitmap("./pyqt5/images/mask.png")
self.resize(self.pix.size())
self.setMask(self.pix)
def paintEvent(self, event):
painter = QPainter(self)
# 在指定區(qū)域直接繪制窗口背景
painter.drawPixmap(0, 0, self.pix.width(), self.pix.height(), QPixmap("./pyqt5/images/screen1.jpg"))
if __name__ == "__main__":
app = QApplication(sys.argv)
win = WinForm()
win.show()
sys.exit(app.exec_())
可以拖動的不規(guī)則窗口
import sys
from PyQt5.QtWidgets import QApplication ,QWidget
from PyQt5.QtGui import QPixmap, QPainter , QCursor , QBitmap
from PyQt5.QtCore import Qt
class ShapeWidget(QWidget):
def __init__(self,parent=None):
super(ShapeWidget,self).__init__(parent)
self.setWindowTitle("不規(guī)則的,可以拖動的窗體實現例子")
self.mypix()
# 顯示不規(guī)則 pic
def mypix(self):
self.pix = QBitmap( "./pyqt5/images/mask.png" )
self.resize(self.pix.size())
self.setMask(self.pix)
print( self.pix.size())
self.dragPosition = None
# 重定義鼠標按下響應函數mousePressEvent(QMouseEvent)和鼠標移動響應函數mouseMoveEvent(QMouseEvent),使不規(guī)則窗體能響應鼠標事件,隨意拖動。
def mousePressEvent(self, event):
if event.button() == Qt.LeftButton:
self.m_drag=True
self.m_DragPosition=event.globalPos()-self.pos()
event.accept()
self.setCursor(QCursor(Qt.OpenHandCursor))
if event.button()==Qt.RightButton:
self.close()
def mouseMoveEvent(self, QMouseEvent):
if Qt.LeftButton and self.m_drag:
# 當左鍵移動窗體修改偏移值
self.move(QMouseEvent.globalPos()- self.m_DragPosition )
QMouseEvent.accept()
def mouseReleaseEvent(self, QMouseEvent):
self.m_drag=False
self.setCursor(QCursor(Qt.ArrowCursor))
#一般 paintEvent 在窗體首次繪制加載, 要重新加載paintEvent 需要重新加載窗口使用 self.update() or self.repaint()
def paintEvent(self, event):
painter = QPainter(self)
painter.drawPixmap(0,0,self.width(),self.height(),QPixmap("./pyqt5/images/boy.png"))
if __name__ == '__main__':
app=QApplication(sys.argv)
form=ShapeWidget()
form.show()
app.exec_()

不規(guī)則窗口實現動畫效果
import sys
from PyQt5.QtWidgets import QApplication, QWidget
from PyQt5.QtGui import QPixmap, QPainter, QCursor
from PyQt5.QtCore import Qt, QTimer
class ShapeWidget(QWidget):
def __init__(self, parent=None):
super(ShapeWidget, self).__init__(parent)
self.i = 1
self.mypix()
self.timer = QTimer()
self.timer.setInterval(500) # 定時器每500毫秒更新一次
self.timer.timeout.connect(self.timeChange)
self.timer.start()
# 顯示不規(guī)則圖片
def mypix(self):
self.update()
if self.i == 5:
self.i = 1
self.mypic = {1:'./pyqt5/images/left.png', 2:'./pyqt5/images/up.png', 3:'./pyqt5/images/right.png', 4:'./pyqt5/images/down.png'}
self.pix = QPixmap(self.mypic[self.i], "0", Qt.AvoidDither | Qt.ThresholdDither | Qt.ThresholdAlphaDither)
self.resize(self.pix.size())
self.setMask(self.pix.mask())
self.dragPosition = None
def mousePressEvent(self, event):
if event.button() == Qt.LeftButton:
self.m_drag = True
self.m_DragPosition = event.globalPos() - self.pos()
event.accept()
self.setCursor(QCursor(Qt.OpenHandCursor))
def mouseMoveEvent(self, QMouseEvent):
if Qt.LeftButton and self.m_drag:
self.move(QMouseEvent.globalPos() - self.m_DragPosition)
QMouseEvent.accept()
def mouseReleaseEvent(self, QMouseEvent):
self.m_drag = False
self.setCursor(QCursor(Qt.ArrowCursor))
def paintEvent(self, event):
painter = QPainter(self)
painter.drawPixmap(0, 0, self.pix.width(), self.pix.height(), self.pix)
def mouseDoubleClickEvent(self, event):
if event.button() == 1:
self.i += 1
self.mypix()
def timeChange(self):
self.i += 1
self.mypix()
if __name__ == "__main__":
app = QApplication(sys.argv)
win = ShapeWidget()
win.show()
sys.exit(app.exec_())
加載GIF動畫效果
import sys
from PyQt5.QtWidgets import QApplication, QLabel, QWidget
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QMovie
class LoadingGifWin(QWidget):
def __init__(self, parent=None):
super(LoadingGifWin, self).__init__(parent)
self.label = QLabel('', self)
self.setFixedSize(128, 128)
self.setWindowFlags(Qt.Dialog | Qt.CustomizeWindowHint)
self.movie = QMovie("./pyqt5/images/loading.gif")
self.label.setMovie(self.movie)
self.movie.start()
if __name__ == "__main__":
app = QApplication(sys.argv)
win = LoadingGifWin()
win.show()
sys.exit(app.exec_())

到此這篇關于一文詳解PyQt5中實現不規(guī)則窗口的顯示的文章就介紹到這了,更多相關PyQt5不規(guī)則窗口顯示內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python Collections強大的數據結構工具使用實例探索
這篇文章主要介紹了Python Collections強大的數據結構工具的使用實例探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01
Pytorch 使用opnecv讀入圖像由HWC轉為BCHW格式方式
這篇文章主要介紹了Pytorch 使用opnecv讀入圖像由HWC轉為BCHW格式方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
淺談keras使用預訓練模型vgg16分類,損失和準確度不變
這篇文章主要介紹了淺談keras使用預訓練模型vgg16分類,損失和準確度不變,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編小編過來看看吧2020-07-07

