Python Pyqtgraph实时绘图

Python Pyqtgraph实时绘图,python,python-3.x,pyqt5,pyqtgraph,Python,Python 3.x,Pyqt5,Pyqtgraph,我想按x轴移动绘图,但现在所有绘图点都停留在一个屏幕上,起点不移动 窗口代码-主窗口代码。函数更新每5秒运行一次并设置新数据 import sys from PyQt5 import QtWidgets, QtCore, QtGui import stack import pyqtgraph as pgt from random import uniform, normalvariate import random class ExampleApp(QtWidgets.QMainWindow,

我想按x轴移动绘图,但现在所有绘图点都停留在一个屏幕上,起点不移动

窗口代码-主窗口代码。函数更新每5秒运行一次并设置新数据

import sys
from PyQt5 import QtWidgets, QtCore, QtGui
import stack
import pyqtgraph as pgt
from random import uniform, normalvariate
import random

class ExampleApp(QtWidgets.QMainWindow, stack.Ui_MainWindow):
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        self.graphicsView.getAxis('left').setLabel('Data Value', color='#0000ff')
        self.graphicsView.getAxis('bottom').setLabel('time', 's')
        self.graphicsView.showGrid(x=True, y=True)
        self.graphicsView.setYRange(0,10)
        self.graphicsView.addLine(y=5,pen=pgt.mkPen('y'))
        self.graphicsView.addLine(y=7,pen=pgt.mkPen('r'))
        self.curve = self.graphicsView.plot()
        self.L = []
        self.timer = QtCore.QTimer()
        self.timer.timeout.connect(self.updateplot)
        self.timer.start(500)

    def getdata(self):
        frequency = 0.5
        noise = random.normalvariate(0., 1.)
        new = 10.*math.sin(time.time()*frequency*2*math.pi) + noise
        return new

    def updateplot(self):
        val = round(uniform(0,10), 2)
        self.L.append(val)
        self.curve.setData(self.L)
        #QtGui.QGuiApplication.processEvents()


def main():
    app = QtWidgets.QApplication(sys.argv)
    window = ExampleApp()
    window.show()
    app.exec_()

if __name__ == '__main__':
    main()
设计器生成的设计代码(stack.py): 使用PlotWidget而不是

from PyQt5 import QtCore, QtGui, QtWidgets

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(929, 429)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.graphicsView = PlotWidget(self.centralwidget)
        self.graphicsView.setGeometry(QtCore.QRect(9, 9, 901, 321))
        self.graphicsView.setObjectName("graphicsView")
        MainWindow.setCentralWidget(self.centralwidget)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "Data"))

from pyqtgraph import PlotWidget

pyqtgraph将显示列表的数据,在您的情况下,列表始终具有第一个元素,因此您始终可以看到该数据。解决方案是使用具有最大长度的deque,因此将使用最后的元素

import sys
from collections import deque
from PyQt5 import QtWidgets, QtCore, QtGui
import stack
import pyqtgraph as pg
import random


class ExampleApp(QtWidgets.QMainWindow, stack.Ui_MainWindow):
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        self.graphicsView.getAxis('left').setLabel('Data Value', color='#0000ff')
        self.graphicsView.getAxis('bottom').setLabel('time', 's')
        self.graphicsView.showGrid(x=True, y=True)
        self.graphicsView.setYRange(0,10)
        self.graphicsView.addLine(y=5,pen=pg.mkPen('y'))
        self.graphicsView.addLine(y=7,pen=pg.mkPen('r'))
        self.curve = self.graphicsView.plot()
        self.L = deque([0], maxlen=10)
        self.t = deque([0], maxlen=10)
        self.timer = QtCore.QTimer(self)
        self.timer.timeout.connect(self.updateplot)
        self.timer.start(500)

    def updateplot(self):
        val = round(random.uniform(0,10), 2)
        self.L.append(val)
        self.t.append(self.t[-1]+1)
        self.curve.setData(self.t, self.L)