QML使用QCustomPlot笔记

        这里在QML中使用QCustomPlot是定义一个继承自QQuickPaintedItem的类,它包含一个QCustomPlot对象,在paint函数中将这个对象转化为pixmap绘制到布局中显示。

在QML中使用QT的Widget控件也可以借鉴这个思路实现

顺便记录一下QCustomPlot的简单设置与使用。

QCustomPlot可以直接到官网下载源码。

main.cpp中添加代码,将C++类注册为QML组件

#include "plot/liquidheightplot.h"
...

int main(int argc, char *argv[])
{
...
    qmlRegisterType<LiquidHeightPlot>("LiquidHeightPlot", 1, 0, "LiquidHeightPlot");
...
}

类定义liquidheightplot.h

#ifndef LIQUIDHEIGHTPLOT_H
#define LIQUIDHEIGHTPLOT_H

#include "qcustomplot/qcustomplot.h"
#include <QQuickItem>
#include <QQuickPaintedItem>
#include <QVector>
#include <QJsonObject>

class LiquidHeightPlot : public QQuickPaintedItem
{
    Q_OBJECT
public:
    explicit LiquidHeightPlot(QQuickItem *parent = nullptr);
    ~LiquidHeightPlot();

    //更新实时数据
    Q_INVOKABLE void updateRealData(double value);

    //设置历史数据
    Q_INVOKABLE void setHistoryData(QJsonObject data);

    //清除数据
    Q_INVOKABLE void clearData();


signals:
    void sigIllegalData();

private:
    virtual void paint(QPainter *painter);

private:
    QCustomPlot *m_customPlot;
    double                  m_maxY;
    QVector<double>         m_x1;
    QVector<double>         m_y1;
};

#endif // LIQUIDHEIGHTPLOT_H

类实现liquidheightplot.cpp

#include "liquidheightplot.h"
#include <QDateTime>
#include <QStringList>

LiquidHeightPlot::
QML是一种用于创建用户界面的声明性编程语言,通过它可以简单而强大地创建交互式界面。而qcustomplot是基于Qt的一个绘图库,它提供了丰富的绘图功能,可以轻松地绘制各种类型的图表。 在QML使用qcustomplot可以通过以下几个步骤进行: 1. 引入qcustomplot库:首先需要将qcustomplot的库文件导入到QML项目中。可以将qcustomplot所在的文件夹复制到项目的源文件目录中,并在项目文件中添加相应的引用。 2. 创建QCustomPlot组件:在QML文件中,创建一个QCustomPlot组件用于显示绘图内容。可以将它放置在界面的任意位置,并设置其大小和样式。 3. 添加数据:使用QML中的绑定语法,将要绘制的数据传递给QCustomPlot组件。可以使用JavaScript数组或对象表示数据,并将其绑定到QCustomPlot的相应属性上。 4. 绘制图表:根据需要,通过设置QCustomPlot的属性和方法来自定义图表的样式和布局。可以设置图表的标题、坐标轴、网格线、数据点等属性,以及调整图表的大小和位置。 5. 处理交互:qcustomplot支持用户的交互操作,如鼠标点击、拖拽、缩放等。可以通过在QML文件中捕捉相应的事件,并调用qcustomplot提供的方法来实现交互功能。 通过上述步骤,就可以在QML中成功地使用qcustomplot进行绘图。在绘制图表时,可以根据具体需求进行进一步的定制和优化,以满足特定的界面需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值