我写了一个继承graphicsobject 的类,实例化后使用widgets 的additem 添加到绘图窗口,使用timer 去setpos ,在初始窗口的情况下,不断setpos 能过实时更新该图元的位置,但是如果拖动或缩放窗口后,setpos 就不能实时更新图元的位置了。
需要想办法触发该图元的paint 方法才行,请问不另写方法出发paint 如何解决?
参考GPT
可以通过重写graphicsitem的boundingRect方法来实现自动更新。boundingRect方法返回一个矩形,用于确定图元的大小和位置。当图元的位置改变时,boundingRect方法应该返回新的矩形,这样就会自动触发paint方法进行更新。
具体实现可以在boundingRect方法中记录当前位置,然后在setPos方法中更新位置,并返回新的矩形。这样可以保证在拖动或缩放窗口后,图元的位置能够实时更新。
以下是一个示例代码:
from PyQt5.QtGui import QBrush, QPainter, QPen
from PyQt5.QtCore import QRectF
from pyqtgraph import GraphicsObject
class MyItem(GraphicsObject):
def __init__(self):
super().__init__()
self.pos = [0, 0]
self.brush = QBrush()
self.pen = QPen()
def boundingRect(self):
return QRectF(self.pos[0], self.pos[1], 10, 10)
def paint(self, painter, option, widget):
painter.setBrush(self.brush)
painter.setPen(self.pen)
painter.drawRect(self.boundingRect())
def setPos(self, x, y):
self.pos = [x, y]
self.prepareGeometryChange()
return self.boundingRect()
在setPos方法中,我们更新了位置,然后调用了prepareGeometryChange方法来通知Qt更新图元的boundingRect。这样就可以实现自动更新了。
import pyqtgraph as pg
from pyqtgraph import QtCore
class MyGraphicsObject(pg.GraphicsObject):
def __init__(self):
pg.GraphicsObject.__init__(self)
def paint(self, p, *args):
# 在这里实现图元的绘制操作
p.drawRect(QtCore.QRectF(0, 0, 50, 50))
def boundingRect(self):
return QtCore.QRectF(0, 0, 50, 50)
app = pg.mkQApp()
win = pg.GraphicsWindow()
view = win.addViewBox()
view.setAspectLocked(True)
item = MyGraphicsObject()
view.addItem(item)
# 使用定时器更新图元的位置
timer = QtCore.QTimer()
timer.timeout.connect(lambda: item.setPos(item.pos().x() + 1, item.pos().y()))
timer.start(100)
if __name__ == '__main__':
import sys
if sys.flags.interactive != 1 or not hasattr(QtCore, 'PYQT_VERSION'):
pg.QtGui.QApplication.exec_()