Qt QCustomPlot画色阶图

        工作中用到QCustomPlot画曲线图和色阶图,并且在色阶图上添加文字,圆圈或者几条线段画一些图形,这里写个简单的例子把这几个功能记录一下,代码在这里: 

https://download.csdn.net/download/Sakuya__/89681279icon-default.png?t=N7T8https://download.csdn.net/download/Sakuya__/89681279        本文代码效果如下:


 代码之路

        MainWindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include "CustomPlot/qcustomplot.h"#include <QMainWindow>QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();// 初始化界面void initWindow();private slots:void on_Btn_Clear_clicked();void on_Btn_AddText_clicked();void on_Btn_AddEllipse_clicked();void on_Btn_AddLine_clicked();private:Ui::MainWindow *ui;QVector<QCPItemText*> m_itemText;           // 文字QVector<QCPItemEllipse*> m_itemEllipse;     // 圆QVector<QCPItemLine*> m_itemLine;           // 线
};
#endif // MAINWINDOW_H

        MainWindow.cpp

#include "MainWindow.h"
#include "ui_MainWindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);initWindow();
}MainWindow::~MainWindow()
{delete ui;
}void MainWindow::initWindow()
{// 配置轴矩形,允许通过拖拽/缩放尺度改变颜色范围ui->customPlot->setInteractions(QCP::iRangeDrag|QCP::iRangeZoom| QCP::iSelectPlottables);ui->customPlot->axisRect()->setupFullAxesBox(true);// 设置x轴和y轴的坐标轴名字ui->customPlot->xAxis->setLabel("横向距离(m)");ui->customPlot->yAxis->setLabel("纵向距离(m)");// 创建QCPColorMap对象QCPColorMap *colorMap = new QCPColorMap(ui->customPlot->xAxis, ui->customPlot->yAxis);colorMap->setAntialiased(true);// 设置QCPColorMap的数据点为 nx*ny 个int nx = 257;int ny = 257;colorMap->data()->setSize(nx, ny);// 设置X轴和Y轴的坐标范围colorMap->data()->setRange(QCPRange(-3, 3), QCPRange(-3, 3));// 打开文件,读取数据QFile file(":/Resouce/data.txt");file.open(QIODevice::ReadOnly | QIODevice::Text);QTextStream in(&file);QList<double> data;while (!in.atEnd()){QString line = in.readLine();double a = line.toDouble();data.push_back(a);}// 根据读到的数据,为QCPColorMap的每个单元格点设置数据double x, y, z;for (int xIndex = 0; xIndex < nx; ++xIndex){for (int yIndex = 0; yIndex < ny; ++yIndex){// 把xIndex和yIndex表示的单元格索引,转换为此QCPColorMapData的单元格索引colorMap->data()->cellToCoord(xIndex, yIndex, &x, &y);// 把读到的数据值赋值给QCPColorMap的每个单元格z = data.at(xIndex * 257 + yIndex);colorMap->data()->setCell(xIndex, yIndex, z);}}// 添加右侧的色带QCPColorScale *colorScale = new QCPColorScale(ui->customPlot);// 设置色带值的范围colorScale->setDataRange(QCPRange(-190, 0));// 将颜色图与色标关联colorMap->setColorScale(colorScale);// 设置色带刻度垂直条,刻度线/坐标轴标签右侧(实际上,右侧已经是默认值)colorScale->setType(QCPAxis::atRight);// 设置色带右侧的名字colorScale->axis()->setLabel("Strength Value");// 色条使用的颜色渐变QCPColorGradient gradient;gradient.setColorStopAt(0.0, QColor("#f6efa6"));   // 设置色条开始时的颜色gradient.setColorStopAt(1.0, QColor("#bf444c"));   // 设置色条结束时的颜色// 将其添加到主轴矩形的右侧ui->customPlot->plotLayout()->addElement(0, 1, colorScale);// 使用插值,界面不显示小方块(默认是禁用的)colorMap->setInterpolate(true);// 将颜色贴图的“颜色渐变”设置为其中一个预设colorMap->setGradient(QCPColorGradient::gpJet);// 确保轴rect和色标同步其底边距和顶边距,以便它们对齐QCPMarginGroup *marginGroup = new QCPMarginGroup(ui->customPlot);ui->customPlot->axisRect()->setMarginGroup(QCP::msBottom|QCP::msTop, marginGroup);colorScale->setMarginGroup(QCP::msBottom|QCP::msTop, marginGroup);// 重新缩放数据维度(颜色),以使所有数据点都位于颜色渐变显示的范围内(由于已经使用setDataRange主动设置了色带的值范围,两个选一个就行)
//    colorMap->rescaleDataRange();// 重新缩放x轴和y轴,以便可以看到整个颜色图ui->customPlot->rescaleAxes();ui->customPlot->replot();
}void MainWindow::on_Btn_Clear_clicked()
{// 清除文字、圆和线段for (int i = 0; i < m_itemText.size(); ++i){if (m_itemText[i] == nullptr)continue;ui->customPlot->removeItem(m_itemText[i]);m_itemText[i] = nullptr;}for (int i = 0; i < m_itemEllipse.size(); ++i){if (m_itemEllipse[i] == nullptr)continue;ui->customPlot->removeItem(m_itemEllipse[i]);m_itemEllipse[i] = nullptr;}for (int i = 0; i < m_itemLine.size(); ++i){if (m_itemLine[i] == nullptr)continue;ui->customPlot->removeItem(m_itemLine[i]);m_itemLine[i] = nullptr;}ui->customPlot->clearPlottables();ui->customPlot->replot();
}void MainWindow::on_Btn_AddText_clicked()
{m_itemText.resize(2);QList<QPoint> list;list << QPoint(1.2, 1.8) << QPoint(-1.2, -1.8);for (int i = 0; i < 2; ++i){m_itemText[i] = new QCPItemText(ui->customPlot);m_itemText[i]->setText("S" + QString::number(i));m_itemText[i]->position->setType(QCPItemPosition::ptPlotCoords); // 位置类型m_itemText[i]->position->setCoords(list[i].x(), list[i].y());m_itemText[i]->setFont(QFont(font().family(), 12)); // 字体大小m_itemText[i]->setColor(Qt::black);}ui->customPlot->replot();
}void MainWindow::on_Btn_AddEllipse_clicked()
{m_itemEllipse.resize(2);QList<QPoint> list;list << QPoint(1.2, 1.8) << QPoint(-1.2, -1.8);for (int i = 0; i < 2; ++i){m_itemEllipse[i] = new QCPItemEllipse(ui->customPlot);m_itemEllipse[i]->setAntialiased(true);double r = 0.2;//每个通道的圆半径大小m_itemEllipse[i]->topLeft->setCoords(list[i].x() - r, list[i].y() + r);m_itemEllipse[i]->bottomRight->setCoords(list[i].x() + r, list[i].y() - r);m_itemEllipse[i]->setPen(QPen(Qt::black, 1));}ui->customPlot->replot();
}void MainWindow::on_Btn_AddLine_clicked()
{m_itemLine.resize(2);QList<QPoint> list;list << QPoint(1.2, 1.8) << QPoint(-1.2, -1.8);for (int i = 0; i < 2; ++i){m_itemLine[i] = new QCPItemLine(ui->customPlot);m_itemLine[i]->start->setCoords(list[i].x() - 0.2, list[i].y());m_itemLine[i]->end->setCoords(list[i].x() + 0.2, list[i].y());m_itemLine[i]->setPen(QPen(Qt::black, 1));}ui->customPlot->replot();
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/411846.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ggml 简介

ggml是一个用 C 和 C 编写、专注于 Transformer 架构模型推理的机器学习库。该项目完全开源&#xff0c;处于活跃的开发阶段&#xff0c;开发社区也在不断壮大。ggml 和 PyTorch、TensorFlow 等机器学习库比较相似&#xff0c;但由于目前处于开发的早期阶段&#xff0c;一些底层…

『功能项目』怪物受击后显示受击状态UI【12】

本专栏每10章会做一次项目优化&#xff0c;但不影响具体功能 我们可以打开优化前的项目10也可以打开优化后的项目11 双击King或者怪物熊预制体 - 进入预制体空间后创建一个Image改名为StateUI01 代表第一个受击状态 修改Canvas的渲染模式 - 改为世界WorldSpace 调节Image&…

3分钟千人被裁,IBM中国 “灭霸式“裁员背后原因?

2024年8月23日&#xff0c;IMB即有员工传出“无法访问系统”&#xff0c;“无法连接到公司网络”的消息&#xff0c;后续传出裁员的传闻。 图片来源网络 2024年8月26日周一&#xff0c;IBM召开3分钟的会议&#xff0c;宣布彻底关闭IBM中国研发部门&#xff0c;之后直接切断会议…

【Go高性能】测试(单元测试、基准测试)

Go测试 一、分类1. 单元测试2. 基准测试 二、基准测试1. 介绍2. 基准测试基本原则3. 使用testing包构建基准测试3.1 执行基准测试3.2 基准测试工作原理3.3 改进基准测试的准确性3.3.1 -benchtime3.3.2 -count3.3.3 -cpu 4. 使用benchstat工具比较基准测试(可跳过&#xff09;4.…

SpringBoot日常:Spring之@PostConstruct解析

简介 spring的Bean在创建的时候会进行初始化&#xff0c;而初始化过程会解析出PostConstruct注解的方法&#xff0c;并反射调用该方法。 PostConstruct 的使用和特点 只有一个非静态方法能使用此注解&#xff1b;被注解的方法不得有任何参数&#xff1b;被注解的方法返回值必…

数据主权与隐私保护的深入探讨

随着数字化进程的加速&#xff0c;数据已成为当今世界的重要资源。数据主权和隐私保护这两个概念也越来越受到关注。数据主权涉及到国家对数据的控制权和管理权&#xff0c;而隐私保护则关乎个人数据的安全性和隐私权利。两者相互交织&#xff0c;共同塑造了数字时代的法律、经…

[RIS]GRES: Generalized Referring Expression Segmentation

1. BaseInfo TitleGRES: Generalized Referring Expression SegmentationAdresshttps://arxiv.org/pdf/2306.00968Journal/TimeCVPR2023Author南洋理工Codehttps://github.com/henghuiding/ReLARead20240829TableVisonLanguage 2. Creative Q&A 考虑结果多目标和无目标&…

2024软考:一场与“难”共舞的奇妙冒险,你值得拥有!

在这个时代&#xff0c;如果说有什么考试能让IT界的勇士们闻风丧胆&#xff0c;又爱又恨&#xff0c;那软考绝对能C位出道&#xff0c;成为众多技术大佬心中的“白月光”与“朱砂痣”。随着岁月悠悠&#xff0c;2024年的软考似乎又悄悄地在难度上动了点小心思&#xff0c;让人不…

【C++ Primer Plus习题】6.5

问题: 解答: #include <iostream> using namespace std;int main() {float salary 0;float tax 0;while (salary>0){cout << "请输入您的工资:";cin >> salary;if (cin.fail())break;if (salary < 5000){tax 0;}else if (salary < 15…

风控领域特征工程

在金融行业&#xff0c;风险控制&#xff08;风控&#xff09;是核心环节&#xff0c;它关乎资产安全、合规性以及机构的长期稳健发展。随着大数据时代的到来&#xff0c;金融机构面临着前所未有的数据量和复杂性。在这样的背景下&#xff0c;风控领域特征工程应运而生&#xf…

20240829版图的层次

1 最常用 Esc&#xff1a;取消操作 i&#xff1a;插入元件版图 c&#xff1a;复制 m&#xff1a;移动 u&#xff1a;撤销上一步操作 q&#xff1a;查看属性 f&#xff1a;全局视图 e&#xff1a;显示设置&#xff08;图层、栅格、走线模式等&#xff09; r&#xff1a;矩形填充…

<Rust>egui学习之小部件(六):如何在窗口中添加菜单栏部件?

前言 本专栏是关于Rust的GUI库egui的部件讲解及应用实例分析&#xff0c;主要讲解egui的源代码、部件属性、如何应用。 环境配置 系统&#xff1a;windows 平台&#xff1a;visual studio code 语言&#xff1a;rust 库&#xff1a;egui、eframe 概述 本文是本专栏的第六篇博…

【爬虫软件】采集抖音博主的主页发布作品

这是我用python开发的抖音爬虫采集软件&#xff0c;可自动按博主抓取已发布视频。 软件界面截图&#xff1a; 爬取结果截图&#xff1a; 几点重要说明&#xff1a; 软件使用演示视频&#xff1a; https://www.bilibili.com/video/BV1Kb42187qf 完整讲解文章&#xff1a; ht…

释放金融交易的未来:掌握量化机器人技术

在金融交易的竞技场上&#xff0c;量化机器人技术正成为投资者手中的一张王牌&#xff0c;引领着交易策略的未来。本文将向您展示量化机器人如何成为金融交易的变革者&#xff0c;并向您展示如何利用这一技术来优化您的投资策略。 量化机器人的力量 量化机器人技术是金融交易领…

Anaconda3简介与安装步骤

目录 Anaconda3简介与功能 1.Anaconda3简介 2.主要功能和特点 3.使用场景 4.总结 Anaconda3安装 1.Anaconda3下载 1.1我的百度网盘 1.2官网下载 1.2.1访问官网 1.2.2输入邮箱 1.2.3登录你的邮箱下载&#xff08;你的噶&#xff09; 2.安装 2.1双击安装 2.2选择安…

Linux——nginx 负载均衡

常规的web服务器一般提供对于静态资源的访问&#xff0c;比如说&#xff1a;图片、web样式 网站提供的大部分交互功能都需要web编程语言的支持&#xff0c;而web服务对于程序的调用&#xff0c;不管编译型语言还是解释型语言&#xff0c;web服务同将对于应用程序的调用递交给通…

路别走窄了,华为认证的这些方向,比数通值钱

华为认证作为全球领先的ICT技术认证之一&#xff0c;以其高标准和权威性在全球范围内受到认可。它不仅代表了专业技能的国际水平&#xff0c;更是IT专业人士职业生涯中的重要里程碑。但谈论起华为认证&#xff0c;似乎大家都默认首选数通。 不止在华为认证&#xff0c;而是在整…

Vue使用v-model收集各种表单数据、过滤器

目录 1. 使用v-model收集各种表单数据2. 日期格式化3. 过滤器 1. 使用v-model收集各种表单数据 若<input type“text”/>&#xff0c;则v-model收集的是value值&#xff0c;用户输入的就是value值若<input type“radio”/>&#xff0c;则v-model收集的是value值&a…

H5开发有哪些技巧?

随着现代社会的飞速发展&#xff0c;网页开发已经从传统的HTML、CSS、JavaScript往H5发展。H5也称为HTML5&#xff0c;可以理解为是HTML的升级版&#xff0c;具有更加优秀的性能、更加完善的功能和更加多样的体验。因其灵活性和跨平台特性&#xff0c;成为了各类移动应用和网页…

R语言报错 | object ‘integral‘ not found whilst loading name

1、报错背景 Registered S3 method overwritten by htmlwidgets:method from print.htmlwidget tools:rstudio Error: package or namespace load failed for ‘Seurat’:object integral not found whilst loading namespace spatstat.core 当我想library&…