QT自定义控件

文章介绍了如何在QT环境中创建自定义界面组件,通过在一个QWidget窗体上添加SpinBox和HorizontalSlider,进行水平布局,并封装成新的Custom类。接着,通过连接信号槽,实现了滑动进度条时数字同步变化以及数字修改时进度条位置同步更新的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

简介

  • QT的UI设计器提供了很多GUI设计的界面组件,可以满足常见的界面设计需求。但是某些时候需要设计特殊的界面组件,而在UI设计器的组件面板里根本没有合适的组件,这时就需要设计自定义的界面组件。

创建工程

  • 先创建一个QWidget窗体
    在这里插入图片描述
  • 然后再添加一个界面,选择添加新文件。
    在这里插入图片描述
  • 选择Qt,选择Qt设计师界面类
    在这里插入图片描述
  • 选择Widget
    在这里插入图片描述
  • 起一个类名,点击完成。
    在这里插入图片描述
    在这里插入图片描述
  • 在Custom的界面上放置一个Spin Box和Horizontal Slider。并进行一个水平布局,将界面调整到合适大小。然后对这两个控件进行封装。
    在这里插入图片描述

封装自定义控件

  • 在widget界面上放置一个Widget组件,
    在这里插入图片描述
  • 右击Widget,点击提升为
    在这里插入图片描述
  • 提升的类的名称就是刚才添加的那个类Custom
    在这里插入图片描述
  • 点击添加,然后点击提升
    在这里插入图片描述
  • 运行程序后,可以看到,在Widget主窗口中就会出现我们自定义的控件
    在这里插入图片描述
  • 我们想要的效果是拉动进度条,数字同步发生变化。接下来就需要在Custom类中去实现我们自定义控件的功能。

自定义控件功能实现

  • 在Custom类的构造函数中,连接对应控件的信号槽。
    在这里插入图片描述
  •   	//spinBox值修改时, horizontalSlider同步移动
      	void (QSpinBox::*p1)(int) = &QSpinBox::valueChanged;
      	connect(ui->spinBox, p1, ui->horizontalSlider, &QSlider::setValue);
    
      	//horizontalSlider移动时, spinBox值同步修改
      	connect(ui->horizontalSlider, &QSlider::valueChanged, ui->spinBox, &QSpinBox::setValue);
    
  • 再运行程序,拖动进度条,数字会发生变化。修改数字,进度条也会发生变化。
    在这里插入图片描述
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大草原的小灰灰

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值