注:我使用Python 3.6.2和PyQt5,虽然本例中的逻辑保持不变,如果你正在使用的其他版本甚至可以理解Python和PyQt。
了解一下什么是说here:
如果指定一个大小为0,则部件将是不可见的。 小部件的大小策略被保留。也就是说,小于相应小部件的最小大小提示的值将被提示的值替换。
一个为您解决问题的选项是调用x.setMinimumWidth()
有一个很小的值,如:
x.setMinimumWidth(1)
但是,如果你自己尝试一下,你会看到
- 它是一个肮脏的黑客,因为它实际离开这里小部件,只是使它很窄,
- 虽然现在你可以拖动分离器时,Wi的初始宽度dget仍然是“32”而不是“20”。
x.setMinimumWidth(0)
也不能按预期工作:它的最小宽度实际上是零默认(如该部件有没有内容,我猜),但它并不能帮助你使分割器项目宽度小于32像素,除非您折叠它。
顺便说一句,设置
m.setCollapsible(0, False)
m.setCollapsible(1, False)
,如果你想分路器停止其坍塌两个孩子的小部件。更多细节here.
我已经找到了解决方法是重载要包括在分线器widget的sizeHint()
方法,如下例所示的(看ButtonWrapper类是什么样的,现在输出)。
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
#Python 3.6.2 and PyQt5 are used in this example
from PyQt5.QtWidgets import (
QPushButton,
QSplitter,
QWidget,
QApplication,
)
import sys
class ButtonWrapper(QPushButton):
def sizeHint(self):
return self.minimumSize()
class Example(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.resize(400, 400)
m = QSplitter(self)
m.resize(200, 100)
x = ButtonWrapper(self)
x.setGeometry(0, 0, 100, 100)
y = QPushButton(self)
y.setGeometry(0, 100, 100, 100)
m.addWidget(x)
m.addWidget(y)
m.setSizes([20, 180])
#Now it really shows "20" as expected
print(x.width())
#minimumWidth() is zero by default for empty QPushButton
print(x.minimumWidth())
#Result of our overloaded sizeHint() method
print(x.sizeHint().width())
print(x.minimumSizeHint().width())
self.setWindowTitle('Example')
self.show()
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())
我不知道这是否是做的东西以正确的方式,但我花了很多时间试图解决我自己的问题连接到这一点,并没有看到满足咫尺天涯什么。如果有人知道更好,我将非常感激实际工作&明确解决方法。