Qt常用控件(四)

一、QDateEdit & QTimeEdit

使用 QDateEdit 作为日期的微调框

使用 QTimeEdit 作为时间的微调框

使用 QDateTimeEdit 作为时间日期的微调框

以上三种用法相似,所以我们以QDateTimeEdit举例

属性 说明
dateTime 时间日期的值
date 单纯日期的值
time 单纯时间的值
displayFormat 时间日期格式:形如yyyy/M/d H:mm
minimumDateTime 最小时间日期
maximumDateTime 最大时间日期
timeSpec Qt::LocalTime :显示本地时间;Qt::UTC :显示协调世界时(UTC);Qt::OffsetFromUTC :显示相对于UTC的偏移量(时差)

核心信号

信号 说明
dateChanged(QDate) 日期改变时触发
timeChanged(QTime) 时间改变时触发
dateTimeChanged(QDateTime) 时间日期任意一个改变时触发

代码样例(实现日期计算器):

首先,在界面上创建两个QDateTimeEdit、一个按钮和一个label

编写按钮的槽函数

cpp 复制代码
void Widget::on_pushButton_clicked()
{
    //获取两个时间框的时间日期
    QDateTime timeOld = ui->dateTimeEdit_old->dateTime();
    QDateTime timeNew = ui->dateTimeEdit_new->dateTime();
    //计算时间差值
    //daysTo可以计算两个日期的天数
    int days = timeOld.daysTo(timeNew);
    //secsTo可以计算两个日期的秒数
    int hours = (timeOld.secsTo(timeNew)/3600) % 24;
    //设置label的内容
    QString text = QString("两个时间相差:") + QString::number(days)
            + QString("天 零") + QString::number(hours) + QString("个小时");
    ui->label->setText(text);
}

运行结果:

二、QDial

使用QDial表示一个旋钮

属性 说明
value 持有的数值
minimum 最小值
maximum 最大值
singleStep 按下方向键时改变的步长
pageStep 按下 pageUp / pageDown 的时候改变的步长
sliderPosition 界面上旋钮显示的初始位置
tracking 外观是否会跟踪数值变化,默认值为 true. ⼀般不需要修改
wrapping 是否允许循环调整.即数值如果超过最大值, 是否允许回到最小值
notchesVisible 是否显示刻度线
notchTarget 刻度线之间的相对位置,数字越大, 刻度线越稀疏

核心信号

信号 说明
valueChanged(int) 数值改变时触发
rangeChanged(int, int) 范围变化时触发

代码样例(调整窗口透明度):

首先,在界面上创建一个旋钮和一个label

编写widget.cpp

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);
}

编写槽函数

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

运行结果:

三、QSlider

使用 QSlider 表示⼀个滑动条

属性 说明
value 持有的数值
minimum 最小值
maximum 最大值
singleStep 按下方向键改变的步长
pageStep 按下 pageUp / pageDown 的时候改变的步长
sliderPosition 滑动条显示的初始位置
tracking 外观是否会跟踪数值变化,默认值为 true. 一般不需要修改
orientation 滑动条的方向是水平还是垂直
invertedAppearance 是否要翻转滑动条的方向
tickPosition 刻度的位置
tickInterval 刻度的密集程度

核心信号

信号 说明
valueChanged(int) 数值改变时触发
rangeChanged(int, int) 范围变化时触发

代码样例(调整窗口的大小):

首先,在界面上创建两个滑条,一个是水平上的,一个是垂直的

编写widget.cpp文件

cpp 复制代码
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(2000);
    ui->verticalSlider->setSingleStep(100);
    ui->verticalSlider->setValue(100);
}

编写槽函数

cpp 复制代码
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;
}

运行代码:

代码样例(通过自定义快捷键调整滑动条位置):

设置 - 减小 value, 设置 = 增加 value(设置 = 是因为跟 + 其实是一样的按键)

首先,在界面上创建一个滑动条和一个lable

编写widget.cpp文件

cpp 复制代码
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(5);
    ui->horizontalSlider->setValue(10);
}

编写槽函数

cpp 复制代码
void Widget::on_horizontalSlider_valueChanged(int value)
{
    ui->label->setText(QString::number(value));
}

对widget.cpp文件进行修改

cpp 复制代码
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(5);
    ui->horizontalSlider->setValue(10);

    //设置快捷键
    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);
}

编写自定义槽函数

cpp 复制代码
//编写自定义槽函数
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);
}

运行代码:

相关推荐
Coding茶水间3 分钟前
基于深度学习的交通标志检测系统演示与介绍(YOLOv12/v11/v8/v5模型+Pyqt5界面+训练代码+数据集)
开发语言·人工智能·深度学习·yolo·目标检测·机器学习
a努力。13 分钟前
字节Java面试被问:TCP的BBR拥塞控制算法原理
java·开发语言·python·tcp/ip·elasticsearch·面试·职场和发展
jiaguangqingpanda25 分钟前
Day24-20260120
java·开发语言·数据结构
m0_5027249525 分钟前
飞书真机调试
开发语言·前端·javascript
橘子师兄2 小时前
C++AI大模型接入SDK—环境搭建
开发语言·c++·人工智能
lkbhua莱克瓦242 小时前
JavaScript核心语法
开发语言·前端·javascript·笔记·html·ecmascript·javaweb
bubiyoushang8882 小时前
基于MATLAB的近红外光谱与PLS方法测定药片有效成分含量的实现
开发语言·matlab
weixin_433179332 小时前
Hangman 猜字游戏使用列表List实现
开发语言·python
偷星星的贼112 小时前
C++中的状态机实现
开发语言·c++·算法
程序员敲代码吗2 小时前
C++中的组合模式实战
开发语言·c++·算法