标题:Qt编写自定义控件71-圆弧进度条
作者:liudianwu
日期:2019-10-16 13:02
内容:
一、前言
现在web形式的图表框架非常流行,国产代表就是echart,本人用过几次,三个字屌爆了来形容,非常强大,而且易用性也非常棒,还是开源免费的,使用起来不要太爽,内置的各种图表和仪表盘等非常丰富,展现形式也是非常多样的。
本次要写的圆弧进度条,就是参考自echart中的一个圆弧进度条,主要结构就是外围一圈圆角进度,中间加上标题和对应进度的百分比,进度条的起始角度和结束角度可以自行调整,这样的话进度条的开口就可以在左边右边上边下边等任意位置,通过调整角度就能实现。绘制的核心就是drawArc函数。
二、实现的功能
* 1:可设置范围值,支持负数值
* 2:可设置精确度,最大支持小数点后3位
* 3:可设置圆弧宽度
* 4:可设置开始旋转角度/结束旋转角度
* 5:可设置仪表盘的标题
* 6:可设置背景颜色/进度颜色/值颜色/文字颜色
* 7:自适应窗体拉伸,文字自动缩放
* 8:可自由拓展各种渐变色
* 9:可设置百分比模式,自动计算值换算成百分比
三、效果图

四、头文件代码
#ifndef PROGRESSARC_H
#define PROGRESSARC_H
/**
* 百分比仪表盘控件 作者:feiyangqingyun(QQ:517216493) 2018-8-30
* 1:可设置范围值,支持负数值
* 2:可设置精确度,最大支持小数点后3位
* 3:可设置圆弧宽度
* 4:可设置开始旋转角度/结束旋转角度
* 5:可设置仪表盘的标题
* 6:可设置背景颜色/进度颜色/值颜色/文字颜色
* 7:自适应窗体拉伸,文字自动缩放
* 8:可自由拓展各种渐变色
* 9:可设置百分比模式,自动计算值换算成百分比
*/
#include
#ifdef quc
#if (QT_VERSION < QT_VERSION_CHECK(5,7,0))
#include
#else
#include
#endif
class QDESIGNER_WIDGET_EXPORT ProgressArc : public QWidget
#else
class ProgressArc : public QWidget
#endif
{
Q_OBJECT
Q_PROPERTY(double minValue READ getMinValue WRITE setMinValue)
Q_PROPERTY(double maxValue READ getMaxValue WRITE setMaxValue)
Q_PROPERTY(double value READ getValue WRITE setValue)
Q_PROPERTY(int pr ..
#1 [zhanglyl 10-16 13:42]
#2 [a13152772488 10-16 13:58]