【Qt学习】QDial 与 QSlider 的 介绍与使用(利用控件 控制窗口透明度 / 窗口大小)

本文介绍了如何在Qt应用中使用QDial和QSlider控件,如QDial用于控制窗口不透明度,通过valueChanged信号调整值;QSlider用于调整窗口大小,通过设置minimum、maximum和value属性。通过实例展示了如何在实际场景中操作和应用这些控件。

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

1. QDila

1.1 介绍

在这里插入图片描述
可以通过 查阅官方文档 对该控件进行了解,我们依次进行总结:

  • 用于 在窗口中显示一个圆形或半圆形的滑动条
  • 通常用于让用户通过拖动来选择一个数值,比如调整音量、亮度等
  • QDial提供了一种直观的方式来调整数值,用户可以通过拖动指针来增加或减少数值,也可以通过点击来精确地设置数值。

核心属性

属性名称描述
minimum设置QDial的最小值
maximum设置QDial的最大值
value设置或获取当前QDial的数值
wrapping设置是否循环滚动(即到达最大值后继续增加会回到最小值)
notchesVisible设置是否显示刻度
notchTarget设置每个刻度之间的步长
notchSize设置刻度的大小
singleStep设置单步增加或减少的数值
pageStep设置大步增加或减少的数值

1.2 实例使用(利用QDial控制窗口不透明度)

这里实现一个功能,利用 QDial 控件调节窗口的不透明度:

  1. 直接对该控件转到槽函数on_dial_valueChanged(int value)

    • 即当转动滚轮时, 该参数值会改变。
  2. 编写如下的代码:

void Widget::on_dial_valueChanged(int value)
{
    ui->label->setText("value: " + QString::number(value));
    this->setWindowOpacity((double)value / 100);
}

效果展示:

请添加图片描述


1.3 资源文件

上述涉及的代码等资源文件在👇

QDial的使用


2. QSlider

在这里插入图片描述

2.1 介绍

同样的,可以通过 查阅官方文档 对该控件进行详细了解,下面进行总结:

  1. 用于 提供一个滑动条 ,用户可以通过拖动滑块或点击滑动条来选择一个数值。
  2. 常用于调整范围值或表示连续的取值

核心属性

属性描述
minimum设置滑动条的最小值。
maximum设置滑动条的最大值。
value当前滑动条的数值。
orientation滑动条的方向,可以是水平或垂直。
tickInterval刻度间隔。
tickPosition刻度的位置。
singleStep单步增加或减少的数值。
pageStep大步增加或减少的数值。

核心信号:

信号描述
valueChanged(int value)在滑动条数值发生变化时发出的信号。
sliderPressed()在用户按下滑块时发出的信号。
sliderReleased()在用户释放滑块时发出的信号。

2.2 实例使用(利用QSlider控制窗口大小)

这里实现功能:利用两个 QSlider 控件调整窗口大小:

  1. 简单在图形化界面中进行布局:
    在这里插入图片描述

  2. widget.cpp中的构造函数中对两滑动条进行初始化:

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    ui->horizontalSlider->setMinimum(100); // 最大值
    ui->horizontalSlider->setMaximum(1920); // 最小值
    ui->horizontalSlider->setValue(800); // 初始值
    ui->horizontalSlider->setSingleStep(50); // 单步移动的数值

    ui->verticalSlider->setMinimum(100);
    ui->verticalSlider->setMaximum(1080);
    ui->verticalSlider->setValue(600);
    ui->verticalSlider->setSingleStep(50);
}
  1. 分别编写两滑动条的valued_changed() 槽函数
    • 即分别控制,当前窗口的长度与宽度
// 通过滑动条控制窗口大小
void Widget::on_horizontalSlider_valueChanged(int value)
{
    ui->label_level->setText("value: " + QString::number(value));
    const QRect& rect = this->geometry();
    this->setGeometry(rect.x(), rect.y(), value, rect.height());
}

void Widget::on_verticalSlider_valueChanged(int value)
{
    ui->label_vertical->setText("value: " + QString::number(value));
    const QRect& rect = this->geometry();
    this->setGeometry(rect.x(), rect.y(), rect.width(), value);
}

效果展示:

请添加图片描述

2.3 资源文件

QSlider的使用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值