將matplotlib圖形嵌入到PySide2界面中


https://blog.csdn.net/weixin_43469047/article/details/115607083

https://blog.csdn.net/qq_28053421/article/details/113828372

https://blog.csdn.net/weixin_43469047/article/details/117733574?utm_source=app&app_version=4.5.4

https://www.cnblogs.com/laoniubile/p/5904817.html

1. 界面設計

簡單創建一個界面:一個 GraphicsView 和 一個 PushButton

2. 定義一個類,繼承FigureCanvas

# from PySide2.QtWidgets import QApplication, QMessageBox
from PySide2.QtWidgets import QApplication, QMainWindow, QGraphicsScene, QFileDialog, QMessageBox
from PySide2.QtUiTools import QUiLoader
import sys
import numpy as np

import matplotlib
from matplotlib.backends.backend_qt5agg import FigureCanvasQTAgg as FigureCanvas
# from matplotlib.figure import Figure
import matplotlib.pyplot as plt
 
matplotlib.use("Qt5Agg")  # 聲明使用QT5

class MyFigureCanvas(FigureCanvas):
  '''
  通過繼承FigureCanvas類,使得該類既是一個PyQt5的Qwidget,又是一個matplotlib的FigureCanvas,這是連接pyqt5與matplotlib的關鍵
  '''
  def __init__(self, parent=None, width=10, height=5, xlim=(0, 2500), ylim=(-2, 2), dpi=100):
    # 創建一個Figure
    fig = plt.Figure(figsize=(width, height), dpi=dpi, tight_layout=True) # tight_layout: 用於去除畫圖時兩邊的空白
 
    FigureCanvas.__init__(self, fig) # 初始化父類
    self.setParent(parent)
 
    self.axes = fig.add_subplot(111) # 調用figure下面的add_subplot方法,類似於matplotlib.pyplot下面的subplot方法
    self.axes.spines['top'].set_visible(False) # 去掉上面的橫線
    self.axes.spines['right'].set_visible(False)
    self.axes.set_xlim(xlim)
    self.axes.set_ylim(ylim)

class Stats:

    def __init__(self):
        # 從文件中加載UI定義

        # 從 UI 定義中動態 創建一個相應的窗口對象
        # 注意:里面的控件對象也成為窗口對象的屬性了
        # 比如 self.ui.button , self.ui.textEdit
        self.ui = QUiLoader().load('mtplt.ui')

        # self.ui.button.clicked.connect(self.handleCalc)
    # 初始化 gv_visual_data 的顯示
        self.gv_visual_data_content = MyFigureCanvas(width=self.ui.graphicsView.width() / 101,
                            height=self.ui.graphicsView.height() / 101,
                            xlim=(0, 2*np.pi),
                            ylim=(-1, 1)) # 實例化一個FigureCanvas
        self.plot_cos()

        self.ui.btn_sin.clicked.connect(self.plot_sin)

    def plot_cos(self):
        x = np.arange(0, 2 * np.pi, np.pi / 100)
        y = np.cos(x)
        self.gv_visual_data_content.axes.plot(x, y)
        self.gv_visual_data_content.axes.set_title('cos()')
        # 加載的圖形(FigureCanvas)不能直接放到graphicview控件中,必須先放到graphicScene,然后再把graphicscene放到graphicview中
        self.graphic_scene = QGraphicsScene() # 創建一個QGraphicsScene
        self.graphic_scene.addWidget(self.gv_visual_data_content) # 把圖形放到QGraphicsScene中,注意:圖形是作為一個QWidget放到放到QGraphicsScene中的
        self.ui.graphicsView.setScene(self.graphic_scene) # 把QGraphicsScene放入QGraphicsView
        self.ui.graphicsView.show() # 調用show方法呈現圖形

    def plot_sin(self):
        x = np.arange(0, 2 * np.pi, np.pi / 100)
        y = np.sin(x)
        self.gv_visual_data_content.axes.clear() # 由於圖片需要反復繪制,所以每次繪制前清空,然后繪圖
        self.gv_visual_data_content.axes.plot(x, y)
        self.gv_visual_data_content.axes.set_title('sin()')
        self.gv_visual_data_content.draw() # 刷新畫布顯示圖片,否則不刷新顯示

app = QApplication([])
stats = Stats()
stats.ui.show()
app.exec_()

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM