基于Qt/QChart实现折线图和散点图的绘制示例程序解析

devtools/2024/10/19 13:23:09/
1. 项目简介

本文讲解的是一个基于Qt框架的QChart模块实现的折线图与散点图结合的绘制程序。程序通过自定义类LineChartWithGradient实现折线图、散点图以及带有渐变填充的区域图,最终形成一个美观的数据可视化效果。

在这里插入图片描述

2. 类构造函数
LineChartWithGradient::LineChartWithGradient(QWidget *parent): QChartView(new QChart(), parent), m_series(new QLineSeries()), m_markerSeries(new QScatterSeries()), m_areaSeries(new QAreaSeries()) {
  • QChartView:用于显示图表的控件。
  • QLineSeries:用于绘制折线图的数据系列。
  • QScatterSeries:用于绘制散点图的数据系列。
  • QAreaSeries:实现区域填充,显示折线图下方的渐变颜色。

构造函数将这些系列对象初始化并将它们添加到图表中,确保折线图与散点图同步显示。

3. 添加折线、散点和区域系列
    m_areaSeries->setUpperSeries(m_series);  // 关联折线图与区域图m_markerSeries->setMarkerShape(QScatterSeries::MarkerShapeCircle);  // 设置散点图点的形状m_markerSeries->setMarkerSize(10.0);  // 设置点的大小m_markerSeries->setColor(Qt::red);  // 设置点的颜色chart()->addSeries(m_areaSeries);  // 将区域系列添加到图表chart()->addSeries(m_series);  // 添加折线系列chart()->addSeries(m_markerSeries);  // 添加散点系列
  • setUpperSeries:将m_series折线系列设置为区域系列的上边界。
  • QScatterSeries:设置散点的形状为圆形,大小为10像素,颜色为红色。
  • addSeries:将不同系列添加到图表,使得折线、区域和散点能够在同一图表中渲染。
4. 数据点设置
void LineChartWithGradient::setData(const QList<QPointF> &points) {m_series->replace(points);m_markerSeries->replace(points);applyGradient();  // 应用渐变效果chart()->update();
}
  • **setData**方法将数据点替换为传入的QList<QPointF>,确保折线图和散点图的数据同步更新。
  • applyGradient:在数据更新后重新应用渐变填充效果。
5. 坐标轴范围设置
void LineChartWithGradient::setXMinMaxvalue(const qreal min, const qreal max) {chart()->axes(Qt::Horizontal).first()->setRange(min, max);  // 设置X轴范围
}
void LineChartWithGradient::setYMinMaxvalue(const qreal min, const qreal max) {chart()->axes(Qt::Vertical).first()->setRange(min, max);  // 设置Y轴范围
}
  • **setXMinMaxvaluesetYMinMaxvalue**分别设置了图表X轴和Y轴的最小和最大值,确保图表在特定的范围内展示。
6. 初始化图表和样式
void LineChartWithGradient::setupChart() {chart()->setTitle(tc("散点渐变折点图"));  // 设置图表标题QPen pen(Qt::red);pen.setWidth(2);  // 设置折线的宽度m_series->setPen(pen);  // 应用折线的画笔样式applyGradient();  // 应用渐变效果
}
  • **setupChart**方法主要用于设置图表的初始样式,包括图表标题、折线宽度等。折线的宽度设置为2像素,颜色为红色。
7. 应用渐变效果
void LineChartWithGradient::applyGradient() {QLinearGradient gradient(QPointF(0, 0), QPointF(0, 1));  // 定义线性渐变gradient.setColorAt(0.0, Qt::red);  // 渐变起始颜色为红色gradient.setColorAt(1.0, Qt::transparent);  // 渐变终止颜色为透明gradient.setCoordinateMode(QGradient::ObjectBoundingMode);  // 以对象坐标模式计算渐变m_areaSeries->setBrush(gradient);  // 设置区域系列的画刷为渐变效果m_areaSeries->setPen(Qt::NoPen);  // 区域图无边框
}
  • **applyGradient**方法用于实现区域图的渐变效果。使用了QLinearGradient类实现线性渐变,从红色渐变到透明,并将其设置为QAreaSeries的填充画刷。
8. 图表效果展示

从附带的图片可以看出,图表包括以下几个部分:

  • 折线图显示数据的变化趋势。
  • 散点图标注了每个数据点的位置,圆点较大,颜色为红色。
  • 折线图下方有红色渐变填充区域,使得图表更具视觉效果。
  • X轴和Y轴都有明确的标度,背景采用深色主题,图表风格简洁明了。
总结

该程序通过Qt提供的图表模块,结合折线、散点和渐变区域图,实现了一个漂亮的散点折线图。程序中使用了大量自定义设置,例如图表样式、渐变效果等,使得图表在呈现数据的同时具有良好的视觉效果。

这种图表适用于展示数据变化趋势,同时突出关键数据点的情境,适合需要清晰展示和标记数据点的场景。


http://www.ppmy.cn/devtools/125302.html

相关文章

sql server 查看实际的执行计划

SET STATISTICS PROFILE ON select ** SET STATISTICS PROFILE off 范围标准分析轻型分析全局包含 query_post_execution_showplan XE 的 xEvent 会话&#xff1b;从 SQL Server 2012 (11.x) 开始跟踪标志 7412&#xff1b;从 SQL Server 2016 (13.x) SP1 开始全局包含 Showpl…

C语言刷题 LeetCode 删除单链表的重复节点 双指针法

题目要求 链表结构&#xff1a;题目中提到的是未排序的链表&#xff0c;链表是由一系列节点组成的&#xff0c;每个节点包含一个值&#xff08;数据&#xff09;和一个指向下一个节点的指针。去重&#xff1a;我们需要遍历链表&#xff0c;删除所有重复的节点&#xff0c;只保…

Python 与 Pycharm 的简易安装教程,包含Pycharm的修改

一. 官方网站 Python网址&#xff1a;python唯一的官方网址。 Pycharm网址&#xff1a;Pycharm的官方网址。 二. python安装步骤 滑动到红色框内 Downloads 导航栏。 红色框是选择适合自己电脑系统和版本的部分&#xff0c;蓝色框是选择系统的部分&#xff0c;黄色框是版本号。…

滑雪——记忆化搜索

题目 代码 //#pragma GCC optimize(3)#include <bits/stdc.h> const int N 310; using namespace std; int dx[4] {-1, 0, 1, 0}, dy[4] {0, 1, 0, -1}; int ans; int g[N][N]; int r, c; int f[N][N]; int dfs(int x, int y) {if(~f[x][y]) return f[x][y];f[x][y] …

SQLite Developer使用说明

1.SQLite Developer下载 SQLite Developer官方版是SharpPlus出品的一款数据库管理工具。支持对sqlite3数据库的管理&#xff0c;能够自动完成窗口显示和执行数据库命令等多种特色。并且支持打开.db文件&#xff0c;适用于Android的开发。另外&#xff0c;使用Sqlite Developer…

TCP/IP协议栈

一、TCP/IP和OSI模型的比较 相同点 两者都是以协议栈的概念为基础 协议栈中的协议彼此相互独立 下层对上层提供服务 不同点 OSI是先有模型&#xff1b;TCP/IP是先有协议&#xff0c;后有模型 OSI是国际标准&#xff0c;适用于各种协议栈&#xff1b;TCP/IP实际标准&…

opencv-rust 系列: 1, 安装及运行自带示例和测试程序

opencv-rust 系列: 1, 安装及运行自带示例和测试程序 运行环境: ubuntu ; rust 已安装; 对rust的掌握为三脚猫程度一. opencv-rust安装:二. 运行自带examples和tests 运行环境: ubuntu ; rust 已安装; 对rust的掌握为三脚猫程度 一. opencv-rust安装: 安装软件: sudo apt in…

我们是如何将Docker构建时间缩短40%的

by: WL Mapmost从设计之初&#xff0c;便选择了云原生道路&#xff0c;在软件开发过程中自然也少不了容器化技术的使用。当然&#xff0c;我们也为Mapmost产品中使用的所有组件构建了 docker 镜像。然而&#xff0c;随着时间的推移&#xff0c;其中一些镜像变得越来越大&#…