这篇文章主要介绍Qt自定义控件如何实现线条型加载条,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
本文实例为大家分享了Qt自定义控件实现线条型加载条的具体代码,供大家参考,具体内容如下
上效果图:
思路:先画一个线条,然后旋转坐标系再画其他线条,突出颜色的线条可以画死再旋转,也可以按照角度递增让特定线画突出颜色(这里使用的是这种)。
LoadingBarA::LoadingBarA(QWidget*parent):
QWidget(parent)
{
timer=newQTimer(this);//定时器
timer->setInterval(50);
connect(timer,QTimer::timeout,this,[=](){
if(pointRect<=rectCount){
pointRect++;
}else{
pointRect=pointRect%rectCount;
}
update();
});
}
voidLoadingBarA::paintEvent(QPaintEvent*event){//重绘事件
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);
floatdegree=360.0/rectCount;//rectCount:共有多少根线条
for(inti=0;i<rectCount;i++){
painter.rotate(degree);
if(i==pointRect-1){
drawRect(&painter,darkColor);//突出颜色
}else{
drawRect(&painter,lightColor);//非突出颜色
}
}
}
voidLoadingBarA::drawRect(QPainter*painter,QColorcolor){//画线条
painter->save();
painter->setPen(Qt::NoPen);
painter->setBrush(color);
QRectrect(arcLength,-rectHeight/2,rectWidth,rectHeight);
painter->drawRoundedRect(rect,rectHeight/2,rectHeight/2);
painter->restore();
}
voidLoadingBarA::setDarkColor(QColortempColor){
this->darkColor=tempColor;
update();
}
voidLoadingBarA::setLightColor(QColorlightColor){
this->lightColor=lightColor;
update();
}
voidLoadingBarA::setRectWidth(intl){
this->rectWidth=l;
update();
}
voidLoadingBarA::setRectHeight(intl){
this->rectHeight=l;
update();
}
voidLoadingBarA::setArcLength(intl){
this->arcLength=l;
update();
}
voidLoadingBarA::setRectCount(intl){
this->rectCount=l;
update();
}
voidLoadingBarA::startLoading(){//设置开始
timer->start();
}
以上是“Qt自定义控件如何实现线条型加载条”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注恰卡编程网行业资讯频道!