如何使 PyQt 中的 QWidget 内容可滚动?

How to make QWidget contents scrollable in PyQt?

首先,我几个小时前开始使用 PyQt。 到目前为止一切顺利——我正在编写 rss 客户端来熟悉 PyQt 我有 QApplicationQMainWindow 和两个自定义小部件。 第一个自定义小部件是:

class RssItem(QWidget):
    __pyqtSignals__ = ("articleViewed(bool)",
                       "articleOpened(bool)",
                       "articleMarkedGood(bool)")

    def __init__(self, title, date, parent = None):
        super(RssItem, self).__init__(parent)
        self.initWidget(title, date)

    def initWidget(self, title, date):
        title = QLabel(title)
        date = QLabel(date)
        titleBox = QHBoxLayout()
        titleBox.addWidget(title)
        titleBox.addWidget(date)
        self.setLayout(titleBox)

在单行中显示(目前)标题和日期 第二个接受 RssItem 小部件数组并将它们显示在垂直列表中:

class ItemsList(QWidget):
    def __init__(self, items, parent=None):
        super(ItemsList, self).__init__(parent)
        self.initWidget(items)

    def initWidget(self, items):
        listBox = QVBoxLayout(self)
        for item in items:
            listBox.addWidget(item)
            listBox.addStretch(1)
        self.setLayout(listBox)

如何使此列表可滚动? 保持在中间我计划将多个 ItemList 合二为一 window 每个都应该有自己的滚动条。

应用程序的主要功能目前仅用于测试这两个小部件:

class MainApp(Qt.QApplication):
    def __init__(self, args):
        super(MainApp, self).__init__(args)
        self.addWidgets()
        self.exec_()

    def addWidgets(self):
        self.window = MainWindow()


class MainWindow(QtGui.QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
        self.initUI()

    def initUI(self):
        self.statusBar().showMessage("ok")
        self.resize(640, 480)
        self.setWindowTitle("Smart Rss")
        items=[]
        for x in range(0, 200):
            items.append(RssItem("Title no %s" % x, "2000-1-%s" %x))
        self.setCentralWidget(ItemsList(items))
        self.show()

编辑:越来越近,将 ItemList.initWidget 更改为

def initWidget(self, items):
    scroll= QScrollArea(self)
    wrap = QWidget(self)
    listBox = QVBoxLayout(self)
    for item in items:
        listBox.addWidget(item)
        listBox.addStretch(1)
    wrap.setLayout(listBox)
    scroll.setWidget(wrap)

但现在我不知道如何让 QScrollArea 填充所有可用的 space 并在更改时自动调整大小。

像这里一样尝试 scroll.setWidgetResizable(True)

def initWidget(self, items):
    listBox = QVBoxLayout(self)
    self.setLayout(listBox)

    scroll = QScrollArea(self)
    listBox.addWidget(scroll)
    scroll.setWidgetResizable(True)
    scrollContent = QWidget(scroll)

    scrollLayout = QVBoxLayout(scrollContent)
    scrollContent.setLayout(scrollLayout)
    for item in items:
        scrollLayout.addWidget(item)
    scroll.setWidget(scrollContent)