您的位置:首页 > 编程语言 > Qt开发

学习记录-Qt布局中的Spacer使用

2016-09-27 22:40 555 查看
在自定义控件后,使用自定义控件进行布局时,采用网格布局,当窗口大小合适,动态创建的空控件数量也合适时,那么控件之间的空白处比较小,能布满窗口,效果比较好看,但是当控件较小或者控件较少时,就都居中显示了。不想要这种效果,想要一种自动靠左对齐或者靠右对齐的方式来显示,该怎么实现呢,Qt布局器中的Spacer就可以解决这个问题。

代码和效果如下:

关键代码:

</pre><pre name="code" class="cpp">    it1 = new TestFrame("test01");
it2 = new TestFrame("test02");
it3 = new TestFrame("test03");
it4 = new TestFrame("test04");
ui->gridLayout->addWidget(it1,0,0);
ui->gridLayout->addWidget(it2,0,1);
ui->gridLayout->addWidget(it3,0,2);
ui->gridLayout->addWidget(it4,0,3);
QHBoxLayout * hb = new QHBoxLayout;
hb->addStretch();
ui->gridLayout->addLayout(hb,0,4);


效果图:



关闭test01的效果,自动靠左对齐



以上是使用代码动态添加窗口的,关键就是那个addStretch(),他就是添加Spacer空白。在设计师里也可以拖控件实现,加入像弹簧一样那个控件Spacers就行了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: