QT自定义控件

简介

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

创建工程

  • 先创建一个QWidget窗体
    QT自定义控件_第1张图片
  • 然后再添加一个界面,选择添加新文件。
    QT自定义控件_第2张图片
  • 选择Qt,选择Qt设计师界面类
    QT自定义控件_第3张图片
  • 选择Widget
    QT自定义控件_第4张图片
  • 起一个类名,点击完成。
    QT自定义控件_第5张图片
    QT自定义控件_第6张图片
  • 在Custom的界面上放置一个Spin Box和Horizontal Slider。并进行一个水平布局,将界面调整到合适大小。然后对这两个控件进行封装。
    QT自定义控件_第7张图片

封装自定义控件

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

自定义控件功能实现

  • 在Custom类的构造函数中,连接对应控件的信号槽。
    QT自定义控件_第13张图片
  •   	//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);
    
  • 再运行程序,拖动进度条,数字会发生变化。修改数字,进度条也会发生变化。
    QT自定义控件_第14张图片

你可能感兴趣的:(QT,qt,ui,开发语言)