Можно ли автоматически масштабировать ось графика, используя Python matplotlib.animation.FuncAnimation () с blit = True? - PullRequest
2 голосов
/ 21 апреля 2020

Я пытаюсь построить график получения данных от датчика с помощью matplotlib.animation.FuncAnimation (). Кроме того, я хотел бы использовать blit = True, потому что, насколько я знаю, это делает программу более эффективной (используя уже построенные значения и обновляя только новые).

Однако, когда я использую blit = True, autoscale_view () и relim (), значения x_axis не масштабируются автоматически и остаются неизменными. Поэтому мой вопрос: возможно ли это или опция blit может использоваться только для "l oop" o "повторяющихся" графиков, в которых x_axis всегда одинаков (в Inte rnet я нашел только такие примеры, как эти: sine graph спирали ...). Кроме того, при использовании blit мой график кажется слепым или обрезанным в некоторых предельных точках (нижней и правой части графика), поэтому все точки не видны.

Это пример моего кода (построение графиков) случайные значения вместо чтения с датчика):

import sys, os, random, matplotlib
import numpy as np
from datetime import datetime
from PyQt5 import QtCore, QtWidgets
from PyQt5.QtWidgets import QApplication, QVBoxLayout, QSizePolicy, QWidget
from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas
from matplotlib.figure import Figure
import matplotlib.pyplot as plt
from matplotlib.animation import FuncAnimation


class MyMplCanvas(FigureCanvas):
    def __init__(self, parent=None, width=5, height=4, dpi=100):
        fig = Figure(figsize=(width, height), dpi=dpi)
        self.ax = fig.add_subplot(1,1,1)
        FigureCanvas.__init__(self, fig)
        FigureCanvas.setSizePolicy(self,
                                   QtWidgets.QSizePolicy.Expanding,
                                   QtWidgets.QSizePolicy.Expanding)
        FigureCanvas.updateGeometry(self)

class ApplicationWindow(QtWidgets.QMainWindow):
    def __init__(self):
        QtWidgets.QMainWindow.__init__(self)
        self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
        self.setWindowTitle("application main window")
        self.main_widget = QtWidgets.QWidget(self)
        self.xdata = []
        self.ydata = []
        vbox = QtWidgets.QVBoxLayout(self.main_widget)
        self.canvas =  MyMplCanvas( self.main_widget,width=6, height=6, dpi=100) ###attention###
        vbox.addWidget(self.canvas)
        self.setLayout(vbox)
        self.main_widget.setFocus()
        self.setCentralWidget(self.main_widget)

        self.line, = self.canvas.ax.plot_date(self.xdata, self.ydata,'-')
        self.canvas.ax.tick_params(axis='x', rotation=50)
        self.ani = FuncAnimation(self.canvas.figure, self.update_line, frames=self.gen_function_time, blit=True ,interval=1000)

    def gen_function_time(self):
        while True: 
            self.now = datetime.now()
            yield self.now

    def update_line(self, frame):
        self.xdata.append(frame)
        self.ydata.append(1+np.random.randint(-3,3))
        self.line.set_data(self.xdata, self.ydata)
        self.canvas.ax.relim()
        self.canvas.ax.autoscale_view()
        return self.line,


if __name__ == "__main__":
    App = QApplication(sys.argv)
    aw = ApplicationWindow()
    aw.show()
    App.exit()
    sys.exit(App.exec_())
...