Qt分页布局与切分窗口的实现

一、如何实现分页展示?

QStackedLayout类可对窗口实现分页展示,每次只显示一个布局,将其他页的布局隐藏。为方便,Qt提供一个内置QStackedLayout的便利类:QStackedWidget.

方案:QStackedWidget+QListWidget/QPushButton等

步骤:(1)基于QDialog或QWidget创建一个新窗体

    (2)添加一个QListWidget或若干个QPushButton和一个QStackedWidget

    (3)完成每个分页的布局(QtDesigner中创建新分页的方法:QStackedWidget中右键选择“Insert Page”;切换分页的方法:右上角箭头)

    (4)建立信号槽:将QListWidget的currentRowChanged(或currentItemChanged)与QStackedWidget的槽setCurrentIndex连接起来。

(QPushButton连接clicked信号)


二、如何实现切分窗口

利用QSplitter嵌套可实现较复杂的窗口切分布局,如下图所示:



三、实战演练

1.分页布局示例如下:




分页布局效果展示:

点击test1项目展示对应页面


点击test2项目展示对应页面



2.切分窗口示例如下:

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    QSplitter *rightSplitter=new QSplitter(Qt::Vertical);
    rightSplitter->addWidget(ui->treeWidget_2);
    rightSplitter->addWidget(ui->textEdit);
    rightSplitter->setStretchFactor(1,1);

    QSplitter *mainSplitter=new QSplitter(Qt::Horizontal);
    mainSplitter->addWidget(ui->treeWidget);
    mainSplitter->addWidget(rightSplitter);
    mainSplitter->setStretchFactor(1,1
                                   );

    setCentralWidget(mainSplitter);

}

切分窗口效果展示:



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ctrlturtle

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值