治疗小鼠事件opencv gui vs pyqt

时间:2016-10-06 19:57:15

标签: python opencv mouseevent pyqt4

我正在使用OpenCV gui函数一段时间,而且可能性对python用户来说有点限制。今天我开始使用Pyqt并得出以下结论:qt真的令人困惑。

现在关于鼠标事件的问题:

在OpenCV中,我只需执行以下操作:

import cv2
cv2.namedWindow('Window',1)
def CallBackFunc(event,x,y,flags,param):
   global xc,yc,evt,flg
   xc,yc,evt,flg=x,y,event,flags

cv2.setMouseCallback('Window', CallBackFunc)

这将打开一个单独的线程,它不断刷新全局变量xc,yc,evt,flg,我可以随时随地访问它们。如果我想停止刷新,我只需cv2.setMouseCallback('Window',nothing)nothing

def nothing():
  pass

它可能不是处理鼠标事件的最美妙方式,但我很好。如何使用PyQt实现这种自由?

编辑:

例如,以下脚本显示白色圆圈,并不断在其中绘制文本。

import sys
from PySide import QtGui
import numpy as np 
import cv2

class QCustomLabel (QtGui.QLabel):


    def __init__ (self, parent = None):
        super(QCustomLabel, self).__init__(parent)
        self.setMouseTracking(True)


    def mouseMoveEvent (self, eventQMouseEvent):
        self.x,self.y=eventQMouseEvent.x(),eventQMouseEvent.y()
        cvImg=np.zeros((900,900),dtype=np.uint8)
        cv2.circle(cvImg,(449,449),100,255,-1)
        cv2.putText(cvImg,"x at {}, y at {}".format(self.x,self.y),(375,455), cv2.FONT_HERSHEY_SIMPLEX,0.5,(0,0,0),1,cv2.LINE_AA)
        height, width= cvImg.shape
        bytearr=cvImg.data
        qImg = QtGui.QImage(bytearr, width, height, QtGui.QImage.Format_Indexed8)
        self.setPixmap(QtGui.QPixmap.fromImage(qImg))

    def mousePressEvent (self, eventQMouseEvent):
        self.evt=eventQMouseEvent.button()


class QCustomWidget (QtGui.QWidget):
    def __init__ (self, parent = None):
        super(QCustomWidget, self).__init__(parent)
        self.setWindowOpacity(1)
        # Init QLabel
        self.positionQLabel = QCustomLabel(self)
        # Init QLayout
        layoutQHBoxLayout = QtGui.QHBoxLayout()
        layoutQHBoxLayout.addWidget(self.positionQLabel)

        self.setLayout(layoutQHBoxLayout)
        self.show()


if QtGui.QApplication.instance() is not None:
    myQApplication=QtGui.QApplication.instance()
else: 
    myQApplication = QtGui.QApplication(sys.argv)


myQTestWidget = QCustomWidget()
myQTestWidget.show()
myQApplication.exec_()

这里的问题是,这都是在QCustomLabel类内部以及MouseMoveEvent函数内部执行的。但我想要一个单独的函数,让我们在该类之外调用它drawCircle,它可以访问鼠标位置和事件。使用opencv,这根本不是问题。并且它只需要写入工作的一小部分,这是pyqt实现所需的。

我认为正确的问题是:为什么我不喜欢pyqt?

1 个答案:

答案 0 :(得分:0)

您可以使用事件过滤器来避免必须继承QLabel

class QCustomWidget (QtGui.QWidget):
    def __init__ (self, parent = None):
        super(QCustomWidget, self).__init__(parent)
        self.setWindowOpacity(1)
        # Init QLabel
        self.positionQLabel = QtGui.QLabel(self)
        self.positionQLabel.setMouseTracking(True)
        self.positionQLabel.installEventFilter(self)
        # Init QLayout
        layoutQHBoxLayout = QtGui.QHBoxLayout()
        layoutQHBoxLayout.addWidget(self.positionQLabel)    
        self.setLayout(layoutQHBoxLayout)
        self.show()

    def eventFilter(self, source, event):
        if event.type() == QtCore.QEvent.MouseMove:
            self.drawCircle(event.x(), event.y())
        return super(QCustomWidget, self).eventFilter(source, event)

    def drawCircle(self, x, y):
        # whatever