在调整大小事件中修改布局

时间:2019-04-09 20:22:02

标签: python pyqt pyqt5 qlayout

PyQt 5.9.2,Python 3.6.6,Windows 10

我想根据其容器窗口小部件的当前宽度动态隐藏/显示窗口小部件。如果space占不到整个宽度的10%,则隐藏按钮“一个”,然后单击按钮“两个”。当用户将容器变大时,按钮将再次显示:“两个”,然后是“一个”。

enter image description here

这是我的实现的一个非常基本的版本,大多数情况下都有效,但是有一个大问题。我开始调整大小,隐藏了“一个”按钮,但随后出现了一些约束,因此无法再减小容器的大小。我必须释放鼠标按钮,然后再次开始该过程以隐藏按钮“ Two”。

enter image description here

import sys
from PyQt5 import QtWidgets

form, space, widgets = None, None, None

def resize_event(event):
    if free_space_width() < 0:
        visible_w = [w for w in widgets if w.isVisible()]
        if len(visible_w) > 1:  # do not hide the last one
            for w in visible_w:
                w.hide()
                if free_space_width(w.width()) >= 0:
                    break  # enough space
    else:
        invisible_w = [w for w in widgets if not w.isVisible()]
        for w in reversed(invisible_w):
            if free_space_width(-w.width()) < 0:
                break
            w.show()


def free_space_width(shift=0):
    "Free space should be at least 10% of the bar width"
    return space.width() + shift - 0.1 * form.width()


if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    form = QtWidgets.QWidget()
    layout = QtWidgets.QHBoxLayout(form)
    layout.setSpacing(0)  # for simplicity
    form.resize(480, 64)
    form.resizeEvent = resize_event

    widgets = [QtWidgets.QPushButton("test button %d" % (i + 1), form)
               for i in range(3)]
    for i in widgets:
        layout.addWidget(i)
    space = QtWidgets.QWidget(form)  # stretchable space
    s_policy = space.sizePolicy()
    s_policy.setHorizontalStretch(1)
    space.setSizePolicy(s_policy)
    layout.addWidget(space)

    form.show()
    sys.exit(app.exec_())

2 个答案:

答案 0 :(得分:2)

一个人可以将按钮放在容器小部件中并重新实现minimumSizeHint方法,这样Qt不会尝试自行计算。

def minimumSizeHint(self):
    return QtCore.QSize(150, 30)

更新:我已经在custom layoutsetGeometry函数中实现了显示/隐藏逻辑。

答案 1 :(得分:0)

  

然后出现了一些约束,并且无法减小容器的大小

layout.setSizeConstraint(QtWidgets.QLayout.SetNoConstraint)

我认为您应该在这样的代码下实现它。

layout = QtWidgets.QHBoxLayout(form)
layout.setSpacing(0)  # for simplicity
layout.setSizeConstraint(QtWidgets.QLayout.SetNoConstraint)