【Qt】QLCDNumber&QProgressBar&QCalendarWidget

目录

QLCDNumber

倒计时小程序

相关属性

QProgressBar

进度条小程序

相关设置


QLCDNumber

QLCDNumber是Qt框架中用于显示数字或计数值的小部件。通常用于显示整数值,例如时钟、计时器、计数器

常用属性

|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 属性 | 说明 |
| intValue | QLCDNumber显示的初始值(int类型) |
| value | QLCDNumber显示的初始值(double),和intValue是联动的 例如给value设置为1.5,intValue的值就是2 设置value和intValue的API是display,不是setValue或setIntValue |
| digitCount | 显示几位数字,可大致控制LCDNumber的大小 |
| mode | 数字显示形式 * QLCDNumber::Dec 十进制模式,显示常规的十进制数字 * QLCDNumber::Hex 十六进制模式 * QLCDNumber::Bin 二进制模式 * QLCDNumber::Oct 八进制模式 只有十进制的时候才能显示小数点后内容 |
| segmentStyle | 设置显示风格 * QLCDNumber::Flat 平面的显示风格,数字呈现在一个平坦的表面上 * QLCDNumber::OutLine 轮廓显示风格,数字具有清晰的轮廓和阴影效果 * QLCDNumber::Filled 填充显示风格,数字被填充颜色并与背景区分开 |
| smallDecimalPoint | 设置比较小的小数点 |

倒计时小程序

倒计时可以使用QTimer,信号和槽实现

QTimer可以通过start()函数设置周期发出timeout信号

cpp 复制代码
void start(int msec);

参数单位是毫秒,start(1000)代表1秒发出一次timeout信号

程序思路如下:

  1. 创建QTimer对象
  2. 关联timeout信号和相应的槽函数
  3. 启动QTimer
  4. 槽函数中修改LCDNumber的值,当倒计时为0时,关闭QTimer

代码如下:

cpp 复制代码
#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //设置QLCDNumber的初始值
    ui->lcdNumber->display(10.00);
    //绑定信号和槽函数
    //信号使用QTimer(计时器)的timeout信号
    timer = new QTimer(this);
    connect(timer, &QTimer::timeout, this, &Widget::handle);
    //计时器还需要启动
    timer->start(10);//参数是设定周期,按周期发出timeout信号

}

void Widget::handle()
{
    double value = ui->lcdNumber->value();
    if(value <= 0.0)
    {
        timer->stop();//倒计时为0时停止计时器
        return;
    }
    ui->lcdNumber->display(value - 0.01);//计时器-1
}

相关属性

segmentStyle,可以设置显示风格

  • QLCDNumber::Flat 平面的显示风格,数字呈现在一个平坦的表面上
  • QLCDNumber::OutLine 轮廓显示风格,数字具有清晰的轮廓和阴影效果
  • QLCDNumber::Filled 填充显示风格,数字被填充颜色并与背景区分开

digitCount,可以设置显示几位数

QProgressBar

QProgressBar是Qt框架中用于显示进度的小部件。通常用于表示任务完成的进度或操作的进展情况。

常用属性

|------------------|-------------------------------------------------------------------------------------------------------|
| 属性 | 说明 |
| minimum | 进度条最小值 |
| maximum | 进度条最大值 |
| value | 进度条当前值 |
| alignment | 文本在进度条中的对齐方式 * Qt::AlignLeft 左对齐 * Qt::AlignRight 右对齐 * Qt::AlignCenter 居中对齐 * Qt::AlingnJustify 两端对齐 |
| textVisible | 进度条的数字是否可见 |
| orientation | 进度条的方向是水平还是垂直 |
| invertAppearance | 是否是朝向反方向增长进度 |
| textDirection | 文本的朝向 |
| format | 展示的数字格式 * %p:表示进度的百分比(0-100) * %v:表示进度的数值(0-100) * %m:表示剩余时间(以毫秒为单位) * %t:表示总时间(以毫秒为单位) |

进度条小程序

程序思路如下:

  1. 初始化QProgressBar对象
  2. 创建QTimer对象
  3. 关联timeout信号和相应的槽函数
  4. 启动QTimer
  5. 槽函数中修改QProgressBar的值,当进度条满时,关闭QTimer
cpp 复制代码
#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //设置进度条的起始和终止
    ui->progressBar->setMinimum(0);
    ui->progressBar->setMaximum(100);
    //设置定时器
    timer = new QTimer(this);
    //连接信号和槽函数
    connect(timer, &QTimer::timeout, this, &Widget::handle);
    //启动定时器,周期为0.1秒
    timer->start(100);
}

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

相关设置

cpp 复制代码
setAlignment()//设置进度条数字的对齐方式
cpp 复制代码
setOrientation()//设置进度条的方向是水平还是垂直
  • setOrientation(Qt::Orientation::Vertical) 垂直方向
  • setOrientation(Qt::Orientation::Horizontal) 水平方向
cpp 复制代码
setInvertAppearance()//设置进度条是否反向增长,true是从右往左,false是从左往右

上述两个程序都使用了QTimer的timeout信号

读者可能会想到创建一个新的线程,更改倒计时或者进度条的值,但Qt是不允许的

Qt中,界面有一个专门的线程负责维护更新(主线程)

对于GUI来说,内部包含了很多的隐藏状态,Qt为了保证修改界面的过程中,线程安全是不会受到影响的,Qt禁止了其他线程直接修改界面

所以Qt要求,对界面的修改都必须在主线程中完成,所以不允许创建新的线程对界面进行修改

QCalendarWidget

QCalendarWidget是Qt框架中用于显示日历和处理日期选择的小部件。允许用户查看和选择日期,并支持多种日期显示格式和交互功能

常用属性

|------------------------|-------------------|
| 属性 | 说明 |
| selectDate | 当前选中的日期 |
| minimumDate | 最小日期 |
| maximumDate | 最大日期 |
| firstDayOfWeek | 每周的第一天(日历的第一列)是周几 |
| gridVisible | 是否显示日历的边框 |
| selectionMode | 是否允许选择日期 |
| navigationBarVisible | 日历上方标题是否显示 |
| horizontalHeaderFormat | 日历上方标题显示的日期格式 |
| verticalHeaderFormat | 日历第一列显示的内容格式 |
| dateEditEnabled | 是否允许日期被编辑 |

重要信号

|---------------------------------|--------------------------------------------|
| 信号 | 说明 |
| selectionChanged(const QDate&) | 当选中的日期发生改变时发出 |
| activated(const QDate&) | 当双击一个有效日期或按下回车键时发出,形参是一个QDate类型,保存了当前选中的日期 |
| currentPageChanged(int, int) | 当当前页面的年份月份改变时发出,形参是改变后的新年份和月份 |


示例:selectionChanged信号发出

Qt Designer设计的界面如下:

添加selectionChanged信号的槽函数

cpp 复制代码
void Widget::on_calendarWidget_selectionChanged()
{
    ui->label->setText(ui->calendarWidget->selectedDate().toString());
}

程序运行如下

相关推荐
软件黑马王子22 分钟前
C#初级教程(4)——流程控制:从基础到实践
开发语言·c#
cpp_learners24 分钟前
QT 引入Quazip和Zlib源码工程到项目中,无需编译成库,跨平台,压缩进度
qt·zlib·加密压缩·quazip
闲猫26 分钟前
go orm GORM
开发语言·后端·golang
黑不溜秋的1 小时前
C++ 设计模式 - 策略模式
c++·设计模式·策略模式
李白同学2 小时前
【C语言】结构体内存对齐问题
c语言·开发语言
黑子哥呢?3 小时前
安装Bash completion解决tab不能补全问题
开发语言·bash
青龙小码农3 小时前
yum报错:bash: /usr/bin/yum: /usr/bin/python: 坏的解释器:没有那个文件或目录
开发语言·python·bash·liunx
大数据追光猿3 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!4 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
柠石榴4 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯