首页 > 作文

Qt编写提示进度条的实现示例

更新时间:2023-04-04 07:13:36 阅读: 评论:0

目录
一、前言 二、实现的功能 三、效果图四、头文件代码 五、核心代码 六、控件介绍

一、前言

我们在很多的安装包中,在安装过程中,经常可以在底部看到一个漂亮的进度条,上面悬浮着显示对应的进度,然后底部进度多种颜色渐变展示,qt自带的进度条或者操作系统的进度条样式,不够炫,这次索性直接来个自定义绘制实现,至于是继承qwidget类还是qprogressbar类,都无所谓,如果是继承自qwidget类的话,就需要自己设置最大值最小值范围值,而继承自qprogressbar的话就可以直接用自带的函数来实现。这次编写的进度条,提示信息的背景色也是和下面的进度颜色完全一致跟着变化的。

二、实现的功能

1:可设置最小值/最大值/范围值/当前值
2:可设置是否百分比显示
3:可设置边距,流出空隙防止提示信息跑到外面
4:可设置进度的颜色,可以是渐变画刷
5:可设置背景颜色/文字颜色/提示背景
6:可设置圆角角度
7:如果设置了进度画刷则提示背景也采用该画刷

三、效果图

四、头文件代码

#ifndef progresstip_h#define progresstip_h/** * 提示进度条控件 作者:feiyangqingyun(qq:517216493) 2019-10-05 * 1:可设置最小值/最大值/范围值/当前值 * 2:可设置是否百分比显示 * 3:可设置边距,流出空隙防止提示信息跑到外面 * 4:可设置进度的颜色,可以是渐变画刷 * 5:可设置背景颜色/文字颜色/提示背景 * 6:可设置圆角角度 * 7:如果设置了进度画刷则提示背景也采用该画刷 */#include <qwidget>#ifdef quc#if (qt_version < qt_version_check(5,7,0))#include <qtdesigner/qdesignerexportwidget>#el#include <qtuiplugin/qdesignerexportwidget>#endifclass qdesigner_widget_export progresstip : public qwidget#elclass progresstip : public qwidget#endif{    q_object    q_property(double minvalue read getminvalue write tminvalue)    q_property(double maxvalue read getmaxvalue write tmaxvalue)    q_property(double value read getvalue write tvalue)    q_property(bool percent read getpercent write tpercent)    q_property(int padding read getpadding write tpadding)    q_property(int radius read getradius write tradius)    q_property(qbrush valuebrush read getvaluebrush write tvaluebrush)    q_property(qcolor valuecolor read getvaluecolor write tvaluecolor)    q_property(qcolor bgcolor read getbgcolor write tbgcolor)    q_property(qcolor tipcolor read gettipcolor write ttipcolor)    q_property(qcolor textcolor read gettextcolor write ttextcolor)public:    explicit progresstip(qwidget *parent = 0);protected:    void paintevent(qpaintevent *);        void drawbg(qpainter *painter);    void drawtip(qpainter *painter);    void drawvalue(qpainter *painter);private:    double minvalue;            //万芳好听的歌最小值    double maxvalue;            //最大值    double value;               //目标值    bool percent;               //百分比显示    int padding;                //边距    int radius;                 //圆角角度    qbrush valuebrush;          //进度画刷    qcolor valuecolor;          //进度颜色    qcolor bgcolor;             //背景颜色    qcolor tipcolor;            //提示背景颜色    qcolor textcolor;           //文字颜色public:    double getminvalue()        const;    double getmaxvalue()        const;    double getvalue()           const;    bool getpercent()           const;    int getpadding()            const;    int getradius()             const;    qbrush getvaluebrush()      const;    qcolor getvaluecolor()      const;    qcolor getbgcolor()         const;    qcolor gettipcolor()        const;    qcolor gettextcolor()       const;    qsize sizehint()            const;    qsize minimumsizehint()     const;public q_slots:    //设置范围值    void trange(double minvalue, double maxvalue);    void trange(int minvalue, int maxvalue);    //设置最大最小值    void tminvalue(double minvalue);    void tmaxvalue(double maxvalue);    //设置目标值    void tvalue(double value);    void tvalue(int value);    //设置百分比显示    void tpercent(bool percent);    //设置边距    void tpadding(int padding);    //设置圆角角度    void tradius(int radius);    //设置进度画刷+进度颜色+背景颜色+提示背景+文字颜色    void tvaluebrush(const qbrush &valuebrush);    void tvaluecolor(const qcolor &valuecolor);    void tbgcolor(const qcolor &bgcolor);    void ttipcolor(const qcolor &tipcolor);    void ttextcolor(const qcolor &textcolor);q_signals:    void valuechanged(double value);};#endif // progressplay_h

五、核心代码

void progresstip::paintevent(qpaintevent *){    //绘制准备工作,启用反锯齿,平移坐标轴中心,等比例缩放    qpainter painter(this);    painter.trenderhints(qpainter::antialiasing | qpainter::textantialiasing);    //绘制背景    drawbg(&painter);    //绘制上部分提示信息    drawtip(&painter);    //绘制进度    drawvalue(&painter);}void progresstip::drawbg(qpainter *painter){    painter->save();    painter->tpen(qt::nope季羡林的故事n);    painter->tbrush(bgcolor);    qrect rect(padding, (height() / 3) * 2, width() - padding * 2, height() / 3);    painter->drawroundedrect(rect, radius, radius);    painter->restore();}void progresstip::drawtip(qpainter *painter){    painter->save();    painter->tpen(qt::nopen);    painter->tbrush(valuebrush == qt::nobrush ? tipcolor : valuebrush);    //计算当前值对应的百分比    double step = valu低碳环保论文e / (maxvalue - minvalue);    int progress = (width() - padding * 2) * step;    //绘制上部分提示信息背景    qrect rect(progress, 0, padding * 2, (double)height() / 2.1);    painter->drawroundedrect(rect, 2, 2);    //绘制倒三角    int centerx = rect.center().x();    int inity = rect.height();    int offt = 5;    qpolygon pts;    pts.append(qpoint(centerx - offt, inity));    pts.append(qpoint(centerx + offt, inity));    pts.append(qpoint(centerx, inity + offt));    painter->drawpolygon(pts);    //绘制文字    qstring strvalue;    if (percent) {        double temp = value / (maxvalue - minvalue) * 100;        strvalue = qstring("%1%").arg(temp, 0, 'f', 0);    } el {        strvalue = qstring("%1").arg((double)value, 0, 'f', 0);    }    painter->tp制造业企业en(textcolor);    painter->drawtext(rect, qt::aligncenter, strvalue);    painter->restore();}void progresstip::drawvalue(qpainter *painter){    painter->save();    painter->tpen(qt::nopen);    //定义了画刷则取画刷,可以形成渐变效果    painter->tbrush(valuebrush == qt::nobrush ? valuecolor : valuebrush);    //计算当前值对应的百分比    double step = value / (maxvalue - minvalue);    int progress = (width() - padding * 2) * step;    qrec单数变复数的规则t rect(padding, (height() / 3) * 2, progress, height() / 3);    painter->drawroundedrect(rect, radius, radius);    painter->restore();}

六、控件介绍

超过160个精美控件,涵盖了各种仪表盘、进度条、进度球、指南针、曲线图、标尺、温度计、导航条、导航栏,flatui、高亮按钮、滑动选择器、农历等。远超qwt集成的控件数量。每个类都可以独立成一个单独的控件,零耦合,每个控件一个头文件和一个实现文件,不依赖其他文件,方便单个控件以源码形式集成到项目中,较少代码量。qwt的控件类环环相扣,高度耦合,想要使用其中一个控件,必须包含所有的代码。全部纯qt编写,qwidget+qpainter绘制,支持qt4.6到qt5.13的任何qt版本,支持mingw、msvc、gcc等编译器,支持任意操作系统比如windows+linux+mac+嵌入式linux等,不乱码,可直接集成到qt creator中,和自带的控件一样使用,大部分效果只要设置几个属性即可,极为方便。每个控件都有一个对应的单独的包含该控件源码的demo,方便参考使用。同时还提供一个所有控件使用的集成的demo。每个控件的源代码都有详细中文注释,都按照统一设计规范编写,方便学习自定义控件的编写。每个控件默认配色和demo对应的配色都非常精美。超过130个可见控件,6个不可见控件。部分控件提供多种样式风格选择,多种指示器样式选择。所有控件自适应窗体拉伸变化。集成自定义控件属性设计器,支持拖曳设计,所见即所得,支持导入导出xml格式。自带activex控件demo,所有控件可以直接运行在ie浏览器中。集成fontawesome图形字体+阿里巴巴iconfont收藏的几百个图形字体,享受图形字体带来的乐趣。所有控件最后生成一个动态库文件(dll或者so等),可以直接集成到qtcreator中拖曳设计使用。目前已经有qml版本,后期会考虑出pyqt版本,如果用户需求量很大的话。自定义控件插件开放动态库使用(永久免费),无任何后门和限制,请放心使用。目前已提供32个版本的dll,其中qt_5_7_0_mingw530_32这个版本会一直保证最新的完整的。不定期增加控件和完善控件,不定期更新sdk,欢迎各位提出建议,谢谢!qt入门书籍推荐霍亚飞的《qt creator快速入门》《qt5编程入门》,qt进阶书籍推荐官方的《c++ gui qt4编程》。强烈推荐程序员自我修养和规划系列书《大话程序员》《程序员的成长课》《解忧程序员》,受益匪浅,受益终生!

sdk地址:https://gitee.com/feiyangqingyun/qucsdk

https://github.com/feiyangqingyun/qucsdk

到此这篇关于qt编写提示进度条的实现示例的文章就介绍到这了,更多相关qt 提示进度条内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-04 07:13:34,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/b78513ec0005135f3fee84920831fce9.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:Qt编写提示进度条的实现示例.doc

本文 PDF 下载地址:Qt编写提示进度条的实现示例.pdf

标签:控件   颜色   进度   背景
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图