QT绘制同心扇形

cpp 复制代码
void ChartForm::paintEvent(QPaintEvent *)
{
    QPainter painter(this);
    painter.setRenderHint(QPainter::Antialiasing);// 设置抗锯齿
    painter.save();

    // 设置无边框(不需要设置QPen,因为默认是不绘制边框的)
    QPen pen(Qt::NoPen);
    // QPen pen(Qt::black, 1);
    painter.setPen(pen);

    QRect rect;

    int step = 50;          // 内圈和外圈的距离
    int sRange = 8;         // 扇形向外绘制的范围(圈数)
    int numSlices = 16;     // 分成多少个扇形
    int lenght = 2 * step;  // 矩形边长
    // 计算扇形的中心点、半径、起始角度和跨度角度
    int centerX = width() / 2;
    int centerY = height() / 2;

    // 生成颜色(这里简单地使用彩虹色)
    QVector<QColor> colors;
    for (int i = 0; i <= sRange; ++i)
    {
        float hue = (float)i / sRange * 360.0f;
        colors.append(QColor::fromHsvF(hue / 360.0f, 1.0f, 1.0f));
    }

    // 绘制每个扇形
    for (int i = 0; i < numSlices; ++i)
    {
        double startAngle = i * 360.0f / numSlices;
        double spanAngle = 360.0f / numSlices;

        for(int idx = 1; idx <= sRange; idx ++)
        {
            QPoint startPt(centerX - idx * step, centerY - idx * step);
            rect.setRect(startPt.x(), startPt.y(), lenght + idx * lenght, lenght + idx * lenght);// 外圈

            int inRadius = idx * lenght;

            QRectF innerRect(startPt.x() + step, startPt.y() + step,inRadius,inRadius);// 内圈

            QPointF outStartPoint;
            outStartPoint.rx() += rect.center().x();
            outStartPoint.ry() = rect.center().y() - outStartPoint.y();

            QPainterPath path;// 创建一个QPainterPath对象
            path.moveTo(outStartPoint); //先移动到圆心
            path.arcTo(rect, startAngle, spanAngle);// 参数(矩形左上角坐标,弧的宽度,弧的高度,起始角,画多少度)
            path.arcTo(innerRect, startAngle + spanAngle, -spanAngle);// 参数(矩形左上角坐标,弧的宽度,弧的高度,起始角,画多少度)
            path.closeSubpath(); // 闭合路径(可选)
            painter.setBrush(colors[idx]);
            painter.drawPath(path);
        }
    }
    painter.restore();
}

执行结果如下图所示:

相关推荐
上去我就QWER1 小时前
Qt中如何获取系统版本信息
开发语言·qt
十五年专注C++开发10 小时前
Qt-Nice-Frameless-Window: 一个跨平台无边框窗口(Frameless Window)解决方案
开发语言·c++·qt
江公望11 小时前
装了新的QtCreator17,没有用Qt5.12自带的QtCreator4,导致QtCreator17无法找到Qt5.12帮助文档
qt·qml
ctgu9014 小时前
PyQt5(八):ui设置为可以手动随意拉伸功能
开发语言·qt·ui
进击的大海贼16 小时前
QT/C++ 消息定时管理器
开发语言·c++·qt
Lj2_jOker17 小时前
QT 给Qimage数据赋值,显示异常,像素对齐的坑
开发语言·前端·qt
孤独的追光者21 小时前
使用Qt Designer开发上位机
开发语言·python·qt
Molesidy1 天前
【随笔】【QT】QT5.15.2版本的最新下载方式!!!
开发语言·qt
梨轻巧1 天前
pyside6的历史发展、Qt 介绍、PyQt 和 pyside6对比
qt·pyqt
恋恋西风2 天前
Qt 打开文件列表选择文件,实现拖拽方式打开文件,拖拽加载
开发语言·qt