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();
}

执行结果如下图所示:

相关推荐
我是菜鸟0713号2 天前
Qt 中 OPC UA 通讯实战
开发语言·qt
JCBP_2 天前
QT(4)
开发语言·汇编·c++·qt·算法
lqjun08273 天前
Qt程序单独运行报错问题
开发语言·qt
酷飞飞3 天前
Qt Designer与事件处理
开发语言·qt·命令模式
mkhase3 天前
9.12-QT-基本登陆界面实现
java·jvm·qt
咕噜咕噜啦啦3 天前
Qt之快捷键、事件处理、自定义按键——完成记事本项目
开发语言·qt
Quz3 天前
QML Charts组件之折线图的鼠标交互
qt
眠りたいです3 天前
基于脚手架微服务的视频点播系统-数据管理与网络通信部分的预备工作
c++·qt·ui·微服务·云原生·架构·媒体
bikong73 天前
Qt/C++,windows多进程demo
c++·windows·qt
油炸自行车3 天前
【Qt】Window环境下搭建Qt6、MSVC2022开发环境(无需提前安装Visual Studio)
qt·visual studio·qt6·msvc2022·qt creator 17.0