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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。