matplotlib + PyQt5:如何传递参数?

Posted

技术标签:

【中文标题】matplotlib + PyQt5:如何传递参数?【英文标题】:matplotlib + PyQt5: How to transfer parameters? 【发布时间】:2018-02-22 19:42:45 【问题描述】:

对于这个问题,我指的是以下代码: http://lagrange.univ-lyon1.fr/docs/matplotlib/examples/user_interfaces/embedding_in_qt5.html

我对代码做了一些修改。我想问一下如何将参数从class ApplicationWindow转移到class MyStaticMplCanvas

from __future__ import unicode_literals
import sys
import os
import random
import matplotlib
# Make sure that we are using QT5
matplotlib.use('Qt5Agg')
from PyQt5 import QtCore, QtWidgets

from numpy import arange, sin, pi
from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas
from matplotlib.figure import Figure

progname = os.path.basename(sys.argv[0])
progversion = "0.1"


class MyMplCanvas(FigureCanvas):
    """Ultimately, this is a QWidget (as well as a FigureCanvasAgg, etc.)."""

    def __init__(self, parent=None, width=5, height=4, dpi=100):
        fig = Figure(figsize=(width, height), dpi=dpi)
        self.axes = fig.add_subplot(111)
        # We want the axes cleared every time plot() is called
        self.axes.hold(False)

        self.compute_initial_figure()

        #
        FigureCanvas.__init__(self, fig)
        self.setParent(parent)

        FigureCanvas.setSizePolicy(self,
                                   QtWidgets.QSizePolicy.Expanding,
                                   QtWidgets.QSizePolicy.Expanding)
        FigureCanvas.updateGeometry(self)

    def compute_initial_figure(self):
        pass


class MyStaticMplCanvas(MyMplCanvas):
    """Simple canvas with a sine plot."""

    def compute_initial_figure(self, input_List):
        print(input_List)
        t = arange(input_List[0], 3.0, 0.01)
        s = sin(2*pi*t)
        self.axes.plot(t, s)


class ApplicationWindow(QtWidgets.QMainWindow):
    def __init__(self):
        QtWidgets.QMainWindow.__init__(self)
        self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
        self.setWindowTitle("application main window")

        self.file_menu = QtWidgets.QMenu('&File', self)
        self.file_menu.addAction('&Quit', self.fileQuit,
                                 QtCore.Qt.CTRL + QtCore.Qt.Key_Q)
        self.menuBar().addMenu(self.file_menu)

        self.help_menu = QtWidgets.QMenu('&Help', self)
        self.menuBar().addSeparator()
        self.menuBar().addMenu(self.help_menu)

        self.main_widget = QtWidgets.QWidget(self)

        input_List = [0, 1, 2]  # How to transfer this input_List into MyStaticMplCanvas?
        l = QtWidgets.QVBoxLayout(self.main_widget)
        sc = MyStaticMplCanvas(self.main_widget, width=5, height=4, dpi=100, input_List)
        l.addWidget(sc)

        self.main_widget.setFocus()
        self.setCentralWidget(self.main_widget)

        self.statusBar().showMessage("All hail matplotlib!", 2000)

    def fileQuit(self):
        self.close()

    def closeEvent(self, ce):
        self.fileQuit()


qApp = QtWidgets.QApplication(sys.argv)

aw = ApplicationWindow()
aw.setWindowTitle("%s" % progname)
aw.show()
sys.exit(qApp.exec_())

感谢您的帮助!

【问题讨论】:

【参考方案1】:

你必须直接通过sc对象使用compute_initial_figure方法:

class MyMplCanvas(FigureCanvas):
    """Ultimately, this is a QWidget (as well as a FigureCanvasAgg, etc.)."""

    def __init__(self, parent=None, width=5, height=4, dpi=100):
        fig = Figure(figsize=(width, height), dpi=dpi)
        self.axes = fig.add_subplot(111)
        # We want the axes cleared every time plot() is called
        self.axes.hold(False)

        #
        FigureCanvas.__init__(self, fig)
        self.setParent(parent)

        FigureCanvas.setSizePolicy(self,
                                   QtWidgets.QSizePolicy.Expanding,
                                   QtWidgets.QSizePolicy.Expanding)
        FigureCanvas.updateGeometry(self)


class MyStaticMplCanvas(MyMplCanvas):
    """Simple canvas with a sine plot."""

    def compute_initial_figure(self, input_List):
        print(input_List)
        t = arange(input_List[0], 3.0, 0.01)
        s = sin(2*pi*t)
        self.axes.plot(t, s)


class ApplicationWindow(QtWidgets.QMainWindow):
    def __init__(self):
        QtWidgets.QMainWindow.__init__(self)
        self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
        self.setWindowTitle("application main window")

        self.file_menu = QtWidgets.QMenu('&File', self)
        self.file_menu.addAction('&Quit', self.fileQuit,
                                 QtCore.Qt.CTRL + QtCore.Qt.Key_Q)
        self.menuBar().addMenu(self.file_menu)

        self.help_menu = QtWidgets.QMenu('&Help', self)
        self.menuBar().addSeparator()
        self.menuBar().addMenu(self.help_menu)

        self.main_widget = QtWidgets.QWidget(self)

        input_List = [0, 1, 2]  # How to transfer this input_List into MyStaticMplCanvas?
        l = QtWidgets.QVBoxLayout(self.main_widget)
        sc = MyStaticMplCanvas(self.main_widget, width=5, height=4, dpi=100)
        l.addWidget(sc)
        sc.compute_initial_figure(input_List)

        self.main_widget.setFocus()
        self.setCentralWidget(self.main_widget)

        self.statusBar().showMessage("All hail matplotlib!", 2000)

    def fileQuit(self):
        self.close()

    def closeEvent(self, ce):
        self.fileQuit()

注意: 我建议阅读有关 OOP 的内容。

【讨论】:

我发现 matplotlib 比 PyQt 难学得多,因为它非常“分散”。对我来说,它看起来像是一种不同的语言。 @LucasMeier matplotlib 比 pyqt 更“python”,它看起来像标准的 python 库。 @LucasMeier 在您的情况下,最有可能发生的事情是您没有掌握 Python 和 OOP 的基本编程知识。 确实如此。我已经尝试使用 python 快两年了,但我还是个新手。 :-(

以上是关于matplotlib + PyQt5:如何传递参数?的主要内容,如果未能解决你的问题,请参考以下文章

如何在pyqt5中的两个窗口之间传递参数?

PyQt5 结合 matplotlib 时,如何显示其 NavigationToolbar

PyQt5中的Matplotlib:如何去除边缘的小空间

如何在 Pyqt5 环境中使用 Pickle 保存 Matplotlib 图?

输入用户数据时如何更新 Matplotlib 中的绘图(通过 PyQt5 按钮)

急急急 pyqt5 matplotlib 多线程问题,求大佬指点啊