Qt中使用QtCharts实时绘制雷达点云二维散点图

一、Qt Charts组件安装

        在Qt安装时勾选Qt Charts组件,该组件包含相关二维图表绘制组件,此处必须勾选。

        Qt Data Visualization包含相关三维图形绘制组件,后续想用三维图形绘制可以勾选安装。

二、准备

        1、在项目的.pro文件中加上 QT += charts

QT       += charts

        2、引用头文件及名字空间

#include <QChartView>
#include <QtCharts>
#include <QtCharts/QScatterSeries>

QT_CHARTS_USE_NAMESPACE

三、ui设计

        两个按钮用于启动UDP线程,接收雷达数据,一个widget用于放置散点图表。

四、头文件代码 

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QDebug>
#include <QPointF>
#include <QChartView>
#include <QtCharts>
#include <QtCharts/QScatterSeries>
#include <QMetaType>
#include "udpthread.h"
#define PI 3.1415

typedef QVector<float> MY_BUF ;

QT_CHARTS_USE_NAMESPACE

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private slots:

    void on_pushButton_start_clicked();
    void on_pushButton_stop_clicked();
    void drawPoint(MY_BUF,MY_BUF);

private:
    Ui::MainWindow *ui;

    void initMap();
    udpThread UDPthread;
    QChart *m_chart;
    QScatterSeries *m_scatterSeries; //散点类型
};
#endif // MAINWINDOW_H

五、源文件代码

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    qRegisterMetaType<MY_BUF>("MY_BUF");
    initMap();
    this->setWindowTitle("UDP_Reciver");
    //UDP线程接收雷达点云数据,通过信号实时刷新绘图
    connect(&UDPthread,SIGNAL(pointdata(MY_BUF,MY_BUF)),this,SLOT(drawPoint(MY_BUF,MY_BUF)));

}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::initMap()
{
    m_chart = new QChart();
    m_scatterSeries = new QScatterSeries(m_chart);
    m_scatterSeries->setUseOpenGL(true);            //启用OpenGL,否则可能会很卡顿
    m_scatterSeries->setMarkerShape(QScatterSeries::MarkerShapeRectangle);//设置散点样式
    m_scatterSeries->setMarkerSize(4);              //设置散点大小
    m_scatterSeries->setColor(QColor(0,0,255));     //设置散点颜色

    m_chart->addSeries(m_scatterSeries);
    m_chart->createDefaultAxes();
    m_chart->axes(Qt::Horizontal).first()->setRange(-55.0, 55.0); //设置水平坐标范围
    m_chart->axes(Qt::Vertical).first()->setRange(0, 50.0);       //设置垂直坐标范围
    m_chart->legend()->hide();                                    //隐藏图例

    ui->widget->setChart(m_chart);
    ui->widget->setRubberBand(QChartView::RectangleRubberBand);   //拉伸效果
    ui->widget->chart()->setAnimationOptions(QChart::AllAnimations);

}
//绘制散点
void MainWindow::drawPoint(MY_BUF bufX,MY_BUF bufY)
{
    QList<QPointF> listPoint;
    m_scatterSeries->clear(); 
    for (int i = 0;i < bufX.count();i++ )
    {
        QPointF pointf;
        pointf.setX(bufX[i]);
        pointf.setY(bufY[i]);
        listPoint << pointf;
    }
    m_scatterSeries->replace(listPoint); //更新散点
}

void MainWindow::on_pushButton_start_clicked()
{
    if(!UDPthread.isRunning())
    {
        UDPthread.start();
    }
    ui->pushButton_start->setEnabled(false);
    ui->pushButton_stop->setEnabled(true);
}

void MainWindow::on_pushButton_stop_clicked()
{
    if(UDPthread.isRunning())
    {
        UDPthread.stop();
    }
    ui->pushButton_start->setEnabled(true);
    ui->pushButton_stop->setEnabled(false);
}

六、效果展示

七、最后 

        后续会有利用 Qt Data Visualization绘制三维点云图,及QT + VS2019 + PCL + VTK的环境搭建,利用QVTKWidget绘制PCL电压的相关内容。

        新人上路,谢谢关注!

       1. 想了解三维维散点图请参考本人文章:

        Qt中使用QtDataVisualization实时绘制雷达点云三维散点图

        2.PCL绘制实时点云请参考后面文章:

        QT+VS2019+PCL实时绘制激光雷达点云

      

  • 7
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 18
    评论
使用 QtCharts 进行二维坐标图绘制的基本步骤如下: 1. 引入头文件 在代码引入 QtCharts 模块的头文件: ```cpp #include <QtCharts> ``` 2. 创建 QChart 对象 创建一个 QChart 对象,用于绘制图表: ```cpp QChart *chart = new QChart; ``` 3. 设置图表标题 使用 setTitle() 函数设置图表的标题: ```cpp chart->setTitle("My Chart"); ``` 4. 创建数据系列 使用 QLineSeries、QScatterSeries 或 QBarSeries 等类创建数据系列,分别用于绘制线图、散点图或柱状图: ```cpp QLineSeries *series = new QLineSeries; ``` 5. 添加数据 使用 append() 函数向数据系列添加数据: ```cpp series->append(0, 1); series->append(1, 3); series->append(2, 4); ``` 6. 将数据系列添加到图表 使用 addSeries() 函数将数据系列添加到图表: ```cpp chart->addSeries(series); ``` 7. 创建坐标轴 使用 QValueAxis 或 QDateTimeAxis 等类创建 X 轴或 Y 轴: ```cpp QValueAxis *axisX = new QValueAxis; axisX->setTitleText("X Axis"); chart->addAxis(axisX, Qt::AlignBottom); QValueAxis *axisY = new QValueAxis; axisY->setTitleText("Y Axis"); chart->addAxis(axisY, Qt::AlignLeft); ``` 8. 将坐标轴添加到图表 使用 addAxis() 函数将 X 轴或 Y 轴添加到图表: ```cpp series->attachAxis(axisX); series->attachAxis(axisY); ``` 9. 显示图表 将图表添加到视图,并显示出来: ```cpp QChartView *chartView = new QChartView(chart); chartView->setRenderHint(QPainter::Antialiasing); chartView->show(); ``` 以上是使用 QtCharts 进行二维坐标图绘制的基本步骤,可以根据具体的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

源客V

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值