引言
图形与图像绘制支持是一个GUI框架库的核心模块之一,从Java的Graphics2D到Android的Canvas类支持到PyQT5中的QPainter类支持与图元支持,都很好的满足了GUI库的图形绘制与渲染需求。
QPainter类介绍
QPainter类是PyQT5中图形绘制类,支持圆、椭圆、矩形、圆角矩形、线段、文本、图像、多边形、弧形等常见几何形状的绘制与填充,支持颜色、旋转、状态复位、平移、错切等设置操作。所有的QWidget类都继承了paintEvent方法,绘制代码都应该在paintEvent方法中完成执行。一个典型的paintEvent方法绘制代码如下:
def paintEvent(self, paintEvent): painter = QPainter(self) painter.setPen(Qt.blue) painter.setFont(QFont("Arial", 30)) painter.drawText(rect(), Qt.AlignCenter, "OpenCV学堂")上述代码首先获取画笔,然后设置颜色与字体,最后绘制文本。通过用户创建Painter实例的方式绘制,绘制结束之后需要显式销毁,通过系统的painter绘制则无需这样,对比如下: 用户创建绘制
def paintEvent(self, paintEvent): p = QPainter() p.begin(self) p.drawLine(...) # drawing code p.end()
调用系统绘制
def paintEvent(self, paintEvent): p = QPainter(self) p.drawLine(...) # drawing code所有绘制的函数支持都是draw开头,所有填充的函数都是fill开头,什么绘制与填充,请看下图:
综合代码演示
代码实现了绘制与填充不同的几何形状,支持不同颜色设置,线宽设置,风格设置等。运行结果如下图:
添加上显示图像功能之后如下:
相关自定义绘制类代码如下:
1from PyQt5 import QtWidgets 2from PyQt5 import QtGui 3from PyQt5 import QtCore 4import sys 5 6 7class MyCustomCanvas(QtWidgets.QWidget): 8 def __init__(self): 9 super().__init__() 10 print("create my custom canvas") 11 12 def paintEvent(self, event): 13 painter = QtGui.QPainter(self) 14 # 设置为反锯齿 15 painter.setRenderHint(QtGui.QPainter.Antialiasing) 16 17 # 填充黑色背景 18 painter.fillRect(self.rect(), QtCore.Qt.black) 19 20 # 绘制图像 21 pic = QtGui.QPixmap("test3.png") 22 painter.drawPixmap(self.rect(), pic) 23 24 # 设置字体与颜色,绘制文本 25 pen = QtGui.QPen(QtCore.Qt.green, 5, QtCore.Qt.DashLine) 26 painter.setPen(pen) 27 font = QtGui.QFont() 28 font.setBold(True) 29 font.setPointSizeF(24) 30 painter.setFont(font) 31 painter.drawText(QtCore.QPoint(20, 50), "OpenCV学堂") 32 33 # 5表示线宽 34 pen = QtGui.QPen(QtCore.Qt.red, 5, QtCore.Qt.DashLine) 35 painter.setPen(pen) 36 painter.drawLine(50, 100, 50, 400) 37 38 # 绘制矩形 39 pen = QtGui.QPen(QtCore.Qt.yellow, 5, QtCore.Qt.DotLine) 40 painter.setPen(pen) 41 painter.drawRect(QtCore.QRect(100, 100, 200, 200)) 42 painter.fillRect(100, 100, 200, 200, QtCore.Qt.green) 43 44 # 绘制圆 45 pen = QtGui.QPen(QtCore.Qt.red, 5, QtCore.Qt.DotLine) 46 painter.setPen(pen) 47 48 # 设置为填充模式 49 painter.setBrush(QtGui.QBrush(QtCore.Qt.yellow, QtCore.Qt.SolidPattern)) 50 51 # 直接绘制 52 painter.drawEllipse(QtCore.QRect(300, 300, 150, 150)) 53 54 # 贝塞尔曲线 55 painter.setBrush(QtGui.QBrush(QtCore.Qt.red, QtCore.Qt.SolidPattern)) 56 self.drawBezierCurve(painter) 57 58 def drawBezierCurve(self, qp): 59 path = QtGui.QPainterPath() 60 path.moveTo(450, 100) 61 path.cubicTo(450, 100, 550, 200, 450, 350) 62 qp.drawPath(path)
审核编辑:刘清
全部0条评论
快来发表一下你的评论吧 !