使用PyQt5显示OpenCV图像。

4

我正在学习如何使用pyqt5qt designer,但我感到非常困惑。

我的目标是在单击按钮时显示图片,因为将来我想将所有这些与opencv结合使用。

现在我有一个带有按钮和图像(标签)的窗口。

.ui转换为.py的代码:

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):

        # Omitted code
        self.pushButton.clicked.connect(self.imagen)


    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "PROG PRUEBAS QT"))
        self.pushButton.setText(_translate("MainWindow", "Escala de grises"))
        self.label.setText(_translate("MainWindow", "<html><head/><body><p><img src=\":/chchch/img.png\"/></p></body></html>"))

    #
    def imagen(self):
        img = cv.imread('img.png', 0)
        cv.imshow('sss', img)
        cv.imwrite('pichi.png', img)
    #

import noe_rc

但是现在,当我用Pycharm运行它时,在import noe_rc处崩溃了。如果我注释掉,图片就不会出现。

PS:如果我注释掉importimagen函数将正常工作,但图片将出现在新窗口中。


1
“崩溃”是指PyCharm还是程序?有错误信息吗?noe_rc是由pyrcc5生成的文件吗? - musicamante
1个回答

12
为了显示OpenCV图像,您需要将图像转换为一个 QImage ,然后再转换为 QPixmap ,在这里您可以使用 QLabel 显示图像。
from PyQt5 import QtGui, QtCore, QtWidgets
import cv2
import sys

class DisplayImageWidget(QtWidgets.QWidget):
    def __init__(self, parent=None):
        super(DisplayImageWidget, self).__init__(parent)

        self.button = QtWidgets.QPushButton('Show picture')
        self.button.clicked.connect(self.show_image)
        self.image_frame = QtWidgets.QLabel()

        self.layout = QtWidgets.QVBoxLayout()
        self.layout.addWidget(self.button)
        self.layout.addWidget(self.image_frame)
        self.setLayout(self.layout)

    @QtCore.pyqtSlot()
    def show_image(self):
        self.image = cv2.imread('placeholder4.PNG')
        self.image = QtGui.QImage(self.image.data, self.image.shape[1], self.image.shape[0], QtGui.QImage.Format_RGB888).rgbSwapped()
        self.image_frame.setPixmap(QtGui.QPixmap.fromImage(self.image))

if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    display_image_widget = DisplayImageWidget()
    display_image_widget.show()
    sys.exit(app.exec_())

使用此示例图像,

输入图像描述

输入图像描述


1
我遇到了输出问题,它只是一些空白的黑白行。所以,我删除了 rgbSwapped() 并将 Format_RGB888 更改为 Format_ARGB32。感谢您的回答。这个答案真是救命恩人。非常感谢。 - Mujeeb Ishaque
我的意思是,这个格式 Format_RGBA8888_Premultiplied - Mujeeb Ishaque
1
我的图像颜色正确,但是倾斜了。根据这个答案,在QtGui.QImage.Format_RGB888之前加入了self.image.strides[0] - ygorg
为什么不使用没有 rgbSwapped() 的 Format_BGR888? - Koray

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接