【QT】显示类控件

news2025/1/16 16:57:16

显示类控件

  • 显示类控件
    • 1. label - 标签
    • 2. LCD Number - 显示数字的控件
    • 3. ProgressBar - 进度条
    • 4. Calendar Widget - 日历
    • 5. Line Edit - 输入框
    • 6. Text Edit - 多行输入框
    • 7. Combo Box - 下拉框
    • 8. Spin Box - 微调框
    • 9. Date Edit & Time Edit - 日期微调框
    • 10. Dial - 旋钮
    • 11. Slider - 滑动条

显示类控件

1. label - 标签

QLabel 可以⽤来显⽰⽂本和图片,核⼼属性如下:
在这里插入图片描述在这里插入图片描述

代码示例1: 显示不同格式的⽂本

在这里插入图片描述

代码示例2:显示图片

虽然 QPushButton 也可以通过设置图标的⽅式设置图⽚,但是并⾮是⼀个好的选择。更多的时候还是希望通过 QLabel 来作为⼀个更单纯的显⽰图⽚的⽅式。

1)在界⾯上创建⼀个 QLabel, objectName 为 label
2)创建 resource.qrc ⽂件, 并把图⽚导⼊到 qrc 中
3)修改 widget.cpp, 给 QLabel 设置图片,并设置 scaledContents 属性,即 设置内容伸缩
4) 此时, 如果拖动窗⼝⼤⼩, 可以看到图⽚并不会随着窗⼝⼤⼩的改变⽽同步变化,为了解决这个问题, 可以在 Widget 中重写 resizeEvent 函数.

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    ui->label->setGeometry(0, 0, 800, 600);
			
			    QPixmap pixmap(":/target.png");
			    ui->label->setPixmap(pixmap);
			
			    // 设置内容伸缩
			    ui->label->setScaledContents(true);
			}
			
			// 重写 resizeEvent. 这个函数会在窗⼝⼤⼩发⽣改变时被⾃动调⽤.
			void Widget::resizeEvent(QResizeEvent *event)
			{
			    // 可以直接通过 this->width() 和 this->height() 设置 label 新的尺⼨, 也可以通过event 参数拿到新的尺⼨.
			    // ui->label->setGeometry(0, 0, this->width(), this->height());
			    ui->label->setGeometry(0, 0, event->size().width(), event->size().height());
			
			    qDebug() << event->size();
			}

代码示例3:⽂本对⻬, ⾃动换⾏, 缩进, 边距

  1. 创建四个 label, objectName 分别是 label 到 label_4 并且在 QFrame 中设置 frameShape 为 Box (设置边框之后看起来会更清晰⼀些)

在这里插入图片描述

QFrame 是 QLabel 的⽗类. 其中 frameShape 属性⽤来设置边框性质.

  • QFrame::Box :矩形边框
  • QFrame::Panel :带有可点击区域的⾯板边框
  • QFrame::WinPanel :Windows⻛格的边框
  • QFrame::HLine :⽔平线边框
  • QFrame::VLine :垂直线边框
  • QFrame::StyledPanel :带有可点击区域的⾯板边框,但样式取决于窗⼝主题
  1. 编写 widget.cpp, 给这四个 label 设置属性.

     	Widget::Widget(QWidget *parent)
     	    : QWidget(parent)
     	    , ui(new Ui::Widget)
     	{
     	    ui->setupUi(this);
     	
     	    // 设置文字居中对齐
     	    ui->label->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);
     	    ui->label->setText("垂直水平居中的文本");
     	
     	    // 设置自动换行
     	    ui->label_2->setAlignment(Qt::AlignTop | Qt::AlignLeft);
     	    ui->label_2->setWordWrap(true);
     	    ui->label_2->setText("文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,");
     	
     	    // 设置首行缩进
     	    ui->label_3->setAlignment(Qt::AlignTop | Qt::AlignLeft);
     	    ui->label_3->setIndent(20);
     	    ui->label_3->setText("文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,");
     	
     	    // 设置边距
     	    ui->label_4->setAlignment(Qt::AlignTop | Qt::AlignLeft);
     	    ui->label_4->setMargin(20);
     	    ui->label_4->setText("文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,文本内容,");
     	}
    

代码示例4:设置伙伴

1)创建两个 label 和 两个 radioButton.
objectName 分别问 label , label_2 , radioButton , radioButton_2

在这里插入图片描述

此处把 label 中的⽂本设置为 “快捷键 &A” 这样的形式,其中 & 后⾯跟着的字符,就是快捷键。可以通过 alt + A 的⽅式来触发该快捷键。

但是注意,这⾥的快捷键和 QPushButton 的不同,需要搭配 alt 和 单个字⺟的⽅式才能触发.

2)编写 widget.cpp, 设置 buddy 属性,当然这⾥也可以使⽤ Qt Designer 直接设置。

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    ui->label->setBuddy(ui->radioButton);
			    ui->label_2->setBuddy(ui->radioButton_2);
			}

2. LCD Number - 显示数字的控件

QLCDNumer 是⼀个专⻔⽤来显⽰数字的控件。类似于 “⽼式计算器” 的效果。

在这里插入图片描述

在这里插入图片描述

代码示例1:倒计时

1)在界⾯上创建⼀个 QLCDNumber , 初始值设为 10;objectName 为 lcdNumber

在这里插入图片描述

2)修改 widget.h 代码, 创建⼀个 QTimer 成员, 和⼀个 updateTime 函数

在这里插入图片描述

3)修改 widget.cpp,在构造函数中初始化 QTimer

  • QTimer 表⽰定时器. 通过 start ⽅法启动定时器之后, 就会每隔⼀定周期, 触发⼀次 QTimer::timeout 信号.

  • 使⽤ connect 把 QTimer::timeout 信号和 Widget::updateTime 连接起来, 意味着每次触发 QTimer::timeout 都会执⾏ Widget::updateTime

      		Widget::Widget(QWidget *parent)
      		    : QWidget(parent)
      		    , ui(new Ui::Widget)
      		{
      		    ui->setupUi(this);
      		
      		    // 创建 QTimer 实例
      		    timer = new QTimer(this);
      		
      		    //  连接信号槽. QTimer 会每隔⼀定的时间触发⼀个 timeout 信号. 现在把 timeout 信号和 updateTime 连接起来.
      		    // 此时意味着每次触发 timeout 信号都会伴随 updateTime 函数的执⾏.
      		    connect(timer, &QTimer::timeout, this, &Widget::updateTime);
      		
      		    // 启动 QTimer,并规定每隔 1000ms 触发一次 timeout 信号
      		    timer->start(1000);
      		}
    

4)修改 widget.cpp, 实现 updateTime

  • 通过 intValue 获取到 QLCDNumber 内部的数值.

  • 如果 value 的值归 0 了, 就停⽌ QTimer ;接下来 QTimer 也就不会触发 timeout 信号了.

      		void Widget::updateTime()
      		{
      		    int value = ui->lcdNumber->intValue();
      		    if(value <= 0){
      		        timer->stop();
      		        return;
      		    }
      		    ui->lcdNumber->display(value - 1);
      		}
    

3. ProgressBar - 进度条

使⽤ QProgressBar 表⽰⼀个进度条。

核心属性:

在这里插入图片描述在这里插入图片描述

代码示例:设置进度条按时间增⻓

1)在界⾯上创建进度条, objectName 为 progressBar

在这里插入图片描述

2)修改 widget.h, 创建 QTimer 和 updateProgressBar 函数.

3)修改 widget.cpp, 初始化 QTimer,此处设置 100ms 触发⼀次 timeout 信号. 也就是⼀秒钟触发 10 次.

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			    
			    timer = new QTimer(this);
			    connect(timer, &QTimer::timeout, this, &Widget::updateProgressBar);
			    timer->start(100);
			}

4)修改 widget.cpp,实现 updateProgressBar

			void Widget::updateProgressBar()
			{
			    int value = ui->progressBar->value();
			    if(value >= 100){
			        timer->stop();
			        return;
			    }
			    ui->progressBar->setValue(value + 1);
			}

4. Calendar Widget - 日历

QCalendarWidget 表⽰⼀个 “⽇历” 。

核心属性:

在这里插入图片描述

重要信号:

在这里插入图片描述

代码示例: 获取选中的⽇期

1)在界⾯上创建⼀个 QCalendarWidget 和 ⼀个 label;objectName 为 calendarWidget , label

在这里插入图片描述

2)给 QCalendarWidget 添加 slot 函数

			void Widget::on_calendarWidget_selectionChanged()
			{
			    QDate date = ui->calendarWidget->selectedDate();
			    qDebug() << date;
			
			    ui->label->setText(date.toString());
			}

5. Line Edit - 输入框

QLineEdit ⽤来表⽰单⾏输⼊框. 可以输⼊⼀段⽂本, 但是不能换⾏.

核心属性:

在这里插入图片描述在这里插入图片描述

核心信号:

在这里插入图片描述

代码示例:录入个人信息

1)在界⾯上创建三个输⼊框和两个单选按钮, ⼀个普通按钮.

三个输⼊框的 objectName 为 lineEdit_name , lineEdit_password ,
lineEdit_phone;两个单选按钮的 objectName 为 radioButton_male , radioButton_female;按钮的 objectName 为 pushButton

在这里插入图片描述

2)编写 widget.cpp, 在构造函数中编写初始化代码

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    // 初始化输入框
			    ui->lineEdit_name->setPlaceholderText("请输入姓名");
			    ui->lineEdit_name->setClearButtonEnabled(true); // 清空框
			
			    ui->lineEdit_password->setPlaceholderText("请输入密码");
			    ui->lineEdit_password->setClearButtonEnabled(true);
			    ui->lineEdit_password->setEchoMode(QLineEdit::Password); // 输入密码隐藏
			
			    ui->lineEdit_phone->setPlaceholderText("请输入电话");
			    ui->lineEdit_phone->setClearButtonEnabled(true);
			    ui->lineEdit_phone->setInputMask("000-0000-0000");
			}

3)继续修改 widget.cpp, 给按钮添加 slot 函数

			void Widget::on_pushButton_clicked()
			{
			    QString gender = ui->radioButton_male->isChecked()? "男" : "女";
			    qDebug() << "姓名:" << ui->lineEdit_name->text()
			             << "密码:" << ui->lineEdit_password->text()
			             << "性别:" << gender
			             << "电话:" << ui->lineEdit_phone->text();
			}

代码示例2:使⽤正则表达式验证输⼊框的数据

此处要求在输⼊框中输⼊⼀个合法的电话号码(1 开头, 11 位, 全都是数字). 如果验证不通过, 则确定按钮⽆法点击.

  • 关于正则表达式
    正则表达式是⼀种在计算机中常⽤的, 使⽤特殊字符描述⼀个字符串的特征的机制. 在进⾏字符串匹配时⾮常有⽤。正则表达式的语法还⽐较复杂, ⼀般都是随⽤随查, 不需要背下来
  • 参考:
    正则表达式文档
    正则表达式在线工具

1)在界⾯上创建输⼊框和⼀个按钮.

在这里插入图片描述

2)编写 widget.cpp, 把按钮初始 enabled 设为 false. 给输⼊框添加验证器.

  • 使用 QRegExp 创建⼀个正则表达式对象. “^1\d{10}$” 表⽰ “以 1 开头, 后⾯跟上任意的 10 个十进制数字”.
  • 使用 QRegExpValidator 创建⼀个验证器对象. Qt 中内置了四个主要的验证器对象.

在这里插入图片描述

QRegularExpressionValidator 在匹配性能上做出了⼀定优化. 但是从使⽤⻆度讲, 和 QRegExpValidator 差别不⼤. 我们使⽤ QRegExpValidator 即可。

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    //  设置按钮默认状态是禁用的
			    ui->pushButton->setEnabled(false);
			
			    // 给 lineEdit 注册一个 validator
			    ui->lineEdit->setValidator(new QRegExpValidator(QRegExp("^1\\d{10}$")));
			}

3)编写 widget.cpp, 给 lineEdit 添加 textEdited 信号的 slot 函数.

  • on_lineEdit_textEdited 的参数是当前输⼊框的内容.
  • 通过 lineEdit->validator() 获取到内置的验证器.
  • 通过 validate ⽅法验证⽂本是否符合要求.

第⼀个参数填写的是要验证的字符串. 由于参数要求是 QString& ⽽不是 const QString& , 需要把这个变量复制⼀下.

第⼆个参数是⼀个 int&, 是输出型参数. 当验证的字符串不匹配时, 返回这个字符串的⻓度. (没有啥实质作⽤).

返回值是⼀个枚举,QValidator::Acceptable 表⽰验证通过,QValidator::Invalid 表⽰验证不通过.

			void Widget::on_lineEdit_textEdited(const QString &arg1)
			{
			    qDebug() << arg1;
			
			    QString content = arg1;
			    int pos = 0;
			    if(ui->lineEdit->validator()->validate(content, pos) == QValidator::Acceptable)
			    {
			        // 验证通过,设置按钮的可用状态为启用
			        ui->pushButton->setEnabled(true);
			    }
			    else
			    {
			        // 验证不通过,设置按钮的可用状态为禁用
			        ui->pushButton->setEnabled(false);
			    }
			}

代码示例3:验证两次输⼊的密码⼀致

1)在界⾯上创建两个输⼊框和⼀个 label

在这里插入图片描述

2)编写代码, 设置两个输⼊框的 echoMode 为 Password

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    ui->lineEdit->setEchoMode(QLineEdit::Password);
			    ui->lineEdit_2->setEchoMode(QLineEdit::Password);
			}

3)给两个输⼊框设置 textEdited slot 函数

			void Widget::on_lineEdit_textEdited(const QString &arg1)
			{
			    const QString& s1 = ui->lineEdit->text();
			    const QString& s2 = ui->lineEdit_2->text();
			
			    if(s1.isEmpty() && s2.isEmpty()){
			        ui->label->setText("密码为空!");
			    }
			    else if(s1 == s2){
			        ui->label->setText("两次输入的密码相同!");
			    }
			    else{
			        ui->label->setText("两次输入的密码不相同!");
			    }
			}
			
			void Widget::on_lineEdit_2_textEdited(const QString &arg1)
			{
			    const QString& s1 = ui->lineEdit->text();
			    const QString& s2 = ui->lineEdit_2->text();
			
			    if(s1.isEmpty() && s2.isEmpty()){
			        ui->label->setText("密码为空!");
			    }
			    else if(s1 == s2){
			        ui->label->setText("两次输入的密码相同!");
			    }
			    else{
			        ui->label->setText("两次输入的密码不相同!");
			    }
			}

代码示例4:切换显示密码

1) 创建⼀个输⼊框和⼀个复选按钮.

2)修改 widget.cpp, 设置输⼊框的 echoMode 为 Password

3)修改 widget.cpp, 给 checkBox 添加 slot 函数

			void Widget::on_checkBox_toggled(bool checked)
			{
			    if(checked){
			        ui->lineEdit->setEchoMode(QLineEdit::Normal);
			    }
			    else{
			        ui->lineEdit->setEchoMode(QLineEdit::Password);
			    }
			}

6. Text Edit - 多行输入框

QTextEdit 表⽰多⾏输⼊框. 也是⼀个富⽂本 & markdown 编辑器。并且能在内容超出编辑框范围时⾃动提供滚动条.

核⼼属性

在这里插入图片描述

在这里插入图片描述

核心信号

在这里插入图片描述

代码示例1:获取多⾏输⼊框的内容

1)创建⼀个多⾏输⼊框和⼀个label

在这里插入图片描述

2)给多⾏输⼊框添加 slot 函数. 处理 textChanged 信号.

  • 通过 toPlainText ⽅法获取到内部的⽂本.

  • 类似的, QTextEdit 还提供了 toMarkdown 和 toHtml . 根据需要我们调整不同的获取⽅式

      		void Widget::on_textEdit_textChanged()
      		{
      		    const QString& text = ui->textEdit->toPlainText();
      		
      		    ui->label->setText(text);
      		}
    

代码示例2:验证输⼊框的各种信号

1)创建多⾏输⼊框

2)给输⼊框添加以下⼏个 slot 函数

  • QTextEdit 中包含了⼀个 QTextCursor 对象, 通过这个对象可以获取到当前光标位置和选中的内容

      		void Widget::on_textEdit_textChanged()
      		{
      		    qDebug() << "[textChanged] " << ui->textEdit->toPlainText();
      		}
      		
      		void Widget::on_textEdit_selectionChanged()
      		{
      		    const QTextCursor& cursor = ui->textEdit->textCursor();
      		    qDebug() <<  "[selectionChanged] " << cursor.selectedText();
      		}
      		
      		void Widget::on_textEdit_cursorPositionChanged()
      		{
      		    const QTextCursor& cursor = ui->textEdit->textCursor();
      		    qDebug() <<  "[cursorPositionChanged]" << cursor.position();
      		}
      		
      		void Widget::on_textEdit_undoAvailable(bool b)
      		{
      		    qDebug() << "[undoAvailable] " << b;
      		}
      		
      		void Widget::on_textEdit_redoAvailable(bool b)
      		{
      		    qDebug() << "[redoAvailable] " << b;
      		}
      		
      		void Widget::on_textEdit_copyAvailable(bool b)
      		{
      		    qDebug() << "[copyAvailable] " << b;
      		}
    

3)执⾏程序, 观察结果.
可以看到:

  • 编写内容时, textChanged 和 cursorPositionChanged 会触发
  • 选中⼀段⽂本时, cursorPositionChanged , selectionChanged , copyAvailable 会触发.
  • 按下 ctrl + z 时, textChanged , undoAvailable , redoAvailable , cursorPositionChanged 会触发
  • 按下 ctrl + y, textChanged , undoAvailable , redoAvailable , cursorPositionChanged 会触发

7. Combo Box - 下拉框

QComboBox 表⽰下拉框.

核心属性:

在这里插入图片描述

核心方法:

在这里插入图片描述

核心信号:

在这里插入图片描述

代码示例1:使⽤下拉框模拟⻨当劳点餐

  1. 在界⾯上创建三个下拉框, 和⼀个按钮.

在这里插入图片描述

2)编写 widget.cpp, 初始化三个下拉框的内容

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    ui->comboBox->addItem("巨无霸");
			    ui->comboBox->addItem("鳕鱼堡");
			
			    ui->comboBox_2->addItem("薯条");
			    ui->comboBox_2->addItem("鸡翅");
			
			    ui->comboBox_3->addItem("可乐");
			    ui->comboBox_3->addItem("橙汁");
			}

3)编写 widget.cpp, 给按钮添加 slot 函数

			void Widget::on_pushButton_clicked()
			{
			    qDebug() << "汉堡选择:" << ui->comboBox->currentText();
			    qDebug() << "小吃选择:" << ui->comboBox_2->currentText();
			    qDebug() << "饮料选择:" << ui->comboBox_3->currentText();
			}

代码示例2:从⽂件中加载下拉框的选项

很多时候下拉框的选项并⾮是固定的, ⽽是通过读取⽂件/读取⽹络获取到的.

1)在界⾯上创建⼀个下拉框

2)在D盘下创建⽂件 d:/config.txt , 编写选项. 每个选项占⼀⾏.

3)修改 widget.cpp, 从⽂件中读取选项.

  • 使⽤ ifstream 打开⽂件

  • 使⽤ getline 读取每⼀⾏

  • 使⽤ QString::fromStdString 把 std::string 转成 QString

      		Widget::Widget(QWidget *parent)
      		    : QWidget(parent)
      		    , ui(new Ui::Widget)
      		{
      		    ui->setupUi(this);
      		
      		    std::ifstream file("D:/content.txt");
      		    std::string line;
      		    while(std::getline(file, line)){
      		        ui->comboBox->addItem(QString::fromStdString(line));
      		    }
      		    file.close();
      		}
    

8. Spin Box - 微调框

使⽤ QSpinBox 或者 QDoubleSpinBox 表⽰ “微调框”, 它是带有按钮的输⼊框。可以⽤来输⼊整数/浮点数。通过点击按钮来修改数值⼤⼩。

由于 SpinBox 和 QDoubleSpinBox ⽤法基本相同,就只介绍 SpinBox 的使⽤了.

QSpinBox 关键属性:

在这里插入图片描述
在这里插入图片描述

核心信号:

在这里插入图片描述

代码示例:调整⻨当劳购物⻋中的份数.

1)在界⾯上创建下列内容

  • 三个下拉框: objectName 为 comboBox 到 comboBox_3
  • 三个微调框: objectName 为 spinBox 到 spinBox_3
  • ⼀个按钮: objectName 为 pushButton

在这里插入图片描述

2)编写代码, 修改 widget.cpp, 给下拉框设置初始值.

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    // 初始化下拉框
			    ui->comboBox->addItem("巨无霸");
			    ui->comboBox->addItem("鳕鱼堡");
			    ui->comboBox_2->addItem("鸡翅");
			    ui->comboBox_2->addItem("薯条");
			    ui->comboBox_3->addItem("橙汁");
			    ui->comboBox_3->addItem("可乐");
			
			    // 初始化微调框
			    ui->spinBox->setValue(1);
			    ui->spinBox->setRange(1, 5);
			
			    ui->spinBox_2->setValue(1);
			    ui->spinBox_2->setRange(1, 5);
			
			    ui->spinBox_3->setValue(1);
			    ui->spinBox_3->setRange(1, 5);
			}

3)编写代码, 给按钮添加 slot 函数

			void Widget::on_pushButton_clicked()
			{
			    qDebug() << "当前下单内容: "
			             << ui->comboBox->currentText() << ": " << ui->spinBox->value()
			             << ui->comboBox_2->currentText() << ": " << ui->spinBox_2->value()
			             << ui->comboBox_3->currentText() << ": " << ui->spinBox_3->value();
			}

9. Date Edit & Time Edit - 日期微调框

  • 使⽤ QDateEdit 作为日期的微调框;
  • 使⽤ QTimeEdit 作为时间的微调框;
  • 使⽤ QDateTimeEdit 作为时间⽇期的微调框。

这⼏个控件⽤法⾮常相似, 我们以 QDateTimeEdit 为例进⾏介绍.

QDateTimeEdit 核心属性

在这里插入图片描述

核心信号:

在这里插入图片描述

代码实例:实现日期计算器

1)在界⾯上创建两个 QDateTimeEdit 和⼀个按钮, ⼀个 label

QDateTimeEdit 的 objectName 为 dateTimeEdit_old 和 dateTimeEdit_new

在这里插入图片描述

2)编写计算按钮的 slot 函数

  • 使⽤ daysTo 函数可以计算两个⽇期的天数.

  • 使⽤ secsTo 函数可以计算两个时间的秒数.

  • 通过 (秒数 / 3600) 换算成⼩时数, 再余上 24 得到零⼏个⼩时.

  • 使⽤ QString::number 把整数转成 QString 进⾏拼接.

      		void Widget::on_pushButton_clicked()
      		{
      		    // 获取到两个时间框的时间日期
      		    QDateTime timeOld = ui->dateTimeEdit_old->dateTime();
      		    QDateTime timeNew = ui->dateTimeEdit_new->dateTime();
      		
      		    // 计算日期差值
      		    int days = timeOld.daysTo(timeNew);
      		    int hours = (timeOld.secsTo(timeNew) / 3600) % 24;
      		
      		    // 设置 label 内容
      		    QString text = QString("计算结果为 ") + QString::number(days) + QString(" 天 零 ")
      		            + QString::number(hours) + QString(" 个小时!");
      		
      		    ui->label->setText(text);
      		}
    

10. Dial - 旋钮

使⽤ QDial 表⽰⼀个 旋钮.

核心属性:

在这里插入图片描述

核心信号:

在这里插入图片描述

代码示例:调整窗⼝透明度

1)在界⾯上创建⼀个旋钮和⼀个 label

2)编写 widget.cpp, 对旋钮初始化

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			    
			    // 设置可以循环旋转
			    ui->dial->setWrapping(true);
			    // 设置刻度线可见
			    ui->dial->setNotchesVisible(true);
			    // 设置最大值
			    ui->dial->setMaximum(100);
			    // 设置最小值
			    ui->dial->setMinimum(0);
			    // 设置初始值
			    ui->dial->setValue(100);
			}

3)编写 widget.cpp, 设置旋钮的 valueChanged slot 函数

			void Widget::on_dial_valueChanged(int value)
			{
			    ui->label->setText(QString("当前不透明度为: ") + QString::number(value));
			    this->setWindowOpacity((double)value / 100);
			}

11. Slider - 滑动条

使⽤ QSlider 表⽰⼀个滑动条.

QSlider 和 QDial 都是继承⾃ QAbstractSlider , 因此⽤法上基本相同.

核心属性:

在这里插入图片描述

核心信号:

在这里插入图片描述

代码示例:

1)在界⾯上创建两个滑动条, 分别是⽔平和垂直滑动条;objectName 分别为 horizontalSlider 和 verticalSlider

2)编写代码初始化滑动条

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    ui->horizontalSlider->setMinimum(500);
			    ui->horizontalSlider->setMaximum(2000);
			    ui->horizontalSlider->setSingleStep(100);
			    ui->horizontalSlider->setValue(800);
			
			    ui->verticalSlider->setMinimum(500);
			    ui->verticalSlider->setMaximum(1500);
			    ui->verticalSlider->setSingleStep(100);
			    ui->verticalSlider->setValue(600);
			
			    //  翻转朝向, 默认滑块从下向上增⻓, 改成从上往下增⻓.
			//    ui->verticalSlider->setInvertedAppearance(true);
			}

3)编写滑动条的 valueChanged slot 函数

			void Widget::on_horizontalSlider_valueChanged(int value)
			{
			    QRect rect = this->geometry();
			    this->setGeometry(rect.x(), rect.y(), value, rect.height());
			    qDebug() << value;
			}
			
			void Widget::on_verticalSlider_valueChanged(int value)
			{
			    QRect rect = this->geometry();
			    this->setGeometry(rect.x(), rect.y(), rect.width(), value);
			    qDebug() << value;
			}

代码示例2:通过⾃定义快捷键调整滑动条位置.

设置 - 减⼩ value, 设置 = 增加 value;默认情况下滑动条可以通过 ⽅向键 或者 pageUp / pageDown 调整大小。

1)在界⾯上创建滑动条和 label

2)编写初始化代码

			Widget::Widget(QWidget *parent)
			    : QWidget(parent)
			    , ui(new Ui::Widget)
			{
			    ui->setupUi(this);
			
			    ui->label->setText("");
			    ui->horizontalSlider->setMinimum(0);
			    ui->horizontalSlider->setMaximum(100);
			    ui->horizontalSlider->setSingleStep(10);
			    ui->horizontalSlider->setValue(0);
			}

3)创建 valueChanged 的 slot 函数

			void Widget::on_horizontalSlider_valueChanged(int value)
			{
			    ui->label->setText("当前值为: " + QString::number(value));
			}

4)修改 widget.cpp 构造函数,增加快捷键

  • 使⽤ QShortCut 类设置快捷键.

  • 快捷键触发时, 会发出 QShortcut::activated 信号, 我们连接到⾃⼰写的 slot 函数.

      		// 设置快捷键
      	    QShortcut* shortCut1 = new QShortcut(this);
      	    shortCut1->setKey(QKeySequence("-"));
      	    connect(shortCut1, &QShortcut::activated, this, &Widget::subValue);
      	    
      	    QShortcut* shortCut2 = new QShortcut(this);
      	    shortCut2->setKey(QKeySequence("="));
      	    connect(shortCut2, &QShortcut::activated, this, &Widget::addValue);
    

5)编写⾃定义 slot 函数

			void Widget::subValue()
			{
			    int value = ui->horizontalSlider->value();
			    ui->horizontalSlider->setValue(value - 10);
			}
			
			void Widget::addValue()
			{
			    int value = ui->horizontalSlider->value();
			    ui->horizontalSlider->setValue(value + 10);
			}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1904034.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

3-4 优化器和学习率

3-4 优化器和学习率 主目录点这里 优化器是机器学习和深度学习模型训练过程中用于调整模型参数的方法。它的主要目标是通过最小化损失函数来找到模型参数的最优值&#xff0c;从而提升模型的性能。 在深度学习中&#xff0c;优化器使用反向传播算法计算损失函数相对于模型参数…

pycharm远程连接和conda环境参考博客自用整理

pycharm远程连接 pycharm的连接需要先用xftp把项目上传上去&#xff08;包括venv&#xff09;&#xff0c;似乎才能连 https://blog.csdn.net/weixin_41174300/article/details/134420981 注意要上传一份一模一样的&#xff0c;然后在deployment里面添加mapping 注意传输文件…

【C语言】操作符--百科全书

目录 一、操作符的分类 二、 ⼆进制和进制转换 三、 原码、反码、补码 四、 移位操作符 五、位操作符&#xff1a;&、|、^、~ 六、单⽬操作符 七、逗号表达式 八、 下标访问[]、函数调⽤() 九、结构体 十、操作符的属性&#xff1a;优先级、结合性 十一、表达式…

P1392 取数

传送门&#xff1a;取数 如若你看完题解后&#xff0c;仍有问题&#xff0c;欢迎评论 首先说一下 我首先想到的思路 &#xff08; 20%通过率 &#xff09;&#xff1a;通过dfs , 将所有的情况放入priority_queue中&#xff08;greater<int>&#xff09;&#xff0c;维持…

【ARMv8/v9 GIC 系列 1.7 -- GIC PPI | SPI | SGI | LPI 中断使能配置介绍】

文章目录 GIC 各种中断使能配置PPIs(每个处理器私有中断)SPIs(共享外设中断)SGIs(软件生成的中断)LPIs(局部中断)GIC 各种中断使能配置 在ARM GICv3和GICv4架构中,不同类型的中断(如PPIs、SPIs、SGIs和LPIs)可以通过不同的方式进行启用和禁用。 下面详细介绍这些中…

java项目总结6

目录 1.双列集合 2.map的三种遍历方式&#xff1a; 1.键找值 2.键值对 3.lambda遍历map 3.HashMap 例子&#xff1a;统计字符出现次数 4.LinkedHashMap 5.TreeMap 6.可变参数 7.Collections: 1.双列集合 双列集合特点&#xff1a; 定义Map<String&#xff0c;St…

【Python】已解决:(paddleocr导包报错)ModuleNotFoundError: No module named ‘paddle’

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决&#xff1a;&#xff08;paddleocr导包报错&#xff09;ModuleNotFoundError: No module named ‘paddle’ 一、分析问题背景 近日&#xff0c;一些使用PaddleOCR库进行文字…

移动校园(3):处理全校课程数据excel文档,实现空闲教室查询与课程表查询

首先打开教学平台 然后导出为excel文档 import mathimport pandas as pd import pymssql serverName 127.0.0.1 userName sa passWord 123456 databaseuniSchool conn pymssql.connect(serverserverName,useruserName,passwordpassWord,databasedatabase) cursor conn.cur…

vue3项目 前端blocked:mixed-content问题解决方案

一、问题分析 blocked:mixed-content其实浏览器不允许在https页面里嵌入http的请求&#xff0c;现在高版本的浏览器为了用户体验&#xff0c;都不会弹窗报错&#xff0c;只会在控制台上打印一条错误信息。一般出现这个问题就是在https协议里嵌入了http请求&#xff0c;解决方法…

拉曼光谱入门:3.拉曼光谱的特征参数与定量定性分析策略

1.特征参数 1.1 退偏振率 退偏振率&#xff08;p&#xff09;是一个衡量拉曼散射光偏振状态的参数&#xff0c;它描述了拉曼散射光的偏振方向与入射光偏振方向之间的关系。退偏振率定义为垂直偏振方向的拉曼散射强度与平行偏振方向的拉曼散射强度之比。退偏振率&#xff08;p&…

逆变器学习笔记(二)

用正点原子示波器看交流220V波形的时候&#xff0c;一定注意先把探头调到X10档位&#xff01;&#xff01;!!!!!!!!!!!!!!!!!!!!!!!!!!! 全桥LLC电路&#xff1a; 1.电感的两种模式——DCM和CCM的区别&#xff1a; DCM&#xff08;Discontinuous Conduction Mode&#xff0c;…

【数据结构】05.双向链表

一、双向链表的结构 注意&#xff1a;这里的“带头”跟前面我们说的“头节点”是两个概念&#xff0c;带头链表里的头节点&#xff0c;实际为“哨兵位”&#xff0c;哨兵位节点不存储任何有效元素&#xff0c;只是站在这里“放哨的”。 “哨兵位”存在的意义&#xff1a;遍历循…

Go语言如何入门,有哪些书推荐?

Go 语言之所以如此受欢迎&#xff0c;其编译器功不可没。Go 语言的发展也得益于其编译速度够快。 对开发者来说&#xff0c;更快的编译速度意味着更短的反馈周期。大型的 Go 应用程序总是能在几秒钟之 内完成编译。而当使用 go run编译和执行小型的 Go 应用程序时&#xff0c;其…

Facebook数据仓库的变迁与启示

❃博主首页 &#xff1a; <码到三十五> ☠博主专栏 &#xff1a; <mysql高手> <elasticsearch高手> <源码解读> <java核心> <面试攻关> ♝博主的话 &#xff1a; <搬的每块砖&#xff0c;皆为峰峦之基&#xff1b;公众号搜索(码到…

昇思学习打卡-10-ShuffleNet图像分类

文章目录 网络介绍网络结构部分实现对应网络结构 模型训练shuffleNet的优缺点总结优点不足 网络介绍 ShuffleNet主要应用在移动端&#xff0c;所以模型的设计目标就是利用有限的计算资源来达到最好的模型精度。ShuffleNetV1的设计核心是引入了两种操作&#xff1a;Pointwise G…

20、matlab信号波形生成:狄利克雷函数、高斯脉冲和高斯脉冲序列

1、名词说明 狄利克雷函数&#xff08;Dirac Delta Function&#xff09; 狄利克雷函数&#xff0c;也称为单位冲激函数或δ函数&#xff0c;是一个在数学和信号处理中常用的特殊函数。狄利克雷函数通常用符号δ(t)表示&#xff0c;其定义为&#xff1a; δ(t) { ∞, t 0{…

美股交易相关知识点 持续完善中

美股交易时间 美东时间&#xff1a;除了凌晨 03:50 ~ 04:00 这10分钟时间不可交易以外&#xff0c;其他时间都是可以交易的。 如果是在香港或者北京时间下交易要区分两种: 美东夏令时&#xff1a;除了下午 15:50 ~ 16:00 这10分钟时间不可交易以外&#xff0c;其他时间都是可…

springboot公寓租赁系统-计算机毕业设计源码03822

摘要 1 绪论 1.1 研究背景与意义 1.2选题背景 1.3论文结构与章节安排 2 公寓租赁系统系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能性分析 2.3 系统用例分析 2.4 系…

GRPC使用之ProtoBuf

1. 入门指导 1. 基本定义 Protocol Buffers提供一种跨语言的结构化数据的序列化能力&#xff0c;类似于JSON&#xff0c;不过更小、更快&#xff0c;除此以外它还能用用接口定义(IDL interface define language)&#xff0c;通protoc编译Protocol Buffer定义文件&#xff0c;…

拆分Transformer注意力,韩国团队让大模型解码提速20倍|大模型AI应用开始小规模稳步爆发|周伯文:大模型也有幻觉,全球AI创新指数公布

拆分Transformer注意力&#xff0c;韩国团队让大模型解码提速20倍AI正在颠覆AI上市不到两年&#xff0c;蜗牛游戏可能要退市了&#xff1f;世界人工智能大会结束了&#xff0c;百花齐放&#xff0c;但也群魔乱舞“串联OLED”被苹果带火了&#xff0c;比OLED强在哪里&#xff1f…