Qt扫盲-QScatterSeries理论总结

QScatterSeries是Qt用于创建散点图的数据类,继承自QXYSeries。它可以展示数据点并支持自定义形状和大小。创建散点图包括创建系列对象、添加数据点、设置形状和大小,以及将系列添加到图表中。此外,还能通过设置坐标轴和图例增强可视化效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、概述

QScatterSeries 类以散点图的形式呈现数据。散点数据在图表上显示为点的集合。对于每个点,都指定了两个值,用于确定它在水平轴和垂直轴上的位置。同时,这个这个类是继承至 QXYSeries 类,散点图的很多功能特性和 QLineSeries 和 QSplineSeries 基本一致的。都是横纵坐标代表一个数据。使用的一些概念的话 可以参考我的这边 Qt扫盲-QXYSeries理论总结。 这个 类其实也就是描述这个图含有的数据属性。至于绘图其实就是绘图控件的事情啦。

在这里插入图片描述

二、使用

最简单的一个流程用法就是:

  • 声明一个这个图数据的对象,
  • 对这个对象赋值和设置属性
  • 把这个图数据放到显示这个图的控件上就行。
  QScatterSeries* series = new QScatterSeries();
  series->append(0, 6);
  series->append(2, 4);
  ...
  chart->addSeries(series);

三、扩展

散点图提供了两种散点的形状

  • QScatterSeries::MarkerShapeCircle :圆形(默认的)

  • QScatterSeries::MarkerShapeRectangle :方形

但是我们可以可以自己绘制这个散点的形状,像上面的五角星即是自己绘制的形状

四、扩展使用

1.创建描述散点图对象

要创建散点图,需要一个QScatterSeries实例。这里我们创建了3个散点序列实例,并设置了散点形状和散点大小。

  QScatterSeries *series0 = new QScatterSeries();
  series0->setName("scatter1");
  series0->setMarkerShape(QScatterSeries::MarkerShapeCircle);
  series0->setMarkerSize(15.0);

  QScatterSeries *series1 = new QScatterSeries();
  series1->setName("scatter2");
  series1->setMarkerShape(QScatterSeries::MarkerShapeRectangle);
  series1->setMarkerSize(20.0);

  QScatterSeries *series2 = new QScatterSeries();
  series2->setName("scatter3");
  series2->setMarkerShape(QScatterSeries::MarkerShapeRectangle);
  series2->setMarkerSize(30.0);

2. 对散点图像添加值

我们添加要显示的数据。我们可以使用append()成员函数,也可以使用流操作符。

  series0->append(0, 6);
  series0->append(2, 4);
  series0->append(3, 8);
  series0->append(7, 4);
  series0->append(10, 5);

  *series1 << QPointF(1, 1) << QPointF(3, 3) << QPointF(7, 6) << QPointF(8, 3) << QPointF(10, 2);
  *series2 << QPointF(1, 5) << QPointF(4, 6) << QPointF(6, 3) << QPointF(9, 5);

3. 自定义散点

我们可以将散点形状的Brush定义为QPainter 。这里的QPainter 是使用QPainterPath创建的星形。

  QPainterPath starPath;
  starPath.moveTo(28, 15);
  for (int i = 1; i < 5; ++i) {
      starPath.lineTo(14 + 14 * qCos(0.8 * i * M_PI),
                      15 + 14 * qSin(0.8 * i * M_PI));
  }
  starPath.closeSubpath();

  QImage star(30, 30, QImage::Format_ARGB32);
  star.fill(Qt::transparent);

  QPainter painter(&star);
  painter.setRenderHint(QPainter::Antialiasing);
  painter.setPen(QRgb(0xf6a625));
  painter.setBrush(painter.pen().color());
  painter.drawPath(starPath);

  series2->setBrush(star);
  series2->setPen(QColor(Qt::transparent));

4. 将绘图设备与散点图对象联系

最后我们启用反锯齿,设置图表标题,并将散点序列添加到图表中。我们还禁用了投影,因为它在只显示图表视图的应用程序上看起来不太好。

  setRenderHint(QPainter::Antialiasing);
  chart()->addSeries(series0);
  chart()->addSeries(series1);
  chart()->addSeries(series2);

  chart()->setTitle("Simple scatterchart example");
  chart()->createDefaultAxes();
  chart()->setDropShadowEnabled(false);

5. 设置坐标轴

我们也可以使用散点作为图例标记。

 chart()->legend()->setMarkerShape(QLegend::MarkerShapeFromSeries);

6. 将绘图设备与GUI控件绑定并显示

图表已经准备好了。

ChartView *chartView = new ChartView();
QMainWindow window;
window.setCentralWidget(chartView);
window.resize(400, 300);
window.show();
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

太阳风暴

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

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

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

打赏作者

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

抵扣说明:

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

余额充值