当前位置:   article > 正文

在QT的UI界面,让Widget可以跟随窗体大小而改变_qt布局随窗口大小变化

qt布局随窗口大小变化

可以使用布局(Layout)机制让Widget(QWidget)随窗口一起缩放和移动。

Qt提供以下几种布局:

  • QHBoxLayout:将QWidget按照水平方向依次排列

  • QVBoxLayout:将QWidget按照垂直方向依次排列

  • QGridLayout:将QWidget按照行列划分为多个网格,根据网格位置排列

  • QFormLayout:将QWidget按照表单样式排列

使用布局的过程如下:

  1. 在Qt Designer的左侧对象列表中选择一个QWidget。

  2. 在右侧Widgets工具箱中选择一个布局。

  3. 双击布局,将它添加到QWidget上。

  4. 您可以在属性编辑器中进一步配置布局。

  5. 单击Qt Designer左上角的"窗口"菜单按钮,选择布局配置与在mainwindow.ui的宽高比例一致的宽高比例。

  6. 在QObject的"布局"属性处设置您选择的布局。

  7. 在构造函数中将widget添加到布局中。

  8. 在resize事件中重置布局大小。

以下是一个示例(在主窗口类MainWindow的构造函数中添加):

  1. // 创建垂直布局
  2. QVBoxLayout *layout = new QVBoxLayout();
  3. QWidget *widget = new QWidget(this); // 在MainWindow中创建QWidget
  4. widget->setLayout(layout);
  5. // 创建按钮并添加到布局中
  6. QPushButton *button1 = new QPushButton("Button1");
  7. layout->addWidget(button1, 0, Qt::AlignTop);
  8. QPushButton *button2 = new QPushButton("Button2");
  9. layout->addWidget(button2, 0, Qt::AlignTop);
  10. // 设置widget为MainWindow的中心窗口
  11. this->setCentralWidget(widget);
  12. // 添加resize事件监听器,当窗口缩放时更新布局大小
  13. connect(this, SIGNAL(resized()), this, SLOT(onResized()));
  14. 下面是重置布局尺寸的代码:
  15. void MainWindow::onResized()
  16. {
  17. QWidget *widget = this->centralWidget();
  18. widget->resize(this->size());
  19. }

这样,当您调整主窗口的大小时,QWidget和其中的按钮将跟随窗口一起缩放和移动。

希望这能够帮助您实现自适应QWidget大小和位置。

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,C++设计模式,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QSS,OpenCV,Quick模块,面试题等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/109818?site
推荐阅读
相关标签
  

闽ICP备14008679号