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

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工程师初试总结复盘

       预约的视频面试时间是中午12点,不过面试官并没有准时到,拖了大概5.6分钟吧.Zoom会议上写着xxxJava工程师初试. 面试官戴着口罩,并没有露脸,看起来与我年龄相仿,感觉很年轻. 在我按着 ...

  2. SQLAlchemy02 /SQLAlchemy对数据的增删改查操作、属性常用数据类型详解

    SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 目录 SQLAlchemy02 /SQLAlchemy对数据的增删改查操作.属性常用数据类型详解 1.用se ...

  3. Flask 基础组件(三):路由系统

    1. 常见路由 @app.route('/user/<username>') @app.route('/post/<int:post_id>') @app.route('/po ...

  4. 数据分析02 /pandas基础

    数据分析02 /pandas基础 目录 数据分析02 /pandas基础 1. pandas简介 2. Series 3. DataFrame 4. 总结: 1. pandas简介 numpy能够帮助 ...

  5. It's time for Django

    本节内容 Django流程介绍 Django url Django view Django models Django template Django form Django admin Django ...

  6. 让 axios 支持 finally

    当我们执行一个promise操作时,往往伴随的是要做各种状态的修改(如请求开始时显示loading,结束时隐藏 loading), 这个状态修改,如果没有finally函数,我们需要在then和cat ...

  7. JavaScript图形实例:阿基米德螺线

    1.阿基米德螺线 阿基米德螺线亦称“等速螺线”.当一点P沿动射线OP以等速率运动的同时,该射线又以等角速度绕点O旋转,点P的轨迹称为“阿基米德螺线”. 阿基米德螺线的笛卡尔坐标方程式为: r=10*( ...

  8. Azure Web App (三)切换你的Net Core Web 项目的数据库连接字符串

    一,引言 上一篇文章讲到今天我们演示了一下,如何在Web App中创建 “Deployment Slot”进行快速无停机部署新功能代码,也使用VS进行发布到创建的Web App中创建的新的部署槽位中, ...

  9. Python Ethical Hacking - MODIFYING DATA IN HTTP LAYER(2)

    MODIFYING DATA IN HTTP LAYER Edit requests/responses. Replace download requests. Inject code(html/Ja ...

  10. window下远程连接redis服务

    首先下redis包: 下载地址:https://github.com/MSOpenTech/redis/releases. 之后: 1.注释掉redis.windows-service.conf 中的 ...