qt布局控件叠在一起_Qt基本控件及三大布局

Qt基本控件及三大布局

来源: http://blog.csdn.net/a2604539133/article/details/73920696

Qt基本模块

一、Qt的三大布局

QHBoxLayout:

水平显示布局,所有在其上面摆放的控件只能水平排列下去;

QVBoxLayout:

垂直显示布局,所有在其上面摆放的控件只能垂直排列下去;

QGridLayout

格子显示布局,可以按照表格的形式显示布局;

二、Qt的控件

label:标签,可以显示文本信息,只读;

pushbutton : 普通按钮;

radiobutton : 单选按钮,多个单选按钮中只能选择一个,但是必须放入groupbox中,类似单选题;

checkbox : 多选复选按钮,可以选择同时选择多个,类似多选题;

lineedit : 单行文本编辑框,可以输入单行文本;

textedit : 多行文本输入框,可以输入显示多行文本和图片;

combobox : 下拉文本输入框,在输入框的最右边有个三角下拉按钮,可以选择输入,也可以手动输入;

textbrower : 多行文本显示框,只读;

groupbox : 可以在里面放入特点的东西,统一管理;

slider : 模拟显示滑动条;

spinbox : 数值显示滑动条;

dateedit :

timeedit :

datetimeedit :

lcdnumber :

三、Qt的信号槽

在Qt中所有的对象(继承QObject类)都有connect函数,只要有这个函数就能建立信号槽(通过触发某个控件的信号函数,执行槽中相应的函数);(暂时这样理解,还是有点理解不全面的,之后学习到再来修改);

在Qt中信号槽中可以使用自带的函数,四个参数;也可以执行自定义的函数,三个参数;具体看下面test4的例子就明白了。

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include

#include "MyWidgetEvent.h"

void test() ;

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

QApplication a(argc, argv);

test() ;

return a.exec();

}

void test(){

}

void test5ManyKongJian() {

QWidget *nanWidget = new QWidget() ;

QVBoxLayout *nanVLayout = new QVBoxLayout() ;

/*

**测试label控件

*/

QLabel *label=nullptr ;

nanVLayout->addWidget( label = new QLabel("baidu") ) ;

//QPixmap me("./me.png") ;

//label->setPixmap( me ) ;//问题:链接和图片重复了,怎么分开

label->setWordWrap( true ) ;

label->adjustSize() ;

nanVLayout->connect( label , &QLabel::linkActivated , []( QString str){

qDebug()<

} ) ;

/*

**测试lineedit控件

*/

QLineEdit *lineEdit ;

nanVLayout->addWidget( lineEdit = new QLineEdit("hello") ) ;

/*

**测试button控件

*/

QPushButton *button ;

nanVLayout->addWidget( button = new QPushButton("???") ) ;

button->setStyleSheet("QPushButton {font:bold 16px; color:red;padding:5px}") ;

nanWidget->connect( button , &QPushButton::clicked , [](bool flag){

qDebug()<< "button" ;

}) ;

/*

**测试radiobutton控件

*/

QRadioButton *radioButton ;

nanVLayout->addWidget( radioButton = new QRadioButton("qradiobutton") ) ;

radioButton->setStyleSheet("QRadioButton {font:bold 16px;color:blue;padding:5px}") ;

rad

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Qt布局管理器允许我们在设计界面时更轻松地安排控件的位置和大小,其中一个重要的方面就是控件间的距离。 Qt提供了几种布局管理器,如水平布局(QHBoxLayout)、垂直布局(QVBoxLayout)和网格布局(QGridLayout),它们都可以帮助我们控制控件之间的间距。 在使用布局管理器时,我们可以通过调整布局管理器的间距属性来改变控件之间的距离。每个布局管理器都有一个叫做`setSpacing()`的方法,可以用来设置控件之间的间距。这个方法接受一个整数参数,表示控件之间的像素距离,默认值是0。 例如,如果我们创建了一个水平布局管理器,并希望控件之间的距离为10像素,我们可以使用以下代码: ```cpp QHBoxLayout *layout = new QHBoxLayout; layout->setSpacing(10); ``` 我们还可以对每个布局管理器中的控件对设置不同的间距。布局管理器的`addWidget()`方法会返回一个指向添加的控件的指针,我们可以使用这个指针来访问控件,并通过设置其`layoutSpacing()`属性来改变其与其他控件之间的间距。 例如,如果我们想要一个按钮和一个标签之间的距离比其他控件之间的距离更大,可以使用以下代码: ```cpp QHBoxLayout *layout = new QHBoxLayout; layout->setSpacing(10); QPushButton *button = new QPushButton("按钮"); QLabel *label = new QLabel("标签"); layout->addWidget(button); layout->addSpacing(20); // 设置按钮和标签之间的间距为20像素 layout->addWidget(label); ``` 通过调整布局管理器的间距属性,我们可以很方便地控制控件之间的距离,并实现自定义的界面布局

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值