QVBoxLayout 行大小
QVBoxLayout row size
我有一个小部件,我正在使用 QVBoxLayout 和小部件来组织多行小部件。第一个小部件是 QLabel,然后是多个 QPushButton 小部件。
每个小部件的宽度占宽度的100%,但是第一个小部件(QLabel)的高度比后面的QPushButton小部件大得多。所有的 QPushButtons 都是相同的高度。
看起来第一行的大小已增加以填充布局以填充父级。如果是这种情况,有什么方法可以指示布局仅使用内部小部件所需的高度而不是填充?
QLabel 和 QPushButton 的布局行为的区别在于 sizePolicy,因此解决方案是在垂直部分设置策略QSizePolicy::Maximum
#include <QtWidgets>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QWidget w;
QVBoxLayout *lay = new QVBoxLayout(&w);
QLabel *label = new QLabel("Stack Overflow");
label->setStyleSheet("background-color:salmon;");
QSizePolicy sp = label->sizePolicy();
sp.setVerticalPolicy(QSizePolicy::Maximum);
label->setSizePolicy(sp);
lay->addWidget(label);
for (int i=0; i<4; i++) {
lay->addWidget(new QPushButton(QString("pushbutton-%1").arg(i)));
}
w.show();
return a.exec();
}
我有一个小部件,我正在使用 QVBoxLayout 和小部件来组织多行小部件。第一个小部件是 QLabel,然后是多个 QPushButton 小部件。
每个小部件的宽度占宽度的100%,但是第一个小部件(QLabel)的高度比后面的QPushButton小部件大得多。所有的 QPushButtons 都是相同的高度。
看起来第一行的大小已增加以填充布局以填充父级。如果是这种情况,有什么方法可以指示布局仅使用内部小部件所需的高度而不是填充?
QLabel 和 QPushButton 的布局行为的区别在于 sizePolicy,因此解决方案是在垂直部分设置策略QSizePolicy::Maximum
#include <QtWidgets>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QWidget w;
QVBoxLayout *lay = new QVBoxLayout(&w);
QLabel *label = new QLabel("Stack Overflow");
label->setStyleSheet("background-color:salmon;");
QSizePolicy sp = label->sizePolicy();
sp.setVerticalPolicy(QSizePolicy::Maximum);
label->setSizePolicy(sp);
lay->addWidget(label);
for (int i=0; i<4; i++) {
lay->addWidget(new QPushButton(QString("pushbutton-%1").arg(i)));
}
w.show();
return a.exec();
}