Итак, я не знаю, является ли это особенно умным, но я придумал решение, использующее отдельный таймер, который отслеживает существование clickEvents
.Я надеюсь, что это полезно для людей, имеющих аналогичную проблему.
import sys, pyqtgraph
from PyQt5 import QtGui, QtWidgets, QtCore
class Window(QtWidgets.QDialog):
def __init__(self, parent=None):
QtWidgets.QWidget.__init__(self)
layout = QtGui.QGridLayout(self)
self.view = pyqtgraph.GraphicsLayoutWidget()
self.timer = QtCore.QTimer()
layout.addWidget(self.view,0,0)
self.proxy = pyqtgraph.SignalProxy(self.view.scene().sigMouseMoved, rateLimit=30, slot=self.OnMouseMove)
self.view.scene().sigMouseClicked.connect(self.release)
self.timer.timeout.connect(self.release)
def release(self):
if not self.view.scene().clickEvents:
print("release after drag")
self.timer.stop()
elif not self.timer.isActive():
print("release after click")
def OnMouseMove(self):
if not self.timer.isActive() and self.view.scene().clickEvents:
self.timer.start(10) # After a drag release, this is the "wait" time before self.release is called.
def mouseReleaseEvent(self,ev): # This does only work outside the pyqtgraph widget. It overrides the method in QWidget and not in pyqtgraph.GraphicsScene()
print("released ",ev)
if __name__ == '__main__':
app = QtWidgets.QApplication(sys.argv)
form = Window()
form.show()
sys.exit(app.exec_())