Matplotlib draw () не будет работать в среде pyqt на MacOS - PullRequest
0 голосов
/ 15 марта 2019

Я пытаюсь обновить график matplotlib, встроенный в окно pyqt5. Я использовал self.canvas.draw() (в функции update), чтобы обновить график в функции, чтобы перерисовать фигуру. Это нормально работает в Window, но не работает в MacOS. Я не понимаю, почему и если существует решение для этого?

На самом деле мне нужно нажать на оси, чтобы обновить фигуру ... странно.

from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
import numpy as np
import sys
import matplotlib.pyplot as plt
from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas
from matplotlib.backends.backend_qt5agg import NavigationToolbar2QT as NavigationToolbar

class StimEdit(QMainWindow):
    def __init__(self, parent=None):
        super(StimEdit, self).__init__()
        self.parent = parent

        self.centralWidget = QWidget()
        self.color = self.centralWidget.palette().color(QPalette.Background)
        self.setCentralWidget(self.centralWidget)
        self.mainHBOX_param_scene = QHBoxLayout()

        self.set_Stims()
        self.mainHBOX_param_scene.addWidget(self.Stimulation)
        self.centralWidget.setLayout(self.mainHBOX_param_scene)

    def set_Stims(self):
        self.Stimulation = QGroupBox('Stim N°1')

        self.layout_Stimulation_courbe = QVBoxLayout()
        self.layout_Stimulation = QHBoxLayout()

        self.button = QPushButton('push')
        self.masceneparam = paramViewer(self)
        self.button.clicked.connect(self.button_fun)

        self.layout_Stimulation_courbe.addWidget(self.masceneparam)
        self.layout_Stimulation_courbe.addWidget(self.button)
        self.Stimulation.setLayout(self.layout_Stimulation_courbe)

    def button_fun(self):
        self.masceneparam.update()
        self.parent.processEvents()




class paramViewer(QGraphicsView):
    def __init__(self, parent=None):
        super(paramViewer, self).__init__(parent)
        self.parent=parent
        self.scene = QGraphicsScene(self)
        self.setScene(self.scene)
        self.figure = plt.figure()
        self.canvas = FigureCanvas(self.figure)
        self.toolbar = NavigationToolbar(self.canvas, self)

        self.axes_stim=self.figure.add_subplot(111)
        self.canvas.setGeometry(0, 0, 1600, 500 )
        layout = QVBoxLayout()
        layout.addWidget(self.toolbar)
        layout.addWidget(self.canvas)
        self.setLayout(layout)
        self.canvas.show()


    def update(self):
        self.axes_stim.clear()
        t = np.arange(1000)/100
        self.axes_stim.plot(t,np.sin(2*np.pi*np.random.uniform()*100*t))
        self.canvas.draw()


def main():
    app = QApplication(sys.argv)
    ex = StimEdit(app)
    ex.setWindowTitle('St ')
    ex.show()
    sys.exit(app.exec_( ))


if __name__ == '__main__':
    main()

редактировать

Я пытаюсь использовать пример matplotlib для встраиваемых фигур в Qt (https://matplotlib.org/gallery/user_interfaces/embedding_in_qt_sgskip.html) из @ ImportanceOfBeingErnest

# from PyQt5.QtGui import *
# from PyQt5.QtWidgets import *
import numpy as np
import sys
import matplotlib.pyplot as plt
from matplotlib.figure import Figure

from matplotlib.backends.qt_compat import QtCore, QtWidgets, is_pyqt5
if is_pyqt5():
    from matplotlib.backends.backend_qt5agg import (
        FigureCanvas, NavigationToolbar2QT as NavigationToolbar)
else:
    from matplotlib.backends.backend_qt4agg import (
        FigureCanvas, NavigationToolbar2QT as NavigationToolbar)
from matplotlib.figure import Figure

class StimEdit(QtWidgets.QMainWindow):
    def __init__(self, parent=None):
        super(StimEdit, self).__init__()
        self.parent = parent

        self.centralWidget = QtWidgets.QWidget()
        self.setCentralWidget(self.centralWidget)
        self.mainHBOX_param_scene = QtWidgets.QHBoxLayout()

        self.set_Stims()
        self.mainHBOX_param_scene.addWidget(self.Stimulation)
        self.centralWidget.setLayout(self.mainHBOX_param_scene)

    def set_Stims(self):
        self.Stimulation = QtWidgets.QGroupBox('Stim N°1')

        self.layout_Stimulation_courbe = QtWidgets.QVBoxLayout()
        self.layout_Stimulation = QtWidgets.QHBoxLayout()

        self.button = QtWidgets.QPushButton('push')
        self.masceneparam = paramViewer(self)
        self.button.clicked.connect(self.button_fun)

        self.layout_Stimulation_courbe.addWidget(self.masceneparam)
        self.layout_Stimulation_courbe.addWidget(self.button)
        self.Stimulation.setLayout(self.layout_Stimulation_courbe)

    def button_fun(self):
        self.masceneparam.update()
        self.parent.processEvents()




class paramViewer(QtWidgets.QGraphicsView):
    def __init__(self, parent=None):
        super(paramViewer, self).__init__(parent)
        self.parent=parent
        self.scene = QtWidgets.QGraphicsScene(self)
        self.setScene(self.scene)
        self.figure = Figure()
        self.canvas = FigureCanvas(self.figure )
        self.toolbar = NavigationToolbar(self.canvas, self)

        self.axes_stim=self.figure.add_subplot(111)
        self.canvas.setGeometry(0, 0, 1600, 500 )
        layout = QtWidgets.QVBoxLayout()
        layout.addWidget(self.toolbar)
        layout.addWidget(self.canvas)
        self.setLayout(layout)
        self.canvas.show()


    def update(self):
        self.axes_stim.clear()
        t = np.arange(1000)/100
        self.axes_stim.plot(t,np.sin(2*np.pi*np.random.uniform()*100*t))
        self.canvas.figure.canvas.draw()
        # self.canvas.draw()


def main():
    app = QtWidgets.QApplication(sys.argv)
    ex = StimEdit(app)
    ex.setWindowTitle('St ')
    ex.show()
    sys.exit(app.exec_( ))


if __name__ == '__main__':
    main()

Но проблема все еще остается.

1 Ответ

0 голосов
/ 27 апреля 2019

Ответ от @ImportanceOfBeingErnest

Поскольку у меня нет опыта работы с Mac, я не смогу здесь помочь, но последнее предложение может состоять в том, чтобы заменить .draw() на .draw_idle(). (Оба должны работать в этом случае, но вы никогда не знаете ...)

...