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

本文主要是介绍【Qt学习】QDial 与 QSlider 的 介绍与使用(利用控件 控制窗口透明度 / 窗口大小),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1. QDila
    • 1.1 介绍
    • 1.2 实例使用(利用QDial控制窗口不透明度)
    • 1.3 资源文件
  • 2. QSlider
    • 2.1 介绍
    • 2.2 实例使用(利用QSlider控制窗口大小)
    • 2.3 资源文件

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的使用

这篇关于【Qt学习】QDial 与 QSlider 的 介绍与使用(利用控件 控制窗口透明度 / 窗口大小)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/782492

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Java中switch-case结构的使用方法举例详解

《Java中switch-case结构的使用方法举例详解》:本文主要介绍Java中switch-case结构使用的相关资料,switch-case结构是Java中处理多个分支条件的一种有效方式,它... 目录前言一、switch-case结构的基本语法二、使用示例三、注意事项四、总结前言对于Java初学者