前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Qt自定义控件

Qt自定义控件

作者头像
zy010101
发布2020-04-14 21:44:01
1.1K0
发布2020-04-14 21:44:01
举报
文章被收录于专栏:程序员程序员

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了。如下所示:

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档