2016-10-15 4 views
2

У меня есть раздражающая проблема, которую я не смог решить за последние несколько месяцев. В принципе, я использую jupyter/ipython notebook для вызова pyqt и отображения трехмерных геометрических данных. Это, как я инициализировать приложение в объект и после того, как я добавить некоторые многоугольники и точки, я называю шоу():Обновление виджета PyQt через ящики для ipython/jupyter

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 ноутбук я не могу больше бежать клетки или обновлять виджет, как выход ноутбука получает в очередь и блокируется (?):

#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 

Кажется .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

ответ

4

Я нашел решение с помощью форумов jupyter. По-видимому, в ноутбуке есть трюк во время выполнения, который описан здесь, что позволяет динамически взаимодействовать с glwindow. Очень рад наконец-то решить эту проблему ...

https://github.com/ipython/ipython/blob/master/examples/IPython%20Kernel/gui/gui-qt.py

Вот целая функция, в случае, если этот пример будет удален в будущем:

#!/usr/bin/env python 
"""Simple Qt4 example to manually test event loop integration. 
This is meant to run tests manually in ipython as: 

In [5]: %gui qt 

In [6]: %run gui-qt.py 

Ref: Modified from http://zetcode.com/tutorials/pyqt4/firstprograms/ 
""" 

from PyQt4 import QtGui, QtCore 

class SimpleWindow(QtGui.QWidget): 
    def __init__(self, parent=None): 
     QtGui.QWidget.__init__(self, parent) 

     self.setGeometry(300, 300, 200, 80) 
     self.setWindowTitle('Hello World') 

     quit = QtGui.QPushButton('Close', self) 
     quit.setGeometry(10, 10, 60, 35) 

     self.connect(quit, QtCore.SIGNAL('clicked()'), 
        self, QtCore.SLOT('close()')) 

if __name__ == '__main__': 
    app = QtCore.QCoreApplication.instance() 
    if app is None: 
     app = QtGui.QApplication([]) 

    sw = SimpleWindow() 
    sw.show() 

    try: 
     from IPython.lib.guisupport import start_event_loop_qt4 
     start_event_loop_qt4(app) 
    except ImportError: 
     app.exec_() 

 Смежные вопросы

  • Нет связанных вопросов^_^