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();
}
  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

制造垃圾代码的垃圾coder一个

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值