当前位置: 首页 > news >正文

QT绘制同心扇形

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

执行结果如下图所示:

 

http://www.lryc.cn/news/505869.html

相关文章:

  • 2012年西部数学奥林匹克试题(几何)
  • 8位移位寄存器的verilog语言
  • 【苍穹外卖】学习心得体会-随笔
  • MySQL学习之表的增删改
  • 电脑excel词典(xllex.dll)文件丢失是或损坏是什么原因?“xllex.dll文件缺失“要怎么解决?
  • 【CSS in Depth 2 精译_084】第 14 章:CSS 蒙版、形状与剪切概述 + 14.1:CSS 滤镜
  • gorm源码解析(四):事务,预编译
  • 前端优雅(装逼)写法(updating····)
  • 黑马Java面试教程_P7_常见集合_P4_HashMap
  • 使用 CFD 加强水资源管理:全面概述
  • XXE练习
  • R语言读取hallmarks的gmt文档的不同姿势整理
  • 【Nginx-4】Nginx负载均衡策略详解
  • Python 的 Decimal的错误计算
  • 【韩顺平 Java满汉楼项目 控制台版】MySQL+JDBC+druid
  • 【HAL库】STM32CubeMX开发----STM32F407----Time定时器中断实验
  • react18+ts 封装图表及词云组件
  • 图像根据mask拼接时,边缘有色差 解决
  • 17、ConvMixer模型原理及其PyTorch逐行实现
  • Spring整合Redis基本操作步骤
  • STM32使用SFUD库驱动W25Q64
  • ArKTS基础组件
  • 如何理解TCP/IP协议?如何理解TCP/IP协议是什么?
  • 如何使用 Python 连接 SQLite 数据库?
  • 【博弈模型】古诺模型、stackelberg博弈模型、伯特兰德模型、价格领导模型
  • 单片机:实现花样灯数码管的显示(附带源码)
  • 什么是芯片电阻
  • 【C++】sophus : geometry.hpp 位姿(SE2 和 SE3)和(2D 直线\3D 平面)转换函数 (五)
  • moment()获取时间
  • Azure虚拟机非托管磁盘大小调整