1

我已经matplotlib嵌入PyQt4到我正在开发的应用程序中。问题是当我向图中动态添加子图时,每个添加的子图都会压缩数字。我想我可以通过将数字设置为 a 来解决这个问题,QScrollArea但这不起作用(据我所知)。这是我认为可行的示例

import os
os.environ['QT_API'] = 'pyside'

from PySide.QtGui   import *
from PySide.QtCore  import *

import matplotlib

from matplotlib.backends.backend_qt4agg import FigureCanvasQTAgg
from matplotlib.figure                  import Figure


class Canvas(FigureCanvasQTAgg):

    def __init__(self, parent=None):
        self.figure = Figure()
        super(Canvas, self).__init__(self.figure)

        ax = self.figure.add_subplot(1,1,1)
        ax.plot([1,2,3])
        self.draw()

    def add_subplot(self, data=[]):
        rows = len(self.figure.axes) + 1
        for index, axes in enumerate(self.figure.axes, start=1):
            axes.change_geometry(rows, 1, index)

        ax = self.figure.add_subplot(rows, 1, index+1)
        ax.plot(data)

        self.draw()

class Main(QWidget):

    def __init__(self, parent=None):
        super(Main, self).__init__(parent)

        self.canvas = QScrollArea(self)
        self.canvas.setWidget(Canvas(self))
        self.canvas.setWidgetResizable(True)

        for x in range(5):
            self.canvas.widget().add_subplot()

        layout = QVBoxLayout(self)
        layout.addWidget(self.canvas)


app = QApplication([])
main = Main()
main.show()
app.exec_()

注意到所有的图表是如何被拼凑在一起以显示在同一个可见空间中的吗?我不必滚动查看其他图表。我不确定该怎么做。

任何人都知道如何做到这一点或这样做的另一种方式?

4

1 回答 1

2

两个步骤来勾勒解决这个问题的想法:

取消设置 ScollArea 的大小以显示滚动条。换行:

self.canvas.setWidgetResizable(True)

self.canvas.setWidgetResizable(False)

然后在添加子图时更改图形高度,因为画布将通过检查图形的大小来确定它的高度:

def add_subplot(self, data=[]):
    rows = len(self.figure.axes) + 1
    for index, axes in enumerate(self.figure.axes, start=1):
        axes.change_geometry(rows, 1, index)

    ax = self.figure.add_subplot(rows, 1, index+1)
    ax.plot(data)
    self.figure.set_figheight(self.figure.get_figheight()*1.25)
    self.draw()

在 Main 你必须让 PySide 知道,它必须在滚动区域调整小部件的大小:

    for x in range(5):
        self.canvas.widget().add_subplot()
        self.canvas.widget().adjustSize()
于 2013-02-06T08:24:12.007 回答