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

(19)VTK C++开发示例 --- 分隔文本读取器

文章目录

    • 1. 概述
    • 2. CMake链接VTK
    • 3. main.cpp文件
    • 4. 演示效果


更多精彩内容
👉内容导航 👈
👉VTK开发 👈

1. 概述

本例采用坐标和法线(x y z nx ny nz)的纯文本文件,并将它们读入vtkPolyData并显示在屏幕上。通过更改Reader->SetFieldDelimiterCharacters(" ")的参数,可以很容易地将其更改为读取带有任何分隔符的文件;

演示文件下载地址:vtk-data/Data/DelimitedData.txt at master · pyvista/vtk-data

环境说明
系统ubuntu22.04、windows11
cmake3.22、3.25
Qt5.14.2
编译器g++11.4、msvc2017
VTK9.4.1

2. CMake链接VTK

cmake_minimum_required(VERSION 3.20 FATAL_ERROR) # 设置CMake最低版本
project(vtk2) # 设置项目名称
# 查找VTK库
find_package(VTK COMPONENTS 
CommonColor
CommonCore
CommonDataModel
FiltersGeneral
IOInfovis
InteractionStyle
RenderingContextOpenGL2
RenderingCore
RenderingFreeType
RenderingGL2PSOpenGL2
RenderingOpenGL2
)
if(NOT VTK_FOUND)
message("VTK not found")
return()
endif()add_executable(vtk2 main.cpp) # 添加可执行文件target_link_libraries(vtk2 PRIVATE ${VTK_LIBRARIES}) # 链接VTK库
vtk_module_autoinit(TARGETS vtk2 MODULES ${VTK_LIBRARIES}) # 初始化VTK模块

3. main.cpp文件

/********************************************************************************
* 文件名:   main.cpp
* 创建时间: 2025-03-15 21:00:01
* 开发者:   MHF
* 邮箱:     1603291350@qq.com
* 功能:     
*********************************************************************************/
#include <vtkActor.h>
#include <vtkDelimitedTextReader.h>
#include <vtkDoubleArray.h>
#include <vtkNamedColors.h>
#include <vtkNew.h>
#include <vtkPointData.h>
#include <vtkPolyDataMapper.h>
#include <vtkProperty.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkTable.h>
#include <vtkVersionMacros.h>  // 这个头文件是用来获取VTK版本号的
#include <vtkVertexGlyphFilter.h>using namespace std;int main()
{vtkNew<vtkNamedColors> colors;string fileName = "E:/Code/C++/vtk1/bin/DelimitedData.txt";// 用于读取以特定分隔符(如逗号、制表符等)分隔的文本文件的数据。vtkNew<vtkDelimitedTextReader> reader; reader->SetFileName(fileName.c_str());reader->DetectNumericColumnsOn(); // 自动检测数值列reader->SetFieldDelimiterCharacters(" "); // 设置分隔符reader->Update(); // 更新数据vtkTable* table = reader->GetOutput(); // 获取输出数据vtkNew<vtkPoints> points; // 创建点数据vtkNew<vtkDoubleArray> normals; // 创建数据数组normals->SetNumberOfComponents(3); // 设置数据数组的组件数cout << "行:" <<table->GetNumberOfRows() << endl; // 输出行数cout << "列:"<<table->GetNumberOfColumns() << endl; // 输出列数for(vtkIdType i = 0; i < table->GetNumberOfRows(); i++) // 遍历行{cout << "x:"<< table->GetValue(i, 0).ToDouble() << " y:" << table->GetValue(i, 1).ToDouble() << " z:" << table->GetValue(i, 2).ToDouble() << endl;points->InsertNextPoint(table->GetValue(i, 0).ToDouble(), table->GetValue(i, 1).ToDouble(), table->GetValue(i, 2).ToDouble()); // 插入点数据double n[3];n[0] = table->GetValue(i, 3).ToDouble(); // 获取法向量数据n[1] = table->GetValue(i, 4).ToDouble();n[2] = table->GetValue(i, 5).ToDouble();normals->InsertNextTuple(n); // 插入法向量数据cout << "nx:"<< n[0] << " ny:" << n[1] << " nz:" << n[2] << endl;} vtkNew<vtkPolyData> polydata; // 创建多边形数据polydata->SetPoints(points); // 设置点数据polydata->GetPointData()->SetNormals(normals); // 设置法向量数据vtkNew<vtkVertexGlyphFilter> glyphFilter; // 创建顶点过滤器glyphFilter->SetInputData(polydata); // 设置输入数据glyphFilter->Update(); // 更新数据vtkNew<vtkPolyDataMapper> mapper; // 创建多边形数据映射器mapper->SetInputConnection(glyphFilter->GetOutputPort()); // 设置输入连接vtkNew<vtkActor> actor; // 创建演员actor->SetMapper(mapper); // 设置映射器actor->GetProperty()->SetPointSize(30); // 设置点大小actor->GetProperty()->SetColor(colors->GetColor3d("Tomato").GetData()); // 设置颜色vtkNew<vtkRenderer> renderer; // 创建渲染器renderer->AddActor(actor); // 添加演员renderer->SetBackground(colors->GetColor3d("SteelBlue").GetData()); // 设置背景颜色vtkNew<vtkRenderWindow> renderWindow; // 创建渲染窗口renderWindow->AddRenderer(renderer); // 添加渲染器renderWindow->SetWindowName("DelimitedTextReader"); // 设置窗口名称vtkNew<vtkRenderWindowInteractor> renderWindowInteractor; // 创建渲染窗口交互器renderWindowInteractor->SetRenderWindow(renderWindow); // 设置渲染窗口renderWindow->Render(); // 渲染renderWindowInteractor->Start(); // 开始交互return 0;
}

4. 演示效果

在这里插入图片描述



http://www.xdnf.cn/news/1370.html

相关文章:

  • Kafka 详解
  • 服务器上安装jdk
  • Android Cordova 开发 - Cordova 快速入门(Cordova 环境配置、Cordova 第一个应用程序)
  • SQL Server 2022 常见问题解答:从安装到优化的全场景指南
  • Linux部署Web程序
  • openharmony5.0.0中C++公共基础类测试-线程相关(一)
  • 【项目篇】仿照RabbitMQ模拟实现消息队列
  • .NET、java、python语言连接SAP系统的方法
  • 音视频小白系统入门课-4
  • 个人mysql学习笔记
  • python中 zip的用法
  • 汽车免拆诊断案例 | 2016款奔驰C200L车组合仪表上多个故障灯偶尔点亮
  • 管理100个小程序-很难吗
  • JavaScript性能优化实战(3):内存管理与泄漏防范
  • Rust 学习笔记:Rust 简介
  • 四川气象数据智能体示范应用入围中国信通院“开源大模型+”案例
  • 数据结构手撕--【栈和队列】
  • fpga系列 HDL:跨时钟域同步 脉冲展宽同步 Pulse Synchronization
  • Redis Pipeline 详解
  • Elasticsearch内核探秘:从Shard分配到网络通信的深度实践指南
  • Kafka简介
  • linux内核进程管理(1)——创建,退出
  • Go全栈_Golang、Gin实战、Gorm实战、Go_Socket、Redis、Elasticsearch、微服务、K8s、RabbitMQ全家桶
  • 硬件基本概念
  • 汽车免拆诊断案例 | 2013款大众辉腾车发动机抖动
  • 从物理到预测:数据驱动的深度学习的结构化探索及AI推理
  • STM32提高篇: 蓝牙通讯
  • 量化价值投资的SWOT分析:从传统投资到量化策略的转型
  • chrony服务器
  • 【解读】Chrome 浏览器实验性功能全景