Qt自定义控件

2020-04-14 21:44:01 浏览数 (1)

Qt允许我们自定义控件。这大大提高了设计UI的通用性。

首先,新建一个项目。然后添加Qt设计师界面类。如下所示:

然后给你的控件起个名字,比如MyWidget。

创建完成以后,会直接来到UI设计界面。我们往里面拖一个Spin Box和Horizontal Slider。然后把控件弄到你想要的大小:

然后在你的Main Window.ui中拖一个Container下面的Widget出来。

然后选中右击它有一个提升为如下:然后输入类名,不要填错了。然后点击添加即可,最后点击提升就完成了你自定义控件的使用了。

此时,你运行你的程序就可以看到如下所示的效果。

我们想拖动Slider来改变Spin Box的值以及改变Spin Box的值,Slider就会滑动。那么我们就需要在自定义控件的构造函数中连接信号槽。如下所示:

代码语言:javascript复制
//mywidget.cpp文件
#include "mywidget.h"
#include "ui_mywidget.h"

MyWidget::MyWidget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::MyWidget)
{
    ui->setupUi(this);
    void (QSpinBox::  * p) (int) = &QSpinBox::valueChanged;     //因为valueChanged函数有重载
    connect(ui->spinBox,p,ui->horizontalSlider,&QSlider::setValue);
    connect(ui->horizontalSlider,&QSlider::valueChanged,ui->spinBox,&QSpinBox::setValue);
}

MyWidget::~MyWidget()
{
    delete ui;
}

进行上面的信号槽封装以后,我们就能拖动Slider来改变SpinBox。也能改变SpinBox来改变Slider了。如下所示:

这样就算是完成了自定义控件的封装和使用。

0 人点赞