Qt自定义控件实现圆圈加载进度条
本文实例为大家分享了Qt实现圆圈加载进度条的具体代码,供大家参考,具体内容如下
先看效果图:
思路:画一个占270度的圆弧,然后定义一个定时器,定时旋转坐标系,实现旋转的效果。圆弧需要使用渐变色,实现颜色越来越浅的效果
关键代码:CMProcessBar1.cpp
CMProcessBar1::CMProcessBar1(QWidget*parent): QWidget(parent), ui(newUi::CMProcessBar1) { ui->setupUi(this); QTimer*timer=newQTimer; connect(timer,QTimer::timeout,this,updaterRotation);//定时旋转坐标系 timer->start(3);//定时3毫秒 } CMProcessBar1::~CMProcessBar1() { deleteui; } voidCMProcessBar1::updaterRotation(){//循环360度旋转坐标系 rotation++; if(rotation==360){ rotation=0; } update(); } voidCMProcessBar1::paintEvent(QPaintEvent*event){//根据QPaintPath画出渐变色的圆弧 intwidth=this->width(); intheight=this->height(); intside=qMin(width,height); QPainterpainter(this); painter.setRenderHints(QPainter::Antialiasing|QPainter::TextAntialiasing); painter.translate(width/2,height/2); painter.scale(side/200.0,side/200.0); QConicalGradientgra(QPoint(0,0),0); gra.setColorAt(0,QColor("#3BB6FE")); gra.setColorAt(1,QColor("#FFFFFF")); QBrushbrush(gra); intradis=40; intsider=5; QRectrect(-radis,-radis,radis*2,radis*2); QPainterPathpath; path.arcTo(rect,0,270); QPainterPathsubPath; subPath.addEllipse(rect.adjusted(sider,sider,-sider,-sider)); path=path-subPath; painter.setBrush(brush);//QColor("#66CFFF") painter.setPen(Qt::NoPen); painter.rotate(rotation); painter.drawPath(path); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。