此次记录主要是为了下次使用时能回忆起来才做得笔记,若有需改进的地方,请不吝珠玉。

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下 鼠标点击曲线 显示当前坐标的更多相关文章

  1. Qt 模拟鼠标点击(QApplication::sendEvent(ui->pushbutton, &event0);)

    QPoint pos(0,0);QMouseEvent event0(QEvent::MouseButtonPress, pos, Qt::LeftButton, Qt::LeftButton, Qt ...

  2. QT下过多点的曲线绘制

    绘制过多点的曲线意义重大.但通过试验,QT的PainterPath不是很如意.当多段曲线围成一个区域时,PainterPath内并不包含该区域的所有面积,只包含曲线和其弦构成的面积. 为了解决这一问题 ...

  3. appearance格式化表单元素的边框,在chrome和FF下鼠标点击时会多出一个蓝色边框

    可在元素上添加样式 -webkit-appearance: none; -moz-appearance:none;outline:none; 清除掉元素所有的外貌,以便自定义风格

  4. textarea内容太多, 鼠标点击全部显示

    strRight+="<td bordercolor='#DEDEDE' width='500px' height='50'><div title='"+data ...

  5. html5中canvas的使用 获取鼠标点击页面上某点的RGB

    1.html5中的canvas在IE9中可以跑起来.在IE8则跑不起来,这时候就需要一些东西了. 我推荐这种方法,这样显得代码不乱. <!--[if lt IE9]> <script ...

  6. JQuery怎么实现页面刷新后保留鼠标点击样式的方法

    今天抽空研究了下鼠标点击添加样式的方法.为了防止忘记,写篇文章算是备份吧. $('ul.main-menu li a').each(function(){     if($($(this))[0].h ...

  7. 使用powershell/vbs自动化模拟鼠标点击操作

    今天想做windows上的自动化,所以才有了模拟鼠标点击的需求,先考虑用powershell实现: 首先先安装一个名为“WASP”免费可用的Powershell扩展程序,下载地址:http://was ...

  8. 【ARM开发板】迅为IMX6开发板QT下LVDS和HDMI双屏异显

    本文转自迅为论坛:http://www.topeetboard.com 平台:迅为-IMX6开发板 首先开发板分别连接9.7寸屏和HDMI显示器,然后使用MfgTool工具烧写QT系统,然后拨码开关设 ...

  9. JS高德地图应用 ---- 鼠标点击加入标记 & POI搜索

    代码如下 (填入Key值) : <!DOCTYPE html> <html> <head> <meta charset="utf-8"&g ...

随机推荐

  1. java 面向对象(十一):关键字:package/import

    1.1 使用说明: * 1.为了更好的实现项目中类的管理,提供包的概念 * 2.使用package声明类或接口所属的包,声明在源文件的首行 * 3.包,属于标识符,遵循标识符的命名规则.规范(xxxy ...

  2. 前端03 /css简绍/css选择器

    前端03 /css简绍/css选择器 目录 前端03 /css简绍/css选择器 昨日内容回顾 html标签 常用标签 table标签:表格标签 input标签 select下拉框 textarea多 ...

  3. Windows分页文件设置不当导致SQL Server服务被终止

    Windows分页文件设置不当导致SQL Server服务被终止 文章说明 在正式开始验证和测试之前,先介绍Windows分页文件和SQL Server的动态内存管理.下面测试将分为两种测试场景:场景 ...

  4. Python 爬取异步加载的数据

    在我们的工作中,可能会遇到这样的情况:我们需要爬取的数据是通过ajax异步加载的,这样的话通过requests得到的只是一个静态页面,而我们需要的是ajax动态加载的数据! 那我们应该怎么办呢??? ...

  5. db2数据库基本添加删除表字段总结

    1.添加字段 alter table [table_name] add [column_name] [column_type] 2.更改字段类型 alter table  [table_name] a ...

  6. IDEA 2020版破解

    这期教一下大家如何破解IDEA 最新版破解教程 有以前的idea建议卸载哈~安装最新版的版本 一:我们首先去idea官网下载最新版 下方是idae官网2020最新链接 https://www.jetb ...

  7. antd实战:表单上传,文件列表的过滤与限制。

    用表单上传组件最痛苦的地方是: 他的诸多行为与纯上传组件不一样,而表单的文档关于这一块基本上没有提,只能自己试. 比如我想做一个上传前的拦截. beforeUpload: (file, fileLis ...

  8. ztree : 增删改功能demo与自定义DOM功能demo的结合

    最近有个项目要用ztree,需要用ztree自带的功能(增删改),也需要自定义DOM的功能(置顶). ztree的demo里有增删改的demo,也有自定义DOM的demo,但没有两者结合的. 所以我把 ...

  9. Spring事务源码分析专题(一)JdbcTemplate使用及源码分析

    Spring中的数据访问,JdbcTemplate使用及源码分析 前言 本系列文章为事务专栏分析文章,整个事务分析专题将按下面这张图完成 对源码分析前,我希望先介绍一下Spring中数据访问的相关内容 ...

  10. 题解 SP3734 【PERIODNI - Periodni】

    考虑用\(DP\)和组合数学来解决. 因为原图像不规则的形状不好处理,所以先用笛卡尔树(性质为小根堆)将其划分成一个一个的矩形. 发现在笛卡尔树上的每个节点都对应一个矩形,矩形高为\(h_x-h_{f ...