QT 圆盘百分比

2024-05-24 14:28
文章标签 qt 百分比 圆盘

本文主要是介绍QT 圆盘百分比,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.

/* 设置抗锯齿 */painter.setRenderHints(QPainter::Antialiasing, true);/* 最外层的圆 */QRect drawRect = event->rect();QRadialGradient gradient1(drawRect.center(),
                              drawRect.width() / 2,
                              drawRect.center());
    gradient1.setColorAt(0, Qt::transparent);
    gradient1.setColorAt(0.5, Qt::transparent);// 稍微增加透明部分的范围
    gradient1.setColorAt(0.51, QColor("#00237f"));// 开始显示深蓝色
    gradient1.setColorAt(0.58, QColor("#00237f"));// 保持深蓝色一段时间
    gradient1.setColorAt(0.59, Qt::transparent);// 渐变回透明
    gradient1.setColorAt(1, Qt::transparent);
    painter.setBrush(gradient1);
    painter.setPen(Qt::NoPen);
    painter.drawEllipse(drawRect);
 
    /* 里层的圆 */
    QRadialGradient gradient2(drawRect.center(),
                              drawRect.width() / 2,
                              drawRect.center());
    gradient2.setColorAt(0, Qt::transparent);
    gradient2.setColorAt(0.420, Qt::transparent);
    gradient2.setColorAt(0.421, QColor("#885881e3"));
    gradient2.setColorAt(0.430, QColor("#5881e3"));
    gradient2.setColorAt(0.440, QColor("#885881e3"));
    gradient2.setColorAt(0.441, Qt::transparent);
    gradient2.setColorAt(1, Qt::transparent);
    painter.setBrush(gradient2);
    painter.setPen(Qt::NoPen);
    painter.drawEllipse(drawRect);
 
    /* 数字 */
    QFont font;
    font.setPixelSize(drawRect.width() / 10);
    painter.setPen(Qt::white);
    painter.setFont(font);
    painter.drawText(drawRect, Qt::AlignCenter,
                     QString::number(angleLength * 100 / 360) + "%");
 
    /* 发光背景圆 */
    painter.translate(drawRect.width() >> 1, drawRect.height() >> 1);
    int radius = drawRect.width() / 2;
    /* radius<< 1(左移1位)相当于radius*2 */
    QRectF rect(-radius, -radius, radius << 1, radius << 1);
 
    QRadialGradient gradient3(0, 0, radius);
    gradient3.setColorAt(0, Qt::transparent);
    gradient3.setColorAt(0.42, Qt::transparent);
    gradient3.setColorAt(0.51, QColor("#500194d3"));
    gradient3.setColorAt(0.55, QColor("#22c1f3f9"));
    gradient3.setColorAt(0.58, QColor("#500194d3"));
    gradient3.setColorAt(0.68, Qt::transparent);
    gradient3.setColorAt(1.0, Qt::transparent);
    painter.setBrush(gradient3);
    QPainterPath path1;
    path1.arcTo(rect, startAngle, -angleLength);
    painter.setPen(Qt::NoPen);
    painter.drawPath(path1);
 
    /* 发光圆/弧 */
    QRadialGradient gradient4(0, 0, radius);
    gradient4.setColorAt(0, Qt::transparent);
    gradient4.setColorAt(0.49, Qt::transparent);
    gradient4.setColorAt(0.50, QColor("#4bf3f9"));
    gradient4.setColorAt(0.59, QColor("#4bf3f9"));
    gradient4.setColorAt(0.60, Qt::transparent);
    gradient4.setColorAt(1.0, Qt::transparent);
    painter.setBrush(gradient4);
    QPainterPath path2;
    path2.arcTo(rect, startAngle, -angleLength);
    painter.setPen(Qt::NoPen);
    painter.drawPath(path2);
 
    /* 恢复状态 */
    painter.restore();
 
    /* 设置事件对象的accept标志 */
    event->accept();


#include "arcgraph.h"ArcGraph::ArcGraph(QWidget *parent): QWidget(parent),startAngle(90),angleLength(100)
{this->setMinimumSize(100, 100);setAttribute(Qt::WA_TranslucentBackground, true);
}ArcGraph::~ArcGraph()
{
}void ArcGraph::setstartAngle(int angle)
{startAngle = angle;this->repaint();
}void ArcGraph::setangleLength(int length)
{angleLength = length;this->repaint();
}void ArcGraph::paintEvent(QPaintEvent *event)
{QPainter painter(this);/* 保存状态 */painter.save();/* 设置抗锯齿 */painter.setRenderHints(QPainter::Antialiasing, true);/* 最外层的圆 */QRect drawRect = event->rect();QRadialGradient gradient1(drawRect.center(),drawRect.width() / 2,drawRect.center());gradient1.setColorAt(0, Qt::transparent);gradient1.setColorAt(0.5, Qt::transparent);// 稍微增加透明部分的范围gradient1.setColorAt(0.51, QColor("#00237f"));// 开始显示深蓝色gradient1.setColorAt(0.58, QColor("#00237f"));// 保持深蓝色一段时间gradient1.setColorAt(0.59, Qt::transparent);// 渐变回透明gradient1.setColorAt(1, Qt::transparent);painter.setBrush(gradient1);painter.setPen(Qt::NoPen);painter.drawEllipse(drawRect);/* 里层的圆 */QRadialGradient gradient2(drawRect.center(),drawRect.width() / 2,drawRect.center());gradient2.setColorAt(0, Qt::transparent);gradient2.setColorAt(0.420, Qt::transparent);gradient2.setColorAt(0.421, QColor("#885881e3"));gradient2.setColorAt(0.430, QColor("#5881e3"));gradient2.setColorAt(0.440, QColor("#885881e3"));gradient2.setColorAt(0.441, Qt::transparent);gradient2.setColorAt(1, Qt::transparent);painter.setBrush(gradient2);painter.setPen(Qt::NoPen);painter.drawEllipse(drawRect);/* 数字 */QFont font;font.setPixelSize(drawRect.width() / 10);painter.setPen(Qt::white);painter.setFont(font);painter.drawText(drawRect, Qt::AlignCenter,QString::number(angleLength * 100 / 360) + "%");/* 发光背景圆 */painter.translate(drawRect.width() >> 1, drawRect.height() >> 1);int radius = drawRect.width() / 2;/* radius<< 1(左移1位)相当于radius*2 */QRectF rect(-radius, -radius, radius << 1, radius << 1);QRadialGradient gradient3(0, 0, radius);gradient3.setColorAt(0, Qt::transparent);gradient3.setColorAt(0.42, Qt::transparent);gradient3.setColorAt(0.51, QColor("#500194d3"));gradient3.setColorAt(0.55, QColor("#22c1f3f9"));gradient3.setColorAt(0.58, QColor("#500194d3"));gradient3.setColorAt(0.68, Qt::transparent);gradient3.setColorAt(1.0, Qt::transparent);painter.setBrush(gradient3);QPainterPath path1;path1.arcTo(rect, startAngle, -angleLength);painter.setPen(Qt::NoPen);painter.drawPath(path1);/* 发光圆/弧 */QRadialGradient gradient4(0, 0, radius);gradient4.setColorAt(0, Qt::transparent);gradient4.setColorAt(0.49, Qt::transparent);gradient4.setColorAt(0.50, QColor("#4bf3f9"));gradient4.setColorAt(0.59, QColor("#4bf3f9"));gradient4.setColorAt(0.60, Qt::transparent);gradient4.setColorAt(1.0, Qt::transparent);painter.setBrush(gradient4);QPainterPath path2;path2.arcTo(rect, startAngle, -angleLength);painter.setPen(Qt::NoPen);painter.drawPath(path2);/* 恢复状态 */painter.restore();/* 设置事件对象的accept标志 */event->accept();
}

#ifndef ARCGRAPH_H
#define ARCGRAPH_H#include <QWidget>
#include <QPainter>
#include <QPaintEvent>/* 蓝色科技感弧形视图 */
class ArcGraph : public QWidget
{Q_OBJECTpublic:ArcGraph(QWidget *parent = nullptr);~ArcGraph();void setstartAngle(int);void setangleLength(int);private:void paintEvent(QPaintEvent *event);int startAngle;int angleLength;
};
#endif // ARCGRAPH_H

应用:

ArcGraph *arcGraph=new ArcGraph;
arcGraph->setangleLength(als.toUInt() * 360 / 65535);

效果:

这篇关于QT 圆盘百分比的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Qt 中 isHidden 和 isVisible 的区别与使用小结

《Qt中isHidden和isVisible的区别与使用小结》Qt中的isHidden()和isVisible()方法都用于查询组件显示或隐藏状态,然而,它们有很大的区别,了解它们对于正确操... 目录1. 基础概念2. 区别清见3. 实际案例4. 注意事项5. 总结1. 基础概念Qt 中的 isHidd

QT移植到RK3568开发板的方法步骤

《QT移植到RK3568开发板的方法步骤》本文主要介绍了QT移植到RK3568开发板的方法步骤,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录前言一、获取SDK1. 安装依赖2. 获取SDK资源包3. SDK工程目录介绍4. 获取补丁包二

Qt把文件夹从A移动到B的实现示例

《Qt把文件夹从A移动到B的实现示例》本文主要介绍了Qt把文件夹从A移动到B的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录如何移动一个文件? 如何移动文件夹(包含里面的全部内容):如何删除文件夹:QT 文件复制,移动(

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用

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

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

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节