QCustomPlot系列(5)-实时动态曲线[通俗易懂]

QCustomPlot系列(5)-实时动态曲线[通俗易懂]先来个动图看看效果:支持鼠标平移、滚轮缩放、框选放大、取消框选、一键全显、单击显示xy坐标值。。等平移功能是QCustomPlot自带的功能,参见我的该系列前面的博文。框选放大、全显等功能在另一篇博文中也讲到了。这里只讲2个知识点:1、显示鼠标指向的点坐标,2、实时滚动1、箭头指向要显示的坐标点,代码步骤:(1)添加新类,继承QCustomPlot添加private成员变…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

先来个动图看看效果:

支持鼠标平移、滚轮缩放、框选放大、取消框选、一键全显、单击显示xy坐标值。。等

QCustomPlot系列(5)-实时动态曲线[通俗易懂]

平移功能是QCustomPlot自带的功能,参见我的该系列前面的博文。框选放大、全显等功能在另一篇博文中也讲到了。

这里只讲2个知识点:1、显示鼠标指向的点坐标,2、实时滚动

1、箭头指向要显示的坐标点,代码步骤:

(1)添加新类,继承QCustomPlot
添加private成员变量:

QCPItemText *textLabel;//单击时提示信息框
QCPItemLine *arrow;//提示信息的箭头
在构造中初始化他俩:
    //下面这一段是从QCustomPlot官网抄来的
    /*显示数值的提示框*/
    textLabel = new QCPItemText(this);
    textLabel->setPositionAlignment(Qt::AlignTop|Qt::AlignHCenter);//方框置于上部中间
    textLabel->position->setType(QCPItemPosition::ptAxisRectRatio);
    textLabel->position->setCoords(0.5, 0); // place position at center/top of axis rect
    textLabel->setFont(QFont(font().family(), 16)); // 字体
    textLabel->setPen(QPen(Qt::black)); // 颜色

    //指向数值的箭头:
    arrow = new QCPItemLine(this);
    arrow->start->setParentAnchor(textLabel->bottom);//箭头起点位于提示框的下边框中点
    //arrow->end->setCoords(4, 1.6); // 设置箭头的终点
    arrow->setHead(QCPLineEnding::esSpikeArrow);//箭头类型
    textLabel->setVisible(false);//提示框不可见
    arrow->setVisible(false);//箭头不可见

(2)重写鼠标按下/弹起事件

void MultiCurvesPlot::mousePressEvent(QMouseEvent *event)
{
    //重写后,仍然要使父类的函数,否则自带的拖动功能等就失效了
    QCustomPlot::mousePressEvent(event);//父类的函数

    if(event->buttons() & Qt::LeftButton)//按下鼠标左键
    {
        textLabel->setVisible(true);//提示框可见
        arrow->setVisible(true);//箭头可见
        double x = xAxis->pixelToCoord(event->pos().x());//鼠标坐标转化为XY轴的坐标
        double y = yAxis->pixelToCoord(event->pos().y());
        arrow->end->setCoords(x, y); // 设置箭头的终点
        QString xTime = QDateTime::fromMSecsSinceEpoch(x * 1000.0).toString("hh:mm:ss.zzz");//把单击处的X值转换为时间String
        textLabel->setText(QString("x = %1\ny=%2").arg(xTime).arg(y));//显示XY值
    }
}
void MultiCurvesPlot::mouseReleaseEvent(QMouseEvent *event)
{
    QCustomPlot::mouseReleaseEvent(event);

    if(event->button() == Qt::LeftButton)//左键弹起
    {
        textLabel->setVisible(false);//隐藏数值方框和箭头
        arrow->setVisible(false);
    }

}

2、实时滚动的曲线
我们要做的就两点:1、向graph中添加新的点 this->graph(graphIdx)->addData(currentTime,  y);  2、实时修改X轴的显示范围

在我这个例子中,X轴是实时时间,所以,要想使曲线实时滚动,只要把X轴的显示范围实时修改为:从<当前时间-当前X轴的显示宽度>到<当前时间>即可, 这样曲线就会滚动起来。其中,当前X轴的显示宽度可以从xAxis->range().size()读取。

注意:如果我们接收到的数据点过于频繁,我们不应该每收到一个点都要刷新图像,那样程序效率太低,也没必要。一般设置每30ms刷新一次就足够流畅了,毕竟我们下载的普通电影也就30帧每秒。

因此,我们在一个30ms定时器的槽函数中来做:修改X轴的显示范围+刷新图像。

代码步骤如下:

(1)在构造函数中启动QWidget自带的定时器
 

startTimer(30, Qt::CoarseTimer);//每30ms触发一次timeEvent事件

(2)重写void timerEvent(QTimerEvent *event) Q_DECL_OVERRIDE;函数来响应这个定时器的超时事件:
 

void MultiCurvesPlot::timerEvent(QTimerEvent *event)
{
    Q_UNUSED(event);

    if(autoScroll)//如果启动了自动滚动功能
    {
        double curSeclf = (double)(QDateTime::currentMSecsSinceEpoch()) / 1000.0;//读取当前时间(因为QCustomPlot支持的时间值的ms值在小数位,所以/1000.0了)
        this->xAxis->setRange(curSeclf - xAxis->range().size(), curSeclf);//实时调整X轴的显示范围
    }
    this->replot();//刷新图像
}

代码就这些,非常简单。

群号在左边。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/181333.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm中unresolvedreference_pycharm add new configuration

    pycharm中unresolvedreference_pycharm add new configuration在用Pycharm写项目的时候的时候碰到一个很无语的问题路径明明没有问题,运行也没有出错,但就是爆红,逼死强迫症啊。。。多方查找最后解决了。步骤如下:File–>Settings–>ProjectStructure–>找到问题目录–>Sources–>Apply–>OKOK了,不在爆红…

    2022年8月26日
    5
  • eclipse设置中没有server选项[通俗易懂]

    用eclipse准备配置tomcat,发现配置中没有server选项,参考各种解决方法之后成功解决。准备工作:1.查看eclipse版本号;在eclipse中点Help,现在AboutEclipseIDE;2.添加server插件;eclipse中点Help,选择InstallNewSoftware…;点Add,Name输入上面查询的eclipse版本号,Location…

    2022年4月17日
    351
  • kafka与rocketmq优劣势_kafka rocketmq rabbitmq

    kafka与rocketmq优劣势_kafka rocketmq rabbitmq前言:公司采用了两种消息队列,一种是阿里云的rocketMQ,一种是kafka.分别用在了两种不同的场景.这里做个记录.rocketMQ使用场景:1.异步解耦:拿我们的项目举例,有一个场景,是需要pc端触发派单接口,然后发送给app端消息通知.此时要求能够做到每个app都能收到消息,但是又希望这个发送的过程尽量的短,也就是派单接口尽量快.那么这个派送的过程可以采用rocketM…

    2022年8月31日
    8
  • css3中的calc()

    css3中的calc()

    2022年1月31日
    45
  • 【损失函数系列】softmax loss损失函数详解

    【损失函数系列】softmax loss损失函数详解1.损失函数:损失函数(lossfunction)是用来评测模型的预测值f(x)与真实值Y的相似程度,损失函数越小,就代表模型的鲁棒性越好,损失函数指导模型学习。根据损失函数来做反向传播修改模型参数。机器学习的目的就是学习一组参数,使得预测值与真值无限接近。2.softmaxloss:它是损失函数的一种,是softmax和cross-entropyloss组合而成的损失函数。先看softmax,其函数形式如下:其中zj就是某个神经网络全连…

    2022年6月26日
    74
  • sql数据库回滚操作_sql回滚语句 rollback

    sql数据库回滚操作_sql回滚语句 rollbackcreatetable testtable(idnvchart(50)primkey,namenvchart(50),remarknvchart(50))select*fromtesttable go BEGINTRY –SQLServer需要显示的定义开始一个事务.BEGINTRANSACTION;–插入2条同样的数据

    2022年8月30日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号