使用QPainter和paintEvent在PYQT5中的QLabel中包含的Pixmap上绘制圆圈

问题描述 投票:0回答:1

我是PYQT5的新手,我想在PYQT5的MainWindow UI中的QLabel中包含的Pixmap中绘制一个圆圈,代码如下:

from PyQt5 import QtCore, QtGui, QtWidgets

background_image_path = '001_01_01_041_05.png'

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
    MainWindow.setObjectName("MainWindow")
    MainWindow.resize(800, 600)
    self.centralwidget = QtWidgets.QWidget(MainWindow)
    self.centralwidget.setObjectName("centralwidget")
    self.label = QtWidgets.QLabel(self.centralwidget)
    self.label.setGeometry(QtCore.QRect(60, 60, 331, 401))
    self.label.setObjectName("label")
    MainWindow.setCentralWidget(self.centralwidget)
    self.menubar = QtWidgets.QMenuBar(MainWindow)
    self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 28))
    self.menubar.setObjectName("menubar")
    MainWindow.setMenuBar(self.menubar)
    self.statusbar = QtWidgets.QStatusBar(MainWindow)
    self.statusbar.setObjectName("statusbar")
    MainWindow.setStatusBar(self.statusbar)

    self._image = QtGui.QPixmap(background_image_path)

    self.retranslateUi(MainWindow)
    QtCore.QMetaObject.connectSlotsByName(MainWindow)

def retranslateUi(self, MainWindow):
    _translate = QtCore.QCoreApplication.translate
    MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
    self.label.setPixmap(self._image)

def paintEvent(self, event):
    painter = QtGui.QPainter(self._image)
    painter.drawPixmap(self.rect(), self._image)
    pen = QtGui.QPen()
    pen.setWidth(5)
    painter.setPen(pen)
    painter.drawEllipse(300, 300, 70, 70)


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

但是,我无法获取要调用的paintEvent(self,event)函数。当我确实调用paintEvent(self,event)时,我看不到正在绘制像素图的圆圈。我尝试将QPainter设置为Pixmap本身(在painter = QtGui.QPainter(self._image)中),但这也不起作用。

我做错了什么?

下面的代码有效,这是我的代码所基于的:

from PyQt5 import QtWidgets, QtGui, QtCore
background_image_path = '001_01_01_041_05.png'

class ImageScroller(QtWidgets.QWidget):
    def __init__(self):


def paintEvent(self, event):
    painter = QtGui.QPainter(self)
    painter.drawPixmap(self.rect(), self._image)
    pen = QtGui.QPen()
    pen.setWidth(5)
    painter.setPen(pen)
    painter.drawEllipse(300, 300, 70, 70)


if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication(sys.argv)
    w = ImageScroller()
    w.resize(640, 480)
    w.show()
    sys.exit(app.exec_())

任何想法或建议将不胜感激!

python user-interface pyqt drawing qpainter
1个回答
1
投票

你错过了几行。试试吧:

from PyQt5 import QtWidgets, QtGui, QtCore

background_image_path = 'E:/_Qt/img/heart.png'     # '001_01_01_041_05.png'

class ImageScroller(QtWidgets.QWidget):                    
    def __init__(self):
        super().__init__()                                   # <-------

        self._image = QtGui.QPixmap(background_image_path)   # <-------

    def paintEvent(self, event):
        painter = QtGui.QPainter(self)
        painter.drawPixmap(self.rect(), self._image)
        pen = QtGui.QPen()
        pen.setWidth(5)
        painter.setPen(pen)
        painter.drawEllipse(300, 300, 70, 70)


if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication(sys.argv)
    w = ImageScroller()
    w.resize(640, 480)
    w.show()
    sys.exit(app.exec_())

enter image description here

这里真正的问题是你正在编辑pyuic生成的模块,这总是一个非常糟糕的主意。试试吧:

from PyQt5 import QtCore, QtGui, QtWidgets

background_image_path = 'E:/_Qt/img/heart.png'

class Ui_MainWindow(object):          
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(800, 600)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")

        self.label = QtWidgets.QLabel(self.centralwidget)
        self.label.setGeometry(QtCore.QRect(200, 0, 760, 560))
        self.label.setObjectName("label")

        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 28))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)

#        self._image = QtGui.QPixmap(background_image_path)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
#        self.label.setPixmap(self._image)
        self.label.setText(_translate("MainWindow", 
                           """
                           It is not recommended to modify the design file, 
                           it is appropriate to create another file 
                           to join the logic with the design.
                           """))



#    def paintEvent(self, event):
#        painter = QtGui.QPainter(self._image)
#        painter.drawPixmap(self.rect(), self._image)
#        pen = QtGui.QPen()
#        pen.setWidth(5)
#        painter.setPen(pen)
#        painter.drawEllipse(300, 300, 70, 70)


class MyApp(QtWidgets.QMainWindow, Ui_MainWindow):

    def __init__(self):
        super(MyApp, self).__init__()

        self.setupUi(self)

        self._image = QtGui.QPixmap(background_image_path)

    def paintEvent(self, event):
        painter = QtGui.QPainter(self)  
        painter.drawPixmap(self.rect(), self._image)

        #pen = QtGui.QPen()
        #pen.setWidth(5)
        #painter.setPen(pen)
        painter.setPen(QtGui.QPen(QtCore.Qt.blue, 5))
        painter.drawEllipse(350, 350, 70, 70)


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)

#    MainWindow = QtWidgets.QMainWindow()
#    ui = Ui_MainWindow()
#    ui.setupUi(MainWindow)
#    MainWindow.show()
    window = MyApp()
    window.show() 

    sys.exit(app.exec_())

enter image description here

© www.soinside.com 2019 - 2024. All rights reserved.