CustomPlot 在Qt下 鼠标点击曲线 显示当前坐标
此次记录主要是为了下次使用时能回忆起来才做得笔记,若有需改进的地方,请不吝珠玉。
widget.cpp
#include "widget.h"
#include "ui_widget.h" Widget::Widget(QWidget *parent) :
QWidget(parent),Chartdisplay(new ChartDisplay),
ui(new Ui::Widget)
{
ui->setupUi(this);
Chartdisplay->Ploar1Init(ui->customplot);//CustomPlot初始化
Chartdisplay->Ploar1PrapareData();//数据填充
} Widget::~Widget()
{
delete ui;
}
widget.h
#ifndef WIDGET_H
#define WIDGET_H #include <QWidget>
#include <QGroupBox>
#include <QGridLayout>
#include "chartdisplay.h" namespace Ui {
class Widget;
} class Widget : public QWidget
{
Q_OBJECT public:
explicit Widget(QWidget *parent = );
~Widget(); private:
Ui::Widget *ui;
ChartDisplay *Chartdisplay; }; #endif // WIDGET_H
chartdisplay.cpp
#include "chartdisplay.h"
ChartDisplay::ChartDisplay(QWidget *parent) : QWidget(parent){}
//CustomPlot初始化 坐标显示标签初始化
void ChartDisplay::Ploar1Init(QCustomPlot *customplot)
{
//初始化坐标系范围和意义
CustomPlot = customplot;
CustomPlot->addGraph();
CustomPlot->setSelectionTolerance();
CustomPlot->graph()->setPen(QPen(Qt::darkGray,,Qt::SolidLine));
CustomPlot->graph()->setScatterStyle(QCPScatterStyle(QCPScatterStyle::ssNone,));//曲线样式 样式大小
CustomPlot->xAxis->setLabel("X");
CustomPlot->yAxis->setLabel("Y");
CustomPlot->xAxis->setRange(,);
CustomPlot->yAxis->setRange(-,);
CustomPlot->rescaleAxes(true);//开启自适应
CustomPlot->setInteractions( QCP::iSelectPlottables | QCP::iRangeDrag |QCP::iRangeZoom );//先设置customplot的plottable绘图层可选 鼠标拖拽 滚轮缩放
TextTip = new QCPItemText(CustomPlot);
TextTip->setPositionAlignment(Qt::AlignTop|Qt::AlignHCenter);
TextTip->position->setType(QCPItemPosition::ptAbsolute);
QFont font;
font.setPixelSize();
TextTip->setFont(font); // make font a bit larger
TextTip->setPen(QPen(Qt::black)); // show black border around text
TextTip->setBrush(Qt::white);
TextTip->setVisible(false);
connect(CustomPlot, SIGNAL(plottableClick(QCPAbstractPlottable*, int, QMouseEvent*)), this, SLOT(OnPlotClick(QCPAbstractPlottable*, int, QMouseEvent*)));//关联选点信号
}
//CustomPlot数据填充
void ChartDisplay::Ploar1PrapareData()
{
QVector<double> Xvalue();
QVector<double> Yvalue();
for (int i = ; i < ; i++) {
Xvalue[i]=i;
Yvalue[i]=*qSin(i * 10.0f / );
}
CustomPlot->graph()->setData(Xvalue,Yvalue);
CustomPlot->replot();//重绘图形
}
//选点处理函数
void ChartDisplay::OnPlotClick(QCPAbstractPlottable *plottable, int dataIndex, QMouseEvent *event)
{
//先获取点击的绘图层名称,然后通过名称找到图层ID,再找到对应的数据点 这里因为知道ID 所以直接使用 没有通过名称找
const QCPGraphData *ghd = CustomPlot->graph()->data()->at(dataIndex);
QString text = "(" + QString::number(ghd->key,,) + "," + QString::number(ghd->value,,) + ")";
TextTip->setText(text);//文本内容填充
TextTip->position->setCoords(event->pos().x()+, event->pos().y()-);//文本框所在位置
TextTip->setVisible(true);
CustomPlot->replot();
}
chartdisplay.h
#ifndef CHARTDISPLAY_H
#define CHARTDISPLAY_H
#include <QWidget>
#include "qcustomplot.h" class ChartDisplay : public QWidget
{
Q_OBJECT
public:
explicit ChartDisplay(QWidget *parent = nullptr);
QCustomPlot *CustomPlot;
QCPItemText *TextTip;
void Ploar1Init(QCustomPlot *customplot);
void Ploar1PrapareData();
private slots:
void OnPlotClick(QCPAbstractPlottable *plottable, int dataIndex, QMouseEvent *event);
}; #endif // CHARTDISPLAY_H
所有文件如图1 qcustomplot.h 和 qcustomplot.cpp可以直接去这里 http://www.qcustomplot.com/找找看;
下载完成后把.cpp和.h放在工程目录下,并将cpp和h加入工程;
切记要在.pro中:QT += printsupport;
在ui中添加一个Widget,右键提升为,如图2 输入:QCustomPlot,下面自动生成头文件,记得深蓝色部分要勾选 然后点提示即可
最后改变对象名称为customplot就可以和上面的代码吻合了;
图1

图2

效果图如图3所示 由于只是测试是否可以显示坐标,所以没有改进代码,
显示后挥之不去,哈哈^_^有点小尴尬。不过实际做项目的时候会在线程加上下面这句代码,实际效果还没有测试。(实测中发现如果不太耐心的人点击的时候应该会疯掉的罒ω罒)
TextTip->setVisible(false);
图3

这只是一个基础代码,功能不是太多,需要后续拓展。我就不多解释代码了,注释应该已经很清楚了。
常怀一颗心————空杯心
CustomPlot 在Qt下 鼠标点击曲线 显示当前坐标的更多相关文章
- Qt 模拟鼠标点击(QApplication::sendEvent(ui->pushbutton, &event0);)
QPoint pos(0,0);QMouseEvent event0(QEvent::MouseButtonPress, pos, Qt::LeftButton, Qt::LeftButton, Qt ...
- QT下过多点的曲线绘制
绘制过多点的曲线意义重大.但通过试验,QT的PainterPath不是很如意.当多段曲线围成一个区域时,PainterPath内并不包含该区域的所有面积,只包含曲线和其弦构成的面积. 为了解决这一问题 ...
- appearance格式化表单元素的边框,在chrome和FF下鼠标点击时会多出一个蓝色边框
可在元素上添加样式 -webkit-appearance: none; -moz-appearance:none;outline:none; 清除掉元素所有的外貌,以便自定义风格
- textarea内容太多, 鼠标点击全部显示
strRight+="<td bordercolor='#DEDEDE' width='500px' height='50'><div title='"+data ...
- html5中canvas的使用 获取鼠标点击页面上某点的RGB
1.html5中的canvas在IE9中可以跑起来.在IE8则跑不起来,这时候就需要一些东西了. 我推荐这种方法,这样显得代码不乱. <!--[if lt IE9]> <script ...
- JQuery怎么实现页面刷新后保留鼠标点击样式的方法
今天抽空研究了下鼠标点击添加样式的方法.为了防止忘记,写篇文章算是备份吧. $('ul.main-menu li a').each(function(){ if($($(this))[0].h ...
- 使用powershell/vbs自动化模拟鼠标点击操作
今天想做windows上的自动化,所以才有了模拟鼠标点击的需求,先考虑用powershell实现: 首先先安装一个名为“WASP”免费可用的Powershell扩展程序,下载地址:http://was ...
- 【ARM开发板】迅为IMX6开发板QT下LVDS和HDMI双屏异显
本文转自迅为论坛:http://www.topeetboard.com 平台:迅为-IMX6开发板 首先开发板分别连接9.7寸屏和HDMI显示器,然后使用MfgTool工具烧写QT系统,然后拨码开关设 ...
- JS高德地图应用 ---- 鼠标点击加入标记 & POI搜索
代码如下 (填入Key值) : <!DOCTYPE html> <html> <head> <meta charset="utf-8"&g ...
随机推荐
- 简单讲解一下http2的多路复用
在 HTTP/1 中,每次请求都会建立一次HTTP连接,也就是我们常说的3次握手4次挥手,这个过程在一次请求过程中占用了相当长的时间,即使开启了 Keep-Alive ,解决了多次连接的问题,但是依然 ...
- 用svg实现一个环形进度条
svg实现环形进度条需要用到的知识: 1.会使用path的d属性画一个圆环 //用svg的path元素的A命令画圆 <path d=" M cx cy m 0 -r a r r 0 1 ...
- WPF在.NET 5 中的线路图
WPF是用于构建Windows桌面应用程序的.NET Core UI框架.WPF的所属权最近已经移交给了我们的团队(Windows下开发生态系统和平台的团队).这种转变使跨UI框架(即WinUI和WP ...
- kubernetes系列(十七) - 通过helm安装dashboard详细教程
1. 前提条件 2. 配置https证书为secret 3. dashboard安装 3.1 helm拉取dashboard的chart 3.2 配置dashboard的chart包配置 3.3 he ...
- CentOS8.0 Docker Repository
一.硬件软件准备 1.2台服务器或者电脑(使用云服务器1.阿里云 2.百度云各一台) ,系统均为CentOS 8.0 2.分别安装Docker 3.测试镜像准备(准备的是 ...
- NVIDIA GPU Pascal架构简述
NVIDIA GPU Pascal架构简述 本文摘抄自英伟达Pascal架构官方白皮书:https://www.nvidia.com/en-us/data-center/resources/pasca ...
- JavaScript数组在指定某个元素前或后添加元素
//原数组 var s = [['g','g'],['h','h'],['i','i']]; //要添加的元素 var s1 = ['a','b','c']; //要添加的元素 var s2 = [' ...
- SQL数据多条转单条(CONCAT_WS)
一.concat()函数可以连接一个或者多个字符串 concat(str1,str2,…) 返回结果为连接参数产生的字符串.如有任何一个参数为NULL ,则返回值为 NULL. select conc ...
- Java 并发队列 BlockingQueue
BlockingQueue 开篇先介绍下 BlockingQueue 这个接口的规则,后面再看其实现. 首先,最基本的来说, BlockingQueue 是一个先进先出的队列(Queue),为什么说是 ...
- iOS 高效灵活地配置可复用视图组件的主题
本文首发于 Ficow Shen's Blog,原文地址: iOS 高效灵活地配置可复用视图组件的主题. 内容概览 前言 如何配置主题? 如何更高效地配置主题? 面向协议/接口的方案 ...