PyQt5 在 QLabel 使用 QPainter 绘制矩形

最近发现了一个挺厉害的人工智能学习网站,内容通俗易懂,风趣幽默,感兴趣的可以点击此链接进行查看:床长人工智能教程

 废话不多说,请看正文!

一.基础使用

在QLabel 上绘制矩形,需要使用 paintEvent 并且重写 paintEvent 函数,因为Qpainter 在 QWidget 上不会报错,在其他地方直接使用就会报错.

from PyQt5.QtGui import QImage,QPixmap
import cv2
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
import sys


class MyLabel(QLabel):
    def __init__(self,text):
        super(MyLabel,self).__init__()
        self.x0 = 150
        self.y0 = 120
        self.x1 = 400
        self.y1 = 220
        self.x2 = 150
        self.y2 = 320
        self.x3 = 400
        self.y3 = 420
        self.lab1 = QLabel(self)
        self.lab2 = QLabel(self)
        self.lab1.setText(text)
        self.lab2.setText("操作区")
        self.lab1.setStyleSheet("QLabel{color:rgb(0,0,255);font-size:18px;font-family:Arial;background:transparent;}")
        self.lab2.setStyleSheet("QLabel{color:rgb(0,0,255);font-size:18px;font-family:Arial;background:transparent;}")
        self.lab1.setMaximumSize(100,200)
        self.lab2.setMaximumSize(100,200)
        self.lab1.move(150,120)
        self.lab2.move(150,320)

    #绘制事件
    def paintEvent(self, event):
        super().paintEvent(event)
        rect =QRect(self.x0, self.y0, abs(self.x1-self.x0), abs(self.y1-self.y0))
        painter = QPainter(self)
        painter.setPen(QPen(Qt.red,2,Qt.SolidLine))
        painter.drawRect(rect)
        rect1 = QRect(self.x2, self.y2, abs(self.x3 - self.x2), abs(self.y3 - self.y2))
        painter2 = QPainter(self)
        painter2.setPen(QPen(Qt.red, 2, Qt.SolidLine))
        painter2.drawRect(rect1)

class Example(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.resize(675, 500)
        self.move(100,50)
        self.setWindowTitle('在label中绘制矩形')
        self.lb = MyLabel("输入区") #重定义的label
        img = cv2.imread('a5.jpg')
        showImage = QImage(img.data, img.shape[1], img.shape[0],
                     QImage.Format_RGB888)  # 把读取到的图片数据变成QImage形式
        # 往显示视频的Label里 显示QImage
        self.lb.setPixmap(QPixmap.fromImage(showImage))
        #self.lb.setCursor(Qt.CrossCursor)
        self.horizontalLayout = QHBoxLayout(self)
        self.horizontalLayout.addWidget(self.lb)
        self.show()

if __name__ == '__main__':
    app = QApplication(sys.argv)
    x = Example()
    sys.exit(app.exec_())

 上面的代码运行后就会在嵌套图片的QLabel中画了两个红色矩形.也可根据自己的需求是否要文字提示.

二.升级版一

from PyQt5.QtWidgets import QWidget, QApplication, QLabel
from PyQt5.QtCore import QRect, Qt
from PyQt5.QtGui import QImage, QPixmap, QPainter, QPen
import cv2
import sys

class MyLabel(QLabel):
    x0 = 0
    y0 = 0
    x1 = 0
    y1 = 0
    flag = False

    #鼠标点击事件
    def mousePressEvent(self,event):
        self.flag = True
        self.x0 = event.x()
        self.y0 = event.y()

    #鼠标释放事件
    def mouseReleaseEvent(self,event):
        self.flag = False

    #鼠标移动事件
    def mouseMoveEvent(self,event):
        if self.flag:
            self.x1 = event.x()
            self.y1 = event.y()
            self.update()

    #绘制事件
    def paintEvent(self, event):
        super().paintEvent(event)
        rect =QRect(self.x0, self.y0, abs(self.x1-self.x0), abs(self.y1-self.y0))
        painter = QPainter(self)
        painter.setPen(QPen(Qt.red,2,Qt.SolidLine))
        painter.drawRect(rect)

class Example(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.resize(675, 500)
        self.move(100,50)
        self.setWindowTitle('在label中绘制矩形')
        self.lb = MyLabel(self) #重定义的label
        img = cv2.imread('a5.jpg')
        showImage = QImage(img.data, img.shape[1], img.shape[0],
                     QImage.Format_RGB888)  # 把读取到的图片数据变成QImage形式
        # 往显示视频的Label里 显示QImage
        self.lb.setPixmap(QPixmap.fromImage(showImage))
        self.lb.setCursor(Qt.CrossCursor)#图片可以绘制
        self.show()

if __name__ == '__main__':
    app = QApplication(sys.argv)
    x = Example()
    sys.exit(app.exec_())

代码运行后如下图所示,可以用鼠标绘制一个红色的方框. 

三.升级版二

直接上代码:

代码运行后如截图所示,这个升级版的亮点在于在制作界面Qlabel绘制方框时,可以根据具体界面的需求来绘制多个矩形方框.而不需要一直在MyLabel 类中设置方框(x,y)的位置,可以直接在调用函数中设置矩形的坐标直接绘制出矩形.这样方便制作界面,减少代码的重复率.

from PyQt5.QtGui import QImage,QPixmap
import cv2
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
import sys

class MyLabel(QLabel):
    def __init__(self):
        super().__init__()
        self.data = []

    def setxy(self,x1,y1,x2,y2,text):

        self.lab1 = QLabel(self)
        self.lab1.setText(text)
        self.lab1.setStyleSheet("QLabel{color:rgb(0,0,255);\
                                 font-size:18px;font-family:Arial;background:transparent;}")
        self.lab1.move(x1,y1)
        self.setGeometry(QRect(x1,y1,x2,y2))
        data = [x1,y1,x2,y2]
        self.data.append(data)

    #绘制表格
    def paintEvent(self,event):
        super().paintEvent(event)
        painter = QPainter()
        painter.begin(self)
        for data in self.data:
            rect = QRect(data[0], data[1], abs(data[2] - data[0]), abs(data[3] - data[1]))
            painter.setPen(QPen(Qt.red, 2, Qt.SolidLine))
            painter.drawRect(rect)
        painter.end()


class Example(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.resize(675, 500)
        self.move(100,50)
        self.setWindowTitle('在label中绘制矩形')
        self.lb = MyLabel() #重定义的label
        self.lb.setxy(150, 120, 250, 220, "输入区")
        #self.lb.setGeometry(QRect(150, 120, 250, 220))
        self.lb.setxy(300, 150, 400, 350, "绘图")
        #self.lb.setGeometry(QRect(300, 150, 400, 350))
        img = cv2.imread('a5.jpg')
        showImage = QImage(img.data, img.shape[1], img.shape[0],
                     QImage.Format_RGB888)  # 把读取到的图片数据变成QImage形式
        # 往显示视频的Label里 显示QImage
        self.lb.setPixmap(QPixmap.fromImage(showImage))
        #self.lb.setCursor(Qt.CrossCursor)
        self.horizontalLayout = QHBoxLayout(self)
        self.horizontalLayout.addWidget(self.lb)
        self.show()

if __name__ == '__main__':
    app = QApplication(sys.argv)
    x = Example()
    sys.exit(app.exec_())

参考链接:PyQt5 在label显示的图片中绘制矩形_zzzzjh的博客-CSDN博客_pyqt5 矩形

              PyQt5 教程 《绘画》_pansaky的博客-CSDN博客_pyqt5绘图

  • 11
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zpeien

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值