如何使用Qt自定义控件实现圆盘进度条

这篇文章主要介绍如何使用Qt自定义控件实现圆盘进度条,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

公司主营业务:成都做网站、网站设计、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出润州免费做网站回馈大家。

具体内容如下

自定义控件二:圆盘进度条

主要思路:使用qpainter根据图形需求 画圆和圆弧,画指针(多边形,指定坐标即可),根据具体的value值旋转坐标系,使指针达到旋转效果,旋转度数是根据value值,总共360度,占比求得。最中间需要画文字上去,每次更新value时调用update()方法,重绘界面。

主要代码:CMPassrate1.cpp

void CMPassrate1::paintEvent(QPaintEvent *event){  int width = this->width();  int height = this->height();  int side = qMin(width, height);  QPainter painter(this);  painter.setRenderHints(QPainter::Antialiasing | QPainter::TextAntialiasing);  painter.translate(width / 2, height / 2);  painter.scale(side / 200.0, side / 200.0);  //绘制外圆  paintSide(&painter);  paintOutE(&painter);    paintLine(&painter);//绘制刻度线  paintInE(&painter);  paintPoint(&painter);//绘制指针  paintTextE(&painter);//绘制文字所在的圆  paintText(&painter);//绘制文字  paintValue(&painter);//绘制value对应的填充角度}void CMPassrate1::paintSide(QPainter *painter){  int radis = outRadis;  QRect rect(-radis,-radis,radis*2,radis*2);  painter->save();  painter->setBrush(QBrush(QColor("#505050")));  painter->setPen(Qt::NoPen);  painter->drawEllipse(rect);  painter->restore();}void CMPassrate1::paintOutE(QPainter *painter){  int radis = outRadis-side;  QRect rect(-radis,-radis,radis*2,radis*2);  painter->save();  painter->setBrush(QBrush(QColor("#868686")));  painter->setPen(Qt::NoPen);  painter->drawEllipse(rect);  painter->restore();}void CMPassrate1::paintLine(QPainter *painter){  int lineStart = outRadis-3;  painter->save();  painter->setPen(QColor("#868686"));  int range = 360/12;  for(int i = 0;i<12;i++){    painter->rotate(range);    painter->drawLine(QPoint(lineStart,0),QPoint(outRadis,0));  }  painter->restore();}void CMPassrate1::paintInE(QPainter *painter){  int radis = inRadis;  QRect rect(-radis,-radis,radis*2,radis*2);  painter->save();  painter->setBrush(QBrush(QColor("#646464")));  painter->setPen(Qt::NoPen);  painter->drawEllipse(rect);  painter->restore();}void CMPassrate1::paintTextE(QPainter *painter){  int radis = 23;  QRect rect(-radis,-radis,radis*2,radis*2);  painter->save();  painter->setBrush(QBrush(QColor("#FFFFFF")));  painter->setPen(Qt::NoPen);  painter->drawEllipse(rect);  painter->restore();}void CMPassrate1::paintPoint(QPainter *painter){   painter->save();   const QPoint points[3] = {       QPoint(10,0),       QPoint(-10,0),       QPoint(0,inRadis-5)     };   int range = ((double)value/100)*360;   painter->rotate(range);   painter->setPen(Qt::NoPen);   painter->setBrush(QBrush(QColor("#66CFFF")));   painter->drawConvexPolygon(points,3);   painter->restore();}void CMPassrate1::paintText(QPainter *painter){  int radis = 23;  QRect rect(-radis,-radis,radis*2,radis*2);  painter->save();  painter->setBrush(QBrush(QColor("#000000")));  painter->setPen(QPen(QColor("#000000")));  QFont font = painter->font();  font.setPixelSize(20);  painter->setFont(font);  painter->drawText(rect,Qt::AlignCenter,QString("%1%").arg(QString::number(value)));  painter->restore();}void CMPassrate1::paintValue(QPainter *painter){  int oRandis = outRadis-side;  qDebug()<<"value::"<<value;  int rangle = ((double)value/100)*360;  QRectF rect(-oRandis, -oRandis, oRandis << 1, oRandis << 1);  QPainterPath path;  qDebug()<<"rangle:"<<rangle<<" start:"<<270-rangle;  path.arcTo(rect, 270-rangle, rangle);  // QRectF(-120, -120, 240, 240)  QPainterPath subPath;  subPath.addEllipse(rect.adjusted((oRandis-inRadis),(oRandis-inRadis),-(oRandis-inRadis),-(oRandis-inRadis)));  // path为扇形 subPath为椭圆  path -= subPath;  painter->save();  painter->setBrush(valueColor);  painter->setPen(Qt::NoPen);  painter->drawPath(path);  painter->restore();}

以上是“如何使用Qt自定义控件实现圆盘进度条”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!

网页题目:如何使用Qt自定义控件实现圆盘进度条
本文URL:https://www.cdcxhl.com/article4/pessoe.html

成都网站建设公司_创新互联,为您提供App设计外贸建站手机网站建设软件开发品牌网站设计

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都seo排名网站优化