我有一个烦人的问题,过去几个月来一直没有解决。基本上,我使用jupyter/ipython笔记本调用pyqt并显示3D几何数据。这是如何将应用程序初始化为对象的方式,添加一些多边形和点之后,我调用show():
class Figure(object):
'''
Main API functions
'''
def __init__(self):
print "... initializing canvas ..."
self.app = QApplication(sys.argv)
self.app.processEvents()
...
def show(self): #Show
self.GUI = GLWindow(data)
self.app.exec_()
我希望能够通过笔记本单元格持续地与小部件进行交互/更新。但是,一旦我在Jupyter笔记本中调用show()命令,我就无法再运行任何单元格或更新小部件,因为笔记本输出会被排队(?)并锁定:
#Initialize figure object inside the notebook
fig = plb.figure()
...
fig.show() #Locks out any further jupyter commands while widget on screen
fig.update() #Does not get executed until widget is closed
似乎通过notebook调用的.show()函数会放弃对python内核的控制,但如何重新获取控制权以及如何连接到正在显示的小部件仍然不清楚。
鼠标和键盘事件确实与小部件交互,但它们使用内在的函数,例如mouseMoveEvent(),这些函数在小部件代码中。
class GLWindow(QtGui.QWidget):
def __init__(self, fig, parent=None):
QtGui.QWidget.__init__(self, parent)
self.glWidget = GLWidget(fig, parent=self)
...
class GLWidget(QtOpenGL.QGLWidget):
def __init__(self, fig, parent=None):
QtOpenGL.QGLWidget.__init__(self, parent)
...
def mouseMoveEvent(self, event):
buttons = event.buttons()
modifiers = event.modifiers()
dx = event.x() - self.lastPos.x()
dy = event.y() - self.lastPos.y()
...
我尝试按照相关建议进行操作,但是我不知道如何在小部件之外使用连接或事件。
如果能得到帮助,我将非常感激,因为我已经花了很多时间来尝试解决这个问题,这让我感到很尴尬。 Cat