PyQt 向 MainWindow 添加滚动条

PyQt add a scrollbar to MainWindow

这是一个反复出现的问题,我阅读了很多主题,其中一些对我有所帮助 (python Qt: main widget scroll bar, PyQt: Put scrollbars in this), some not at all (PyQt adding a scrollbar to my main window),我仍然对滚动条有疑问。它们不可用,它们是 'grey'.

这是我的代码(我使用的是 PyQt5):

def setupUi(self, Interface):
    Interface.setObjectName("Interface")
    Interface.resize(1152, 1009)
    sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Fixed, QtWidgets.QSizePolicy.Fixed)
    sizePolicy.setHorizontalStretch(0)
    sizePolicy.setVerticalStretch(0)
    sizePolicy.setHeightForWidth(Interface.sizePolicy().hasHeightForWidth())
    Interface.setSizePolicy(sizePolicy)
    Interface.setMouseTracking(False)
    icon = QtGui.QIcon()        

    self.centralWidget = QtWidgets.QWidget(Interface)
    self.centralWidget.setObjectName("centralWidget")

    self.scrollArea = QtWidgets.QScrollArea(self.centralWidget)
    self.scrollArea.setGeometry(QtCore.QRect(0, 0, 1131, 951))
    self.scrollArea.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn)
    self.scrollArea.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn)
    self.scrollArea.setWidgetResizable(True)
    self.scrollArea.setObjectName("scrollArea")
    self.scrollArea.setEnabled(True)

    self.scrollAreaWidgetContents = QtWidgets.QWidget()
    self.scrollAreaWidgetContents.setGeometry(QtCore.QRect(0, 0, 1112, 932))
    self.scrollAreaWidgetContents.setObjectName("scrollAreaWidgetContents")

    self.horizontalLayout = QtWidgets.QHBoxLayout(self.scrollAreaWidgetContents)
    self.horizontalLayout.setObjectName("horizontalLayout")

所以我想把滚动条放在主控件上,所以如果用户调整主控件的大小 window,滚动条就会出现,让他上下移动以查看位于主控件之外的子控件window 小部件更小,可以左右移动。

感谢帮助!

滚动条变灰是因为您通过将滚动条策略设置为 Qt.ScrollBarAlwaysOn 使它们始终可见,但实际上没有要滚动的内容,因此它们被禁用。如果您希望滚动条仅在需要时出现,您需要使用 Qt.ScrollBarAsNeeded

没有要滚动的内容,因为 QHBoxLayout 中只有 1 个小部件(参见 self.scrollAreaWidgetContents)。此外,如果此方法是从 QMainWindow 执行的,则在设置中央小部件时也会出现错误:self.centralWidget 是一种检索中央小部件的方法。它之所以有效,是因为您正在用 QWidget 实例覆盖它(我相信 python 允许您这样做)。要正确设置中央小部件,您需要在 QMainWindow.

中使用 setCentralWidget()
def setupUi(self, Interface):
    Interface.setObjectName("Interface")
    Interface.resize(1152, 1009)
    sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Fixed, QtWidgets.QSizePolicy.Fixed)
    sizePolicy.setHorizontalStretch(0)
    sizePolicy.setVerticalStretch(0)
    sizePolicy.setHeightForWidth(Interface.sizePolicy().hasHeightForWidth())
    Interface.setSizePolicy(sizePolicy)
    Interface.setMouseTracking(False)
    icon = QtGui.QIcon()        

    self.horizontalLayout = QtWidgets.QHBoxLayout()
    self.horizontalLayout.setObjectName("horizontalLayout")

    self.scrollArea = QtWidgets.QScrollArea()
    self.scrollArea.setGeometry(QtCore.QRect(0, 0, 1131, 951))
    self.scrollArea.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAsNeeded)
    self.scrollArea.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAsNeeded)
    self.scrollArea.setWidgetResizable(True)
    self.scrollArea.setObjectName("scrollArea")
    self.scrollArea.setEnabled(True)

    self.horizontalLayout.addWidget(self.scrollArea)

    centralWidget = QWidgets.QWidget()
    centralWidget.setObjectName("centralWidget")
    centralWidget.setLayout(self.horizontalLayout)

    self.setCentralWidget(centralWidget)

我把Interface留在外面了,因为我不知道它是什么,但其余的应该没问题。

示例代码有几处错误。主要问题是您没有正确使用布局,并且内容小部件没有添加到滚动区域。

下面是修复版(注释行都是垃圾,可以去掉):

def setupUi(self, Interface):
    # Interface.setObjectName("Interface")
    # Interface.resize(1152, 1009)
    # sizePolicy = QtWidgets.QSizePolicy(QtWidgets.QSizePolicy.Fixed, QtWidgets.QSizePolicy.Fixed)
    # sizePolicy.setHorizontalStretch(0)
    # sizePolicy.setVerticalStretch(0)
    # sizePolicy.setHeightForWidth(Interface.sizePolicy().hasHeightForWidth())
    # Interface.setSizePolicy(sizePolicy)
    # Interface.setMouseTracking(False)
    # icon = QtGui.QIcon()
    self.centralWidget = QtWidgets.QWidget(Interface)
    # self.centralWidget.setObjectName("centralWidget")
    layout = QtWidgets.QVBoxLayout(self.centralWidget)

    self.scrollArea = QtWidgets.QScrollArea(self.centralWidget)
    # self.scrollArea.setGeometry(QtCore.QRect(0, 0, 1131, 951))
    # self.scrollArea.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn)
    # self.scrollArea.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOn)
    # self.scrollArea.setWidgetResizable(True)
    # self.scrollArea.setObjectName("scrollArea")
    # self.scrollArea.setEnabled(True)
    layout.addWidget(self.scrollArea)

    self.scrollAreaWidgetContents = QtWidgets.QWidget()
    self.scrollAreaWidgetContents.setGeometry(QtCore.QRect(0, 0, 1112, 932))
    # self.scrollAreaWidgetContents.setObjectName("scrollAreaWidgetContents")

    self.scrollArea.setWidget(self.scrollAreaWidgetContents)

    layout = QtWidgets.QHBoxLayout(self.scrollAreaWidgetContents)
    # self.horizontalLayout.setObjectName("horizontalLayout")
    # add child widgets to this layout...        

    Interface.setCentralWidget(self.centralWidget)