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

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. 简单讲解一下http2的多路复用

    在 HTTP/1 中,每次请求都会建立一次HTTP连接,也就是我们常说的3次握手4次挥手,这个过程在一次请求过程中占用了相当长的时间,即使开启了 Keep-Alive ,解决了多次连接的问题,但是依然 ...

  2. 用svg实现一个环形进度条

    svg实现环形进度条需要用到的知识: 1.会使用path的d属性画一个圆环 //用svg的path元素的A命令画圆 <path d=" M cx cy m 0 -r a r r 0 1 ...

  3. WPF在.NET 5 中的线路图

    WPF是用于构建Windows桌面应用程序的.NET Core UI框架.WPF的所属权最近已经移交给了我们的团队(Windows下开发生态系统和平台的团队).这种转变使跨UI框架(即WinUI和WP ...

  4. kubernetes系列(十七) - 通过helm安装dashboard详细教程

    1. 前提条件 2. 配置https证书为secret 3. dashboard安装 3.1 helm拉取dashboard的chart 3.2 配置dashboard的chart包配置 3.3 he ...

  5. CentOS8.0 Docker Repository

    一.硬件软件准备      1.2台服务器或者电脑(使用云服务器1.阿里云 2.百度云各一台) ,系统均为CentOS 8.0      2.分别安装Docker      3.测试镜像准备(准备的是 ...

  6. NVIDIA GPU Pascal架构简述

    NVIDIA GPU Pascal架构简述 本文摘抄自英伟达Pascal架构官方白皮书:https://www.nvidia.com/en-us/data-center/resources/pasca ...

  7. JavaScript数组在指定某个元素前或后添加元素

    //原数组 var s = [['g','g'],['h','h'],['i','i']]; //要添加的元素 var s1 = ['a','b','c']; //要添加的元素 var s2 = [' ...

  8. SQL数据多条转单条(CONCAT_WS)

    一.concat()函数可以连接一个或者多个字符串 concat(str1,str2,…) 返回结果为连接参数产生的字符串.如有任何一个参数为NULL ,则返回值为 NULL. select conc ...

  9. Java 并发队列 BlockingQueue

    BlockingQueue 开篇先介绍下 BlockingQueue 这个接口的规则,后面再看其实现. 首先,最基本的来说, BlockingQueue 是一个先进先出的队列(Queue),为什么说是 ...

  10. iOS 高效灵活地配置可复用视图组件的主题

      本文首发于 Ficow Shen's Blog,原文地址: iOS 高效灵活地配置可复用视图组件的主题.   内容概览 前言 如何配置主题? 如何更高效地配置主题? 面向协议/接口的方案     ...