让QScrollArea动态调整其父级,但不为其子级扩展

时间:2014-10-15 17:23:09

标签: c++ qt qscrollarea

我似乎遇到了从QScrollArea获取我想要的行为的问题。就目前而言,每当我向窗口小部件的布局添加一些内容作为滚动区域的目标时,它宁愿选择扩展整个窗口而不适合滚动。

这是我当前的设置:

QSplitter * mainArea = new QSplitter( Qt::Vertical );

QWidget * containment = new QWidget;
containment->setLayout( new QVBoxLayout );

currentStructures = new QWidget;
currentStructures->setLayout( new QVBoxLayout );
currentStructures->layout()->setAlignment( Qt::AlignTop );

QScrollArea * scroll = new QScrollArea();
scroll->setWidget( currentStructures );

containment->layout()->addWidget( currentStructures );
mainArea->addWidget( containment );

mainArea->addWidget( new QWidget ); //TODO: create preview bar

this->layout()->addWidget( mainArea );

这使得滚动区域只会扩展并且永远不会显示滚动条。

插入此行:

containment->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Ignored );

我可以让该区域忽略其子项的大小,但它也没有占用所需的空间,也没有显示滚动条 - 它只是对其中的小部件进行处理。

我是使用Qt的新手,但我想知道如何实现我需要的行为:我希望滚动区域贪婪地占据它的父布局可用的区域但是添加时不会垂直展开包含的布局,而是实际显示滚动条。我计划允许大量调整大小,因此它需要实际扩展到父级而不是仅仅是固定大小。关于如何解决GUI的这个方面,我感到很遗憾。谢谢你的时间。

如果您想直观地解决这个问题,可以使用这里的线束。非常感谢你的帮助。

#include <QtWidgets\qapplication.h>
#include <QtWidgets\qsplitter.h>
#include <QtWidgets\qlayout.h>
#include <QtWidgets\qscrollarea.h>
#include <QtWidgets\qpushbutton.h>
#include <QtWidgets\qlabel.h>
#include <QtWidgets\qsizepolicy.h>

int main( int argc, char * argv[] )
{
    QApplication app( argc, argv );

    QWidget * testWidget = new QWidget;
    testWidget->setLayout( new QVBoxLayout );

    //////////////////CODE IN QUESTIION//////////////////////
    QSplitter * mainArea = new QSplitter( Qt::Vertical );

    QWidget * containment = new QWidget;
    containment->setLayout( new QVBoxLayout );

    //containment->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Ignored );

    QWidget * currentStructures = new QWidget;
    currentStructures->setLayout( new QVBoxLayout );
    currentStructures->layout()->setAlignment( Qt::AlignTop );

    QScrollArea * scroll = new QScrollArea();
    scroll->setWidget( currentStructures );

    containment->layout()->addWidget( currentStructures );
    mainArea->addWidget( containment );
    ///////////////////////////////////////////////////////////

    QPushButton * pushIntoLayout = new QPushButton( "Add Element to Widget" );
    QWidget::connect( pushIntoLayout, &QPushButton::clicked, [currentStructures](){ currentStructures->layout()->addWidget( new QLabel( "A generated label" ) ); } );
    mainArea->addWidget( pushIntoLayout );
    currentStructures->setStyleSheet(
        "QWidget {"
            "background-color: #FAA;"
        "}" 
    );


    testWidget->layout()->addWidget( mainArea );

    testWidget->show();
    return app.exec();
}

1 个答案:

答案 0 :(得分:2)

即使在复制并粘贴我的代码以制作测试工具后,我也没有注意到我的严重错误。我错误地将currentStructures窗口小部件推送到容器的布局而不是scroll,即在给它的子项后滚动区域。

Qt docs void QScrollArea::setWidget( QWidget * widget )对不熟悉的人的摘录:

  

小部件成为滚动区域的子节点,在删除滚动区域或设置新小部件时将被销毁。

感谢所有看过来的人。

对于那些想知道的人,固定代码如下所示:

QSplitter * mainArea = new QSplitter( Qt::Vertical );

QWidget * containment = new QWidget;
containment->setLayout( new QVBoxLayout );

QWidget * currentStructures = new QWidget;
currentStructures->setLayout( new QVBoxLayout );
currentStructures->layout()->setAlignment( Qt::AlignTop );

QScrollArea * scroll = new QScrollArea();
scroll->setWidget( currentStructures );
scroll->setWidgetResizable( true );

containment->layout()->addWidget( scroll );
mainArea->addWidget( containment );

mainArea->addWidget( new QWidget ); //TODO: create preview bar

this->layout()->addWidget( mainArea );

干杯!