当前位置: 首页 > news >正文

Qt之3D绘制曲线:QtDataVisualization实时绘制散点图

一、Qt DataVisualization组件安装

        在Qt安装时勾选 Qt Data Visualization组件,该组件包含相关三维图形绘制组件,利用其开发三维绘图功能需要勾选。

二、准备

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

QT       += datavisualization

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

#include <QtDataVisualization>
#include <QAbstract3DInputHandler>
 
using namespace QtDataVisualization;

三、ui设计

两个按钮,一个widget用于放置三维散点图表。

四、头文件代码 
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>


#include <QVector3D>
#include <QDebug>
#include <QPointF>
#include <QtDataVisualization>
#include <QAbstract3DInputHandler>
#include <QSplitter>

#define PI 3.1415
typedef QVector<QVector3D> MY_BUF3D ;

using namespace QtDataVisualization;



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 drawPoint(MY_BUF3D);

    void on_pushButton_1_clicked();

    void on_pushButton_2_clicked();



private:
    Ui::MainWindow *ui;

    void initMap();
    void generateRandomPoints(QVector<QVector3D>& MY_BUF3D, int pointCount, float minX, float maxX, float minY, float maxY, float minZ, float maxZ);

    Q3DScatter *g_3Dgraph;
    QScatter3DSeries *g_3Dseries;//散点类型
    QtDataVisualization::Q3DCamera *g_camera;


};
#endif // MAINWINDOW_H
五、源文件代码
#include "mainwindow.h"
#include "ui_mainwindow.h"

#include <QSplitter>

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

    qRegisterMetaType<MY_BUF3D>("MY_BUF3D");
    this->setWindowTitle("UDP_Reciver");

    initMap();
    QSplitter *splitter = new QSplitter(Qt::Horizontal);

    splitter->addWidget(ui->widget);

    splitter->addWidget(ui->pushButton_2);
    splitter->addWidget(ui->pushButton_1);

    this->setCentralWidget(splitter);

}

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

void MainWindow::initMap()
{
    g_3Dgraph = new Q3DScatter();
    ui->widget = QWidget::createWindowContainer(g_3Dgraph);
    QScatterDataProxy *proxy = new QScatterDataProxy(); //数据代理
    g_3Dseries = new QScatter3DSeries(proxy);//创建序列
    g_3Dseries->setMeshSmooth(true);

    g_3Dgraph->addSeries(g_3Dseries);
    //创建坐标轴
    g_3Dgraph->axisX()->setTitle("axis X");
    g_3Dgraph->axisX()->setTitleVisible(true);
    g_3Dgraph->axisX()->setRange(-10,10);
    g_3Dgraph->axisY()->setTitle("axis Y");
    g_3Dgraph->axisY()->setTitleVisible(true);
    g_3Dgraph->axisY()->setRange(-10,10);
    g_3Dgraph->axisZ()->setTitle("axis Z");
    g_3Dgraph->axisZ()->setTitleVisible(true);
    g_3Dgraph->axisZ()->setRange(-50,50);
    g_3Dgraph->activeTheme()->setLabelBackgroundEnabled(false);
    g_3Dgraph->activeTheme()->setBackgroundColor(QColor(90,90,90));//设置背景色

    // 获取活动相机
    g_camera = g_3Dgraph->scene()->activeCamera();

    // 设置相机的方位角和仰角
    g_camera->setXRotation(45.0f);
    g_camera->setYRotation(30.0f);

    // 设置相机的距离
    g_camera->setZoomLevel(150.0f);



    g_3Dseries->setMesh(QAbstract3DSeries::MeshSphere);//数据点为圆球
    g_3Dseries->setSingleHighlightColor(QColor(0,0,255));//设置点选中时的高亮颜色
    g_3Dseries->setBaseColor(QColor(0,255,255));//设置点的颜色
    g_3Dseries->setItemSize(0.05);//设置点的大小
}

相关文章:

  • 网络原理--IP协议简介
  • Git简单操作
  • EasyRTC嵌入式WebRTC技术与AI大模型结合:从ICE框架优化到AI推理
  • java练习(45)
  • 惯导(机械编排)算法(INS Mechanization)_预备知识笔记
  • 大语言模型的评测
  • server.servlet.session.timeout: 12h(HTTP 会话的超时时间为 12 小时)
  • # C# 中堆(Heap)与栈(Stack)的区别
  • 一文掌握使用深度学习识别验证码详解(包括图形验证码和滑块验证码)
  • Delphi 12.3 函数指针(函数可以当参数)
  • 7.1 线性代数进行图像处理
  • 【博资考4】网安学院-硕转博考试内容
  • 判断奇数偶数
  • Composer如何通过GitHub Personal Access Token安装私有包:完整教程
  • next.js-学习3
  • 【Multipath网络层协议】MPTCP工作原理
  • 【项目管理】基于 C 语言的 QQ 聊天室实现(TCP + 多线程 + SQLite3)
  • Hadoop完全分布式安装配置
  • Rider 安装包 绿色版 Win/Mac/Linux 适合.NET和游戏开发者使用 2025全栈开发终极指南:从零配置到企业级实战
  • 面向对象基础
  • 吴玉凤获任杭州市政协副秘书长,此前担任富阳区委书记
  • 藤井树与藤井树:岩井俊二式的爱情,情书的三重生命
  • 国新办10时将举行新闻发布会,介绍4月份国民经济运行情况
  • 中国旅游日|上天当个“显眼包”!体验低空经济的“飞”凡魅力
  • 无人机企业从科技园区搬到乡村后,村子里变得不一样了
  • 《缶翁的世界》首发:看吴昌硕王一亭等湖州籍书画家的影响