云点数据读写

一、常见点云数据格式

  1. LAS/LAZ格式

    • LAS是点云数据的行业标准格式

    • LAZ是LAS的压缩版本

    • 支持地理参考信息、颜色、强度等属性

  2. PCD格式(Point Cloud Data)

    • PCL(Point Cloud Library)开发的格式

    • 支持ASCII和二进制存储

    • 包含头部信息和数据部分

  3. PLY格式(Polygon File Format)

    • 最初为存储3D扫描仪数据设计

    • 支持点云和网格数据

    • 可包含颜色、法线等属性

  4. OBJ格式

    • 简单文本格式

    • 主要用于3D模型但也可存储点云

二、读写工具和库

  1. PDAL(Point Data Abstraction Library)

    • 开源点云数据处理库

    • 支持多种格式转换和处理

  2. PCL(Point Cloud Library)

    • 强大的点云处理库

    • 提供多种点云格式的读写接口

  3. LASlib/LASzip

    • 专门用于LAS/LAZ格式的读写

  4. CloudCompare

    • 开源点云处理软件

    • 支持多种格式的导入导出

 

三、PCL读写点云数据

 PCL(Point Cloud Library)是处理点云数据的强大开源库,提供了多种点云数据格式的读写功能。以下是使用PCL进行点云数据读写的主要方法。

1. 基本点云数据结构

pcl::PointCloud 类

主要属性

  • width - 点云的宽度(对于无组织点云表示点数,对于有组织点云表示每行点数)

  • height - 点云的高度(对于无组织点云通常为1,对于有组织点云表示行数)

  • points - 存储所有点的向量

  • is_dense - 布尔值,表示点云是否包含无限/NaN值

  • sensor_origin_ - 传感器原点坐标(Eigen::Vector4f)

  • sensor_orientation_ - 传感器方向(Eigen::Quaternionf)

2. 常用点类型

点类型描述包含数据
pcl::PointXYZ基本XYZ点float x, y, z
pcl::PointXYZI带强度的XYZ点float x, y, z, intensity
pcl::PointXYZRGB带RGB颜色的XYZ点float x, y, z; uint32_t rgb
pcl::PointXYZRGBA带RGBA颜色的XYZ点float x, y, z; uint32_t rgba
pcl::PointNormal带法线的XYZ点float x, y, z, normal_x, normal_y, normal_z, curvature

3. 读写点云数据方法

读取点云文件

cpp

#include <pcl/io/pcd_io.h>// 读取PCD文件
pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);
if (pcl::io::loadPCDFile<pcl::PointXYZ>("input.pcd", *cloud) == -1) {PCL_ERROR("Couldn't read file input.pcd\n");return -1;
}// 读取PLY文件
#include <pcl/io/ply_io.h>
pcl::PLYReader reader;
reader.read("input.ply", *cloud);

写入点云文件

cpp

// 写入PCD文件(二进制格式)
pcl::io::savePCDFileBinary("output.pcd", *cloud);// 写入PCD文件(ASCII格式)
pcl::io::savePCDFileASCII("output_ascii.pcd", *cloud);// 写入PLY文件
pcl::PLYWriter writer;
writer.write("output.ply", *cloud, false); // false表示不保存二进制格式

4. 常用方法参数表

方法参数返回值描述
loadPCDFile(const std::string &file_name, PointCloud &cloud)int加载PCD文件
savePCDFile(const std::string &file_name, const PointCloud &cloud, bool binary_mode=false)int保存PCD文件
loadPLYFile(const std::string &file_name, PointCloud &cloud)int加载PLY文件
savePLYFile(const std::string &file_name, const PointCloud &cloud, bool binary_mode=false)int保存PLY文件
fromROSMsg(const sensor_msgs::PointCloud2 &msg, PointCloud &cloud)void从ROS消息转换
toROSMsg(const PointCloud &cloud, sensor_msgs::PointCloud2 &msg)void转换为ROS消息

 其他格式支持

1. PLY格式读写

cpp

#include <pcl/io/ply_io.h>// 读取PLY文件
pcl::PLYReader reader;
reader.read("input.ply", *cloud);// 写入PLY文件
pcl::PLYWriter writer;
writer.write("output.ply", *cloud);
2. OBJ格式读写

cpp

#include <pcl/io/obj_io.h>// 读取OBJ文件
pcl::OBJReader reader;
reader.read("input.obj", *cloud);// 写入OBJ文件
pcl::OBJWriter writer;
writer.write("output.obj", *cloud);
二进制与ASCII格式

PCD文件可以保存为二进制或ASCII格式:

cpp

// 保存为二进制格式(更小更快)
pcl::io::savePCDFileBinary("output_binary.pcd", *cloud);// 保存为压缩二进制格式(更小)
pcl::io::savePCDFileBinaryCompressed("output_compressed.pcd", *cloud);// 保存为ASCII格式(可读)
pcl::io::savePCDFileASCII("output_ascii.pcd", *cloud);

5. 点云基本操作

添加点

cpp

pcl::PointXYZ point;
point.x = 1.0; point.y = 2.0; point.z = 3.0;
cloud->points.push_back(point);

访问点

cpp

// 随机访问
float x = cloud->points[10].x;// 遍历所有点
for (const auto& point : *cloud) {std::cout << "x: " << point.x << " y: " << point.y << " z: " << point.z << std::endl;
}

点云属性

cpp

std::cout << "点云大小: " << cloud->size() << std::endl;
std::cout << "宽度: " << cloud->width << std::endl;
std::cout << "高度: " << cloud->height << std::endl;
std::cout << "是否为有组织点云: " << cloud->isOrganized() << std::endl;

6. 常用信号(ROS相关)

在PCL与ROS结合使用时,常用的信号包括:

信号参数描述
pcl::visualization::PointPickingEventconst pcl::visualization::PointPickingEvent &event当用户选择点时触发
pcl::visualization::KeyboardEventconst pcl::visualization::KeyboardEvent &event键盘事件
pcl::visualization::MouseEventconst pcl::visualization::MouseEvent &event鼠标事件

7. 示例代码:完整读写流程

cpp

#include <iostream>
#include <pcl/io/pcd_io.h>
#include <pcl/point_types.h>int main() {// 创建一个点云对象pcl::PointCloud<pcl::PointXYZ>::Ptr cloud(new pcl::PointCloud<pcl::PointXYZ>);// 填充点云数据cloud->width = 5;cloud->height = 1;cloud->is_dense = false;cloud->points.resize(cloud->width * cloud->height);for (auto& point : *cloud) {point.x = 1024 * rand() / (RAND_MAX + 1.0f);point.y = 1024 * rand() / (RAND_MAX + 1.0f);point.z = 1024 * rand() / (RAND_MAX + 1.0f);}// 保存到文件pcl::io::savePCDFileASCII("test_pcd.pcd", *cloud);std::cout << "保存了 " << cloud->size() << " 个点到 test_pcd.pcd" << std::endl;// 从文件读取pcl::PointCloud<pcl::PointXYZ>::Ptr cloud_from_file(new pcl::PointCloud<pcl::PointXYZ>);pcl::io::loadPCDFile<pcl::PointXYZ>("test_pcd.pcd", *cloud_from_file);// 显示读取的点云for (const auto& point : *cloud_from_file)std::cout << "    " << point.x << " " << point.y << " " << point.z << std::endl;return 0;
}

8. 注意事项

  1. 内存管理:使用智能指针(如boost::shared_ptrpcl::PointCloud::Ptr)管理点云对象

  2. 文件格式:PCD文件有ASCII和二进制格式,二进制格式更节省空间

  3. 点云类型:读写时要确保点云类型匹配

  4. ROS集成:PCL与ROS紧密集成,可以方便地与sensor_msgs::PointCloud2相互转换

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/77491.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[RHEL8] 指定rpm软件包的更高版本模块流

背景&#xff1a;挂载RHEL ISO使用kickstart安装操作系统&#xff0c;安装包未指定安装perl&#xff0c;但是安装完可以查到其版本&#xff0c;且安装的是ISO中多个版本中的最低版本。 原因&#xff1a;&#xff08;1&#xff09;为什么没有装perl&#xff0c;perl -v可以看到版…

Spring 事务管理核心机制与传播行为应用

Spring 事务详解 一、Spring 事务简介 Spring 事务管理基于 AOP&#xff08;面向切面编程&#xff09;实现&#xff0c;通过 声明式事务&#xff08;注解或 XML 配置&#xff09;统一管理数据库操作&#xff0c;确保数据一致性。核心目标&#xff1a;保证多个数据库操作的原子…

JavaScript解密实战指南:从基础到进阶技巧

JavaScript加密技术广泛应用于数据保护、反爬虫和代码混淆&#xff0c;但掌握解密方法能帮助开发者突破技术壁垒。本文结合爬虫实战与安全分析场景&#xff0c;系统梳理JS解密的核心方法与工具。 一、基础解密方法 1. Base64解码 适用于简单编码场景&#xff0c;如Cookie加密…

WEMOS LOLIN32

ESP32是結合Wi-Fi和藍牙的32位元系統單晶片&#xff08;SoC&#xff09;與外接快閃記憶體的模組。許多廠商生產採用ESP32模組的控制板&#xff0c;最基本的ESP控制板包含ESP32模組、直流電壓轉換器和USB序列通訊介面IC。一款名為WEMOS LOLIN32的ESP32控制板具備3.7V鋰電池插座。…

俄罗斯方块-简单开发版

一、需求分析 实现了一个经典的俄罗斯方块小游戏&#xff0c;主要满足以下需求&#xff1a; 1.图形界面 使用 pygame 库创建一个可视化的游戏窗口&#xff0c;展示游戏的各种元素&#xff0c;如游戏区域、方块、分数等信息。 2.游戏逻辑 实现方块的生成、移动、旋转、下落和锁…

使用安全继电器的急停电路设计

使用安全继电器的急停电路设计 一&#xff0c;急停回路的设计1&#xff0c;如何将急停接到线路当中&#xff1f;2&#xff0c;急停开关 如何接到安全继电器中 一&#xff0c;急停回路的设计 急停是每一个设备必不可少的部分&#xff0c;因为关乎安全&#xff0c;所以说所以说他…

【读书笔记·VLSI电路设计方法解密】问题64:什么是芯片的功耗分析

低功耗设计是一种针对VLSI芯片功耗持续攀升问题的设计策略。随着工艺尺寸微缩&#xff0c;单颗芯片可集成更多元件&#xff0c;导致功耗相应增长。更严峻的是&#xff0c;现代芯片工作频率较二十年前大幅提升&#xff0c;而功耗与频率呈正比关系。因此&#xff0c;芯片功耗突破…

在 Debian 10.x 安装和配置 Samba

1. 更新系统 sudo apt update sudo apt upgrade -y2. 安装 Samba sudo apt install samba -y3. 配置 Samba 备份默认配置文件 sudo cp /etc/samba/smb.conf /etc/samba/smb.conf.bak编辑配置文件 sudo nano /etc/samba/smb.conf示例配置&#xff08;共享目录&#xff09; …

修改PointLIO项目

添加key_frame_info.msg消息 新建.msg文件&#xff0c;内容填写为&#xff1a; # Cloud Info Header header # cloud messages sensor_msgs/PointCloud2 key_frame_cloud_ori sensor_msgs/PointCloud2 key_frame_cloud_transed sensor_msgs/PointCloud2 key_frame_poses其中k…

关于隔离1

1.隔离的目的&#xff1a; 在隔离电源设计中&#xff0c;输入与输出之间没有直接电气连接&#xff0c;提供绝缘高阻态&#xff0c;防止电流回路。这意味着输入与输出之间呈现为绝缘的高阻态&#xff0c;从而确保了无电流回路的形成。 隔离与可靠保护有关。电隔离是一种电路设…

【java实现+4种变体完整例子】排序算法中【插入排序】的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格

以下是插入排序的详细解析&#xff0c;包含基础实现、常见变体的完整代码示例&#xff0c;以及各变体的对比表格&#xff1a; 一、插入排序基础实现 原理 将元素逐个插入到已排序序列的合适位置&#xff0c;逐步构建有序序列。 代码示例 public class InsertionSort {void…

清醒思考的艺术

成为穿越暴风雨后的幸存者 系统性错误是指系统性的偏离理性&#xff0c;偏离最理想的、合乎逻辑的、理智的思考和行为。 “系统”一词很重要&#xff0c;因为我们经常错误地走向同一方向。 幸存偏误 幸存偏误会扭曲概率&#xff0c;系统性的高估了成功概率。一旦混淆选择标准和…

DSA数据结构与算法 6

查找技术&#xff08;Searching Techniques&#xff09; 查找简介 在计算机科学中&#xff0c;“查找”指的是在某个集合或序列中寻找特定元素的过程。这个过程可以是成功的&#xff0c;也可以是失败的&#xff1a; 若目标元素存在于集合中&#xff0c;我们称之为“查找成功”…

FastAPI:现代高性能Python Web框架的技术解析与实践指南

一、FastAPI的诞生背景与技术定位 在数字化转型的浪潮中,API(应用程序接口)作为连接服务与数据的核心枢纽,其性能与开发效率直接影响业务迭代速度。传统Python框架如Django和Flask虽功能丰富,但在高并发场景下面临性能瓶颈,且缺乏对异步编程的原生支持。FastAPI应运而生…

VuePress 使用教程:从入门到精通

VuePress 使用教程&#xff1a;从入门到精通 VuePress 是一个以 Vue 驱动的静态网站生成器&#xff0c;它为技术文档和技术博客的编写提供了优雅而高效的解决方案。无论你是个人开发者、团队负责人还是开源项目维护者&#xff0c;VuePress 都能帮助你轻松地创建和管理你的文档…

1.Vue自动化工具安装(Vue-cli)

目录 1.node.js 安装&#xff1a; 2 npm 安装 3 安装Vue-cli 4总结&#xff1a; 一般情况下&#xff0c;单文件组件&#xff0c;我们运行在 自动化工具vue-CLI中&#xff0c;可以帮我们编译单文件组件。所以我们在学习时一般需要在系统中先搭建vue-CLI工具 下面就是一些我…

IP数据报

IP数据报组成 IP数据报&#xff08;IP Datagram&#xff09;是网络中传输数据的基本单位。 IP数据报头部 版本&#xff08;Version&#xff09; 4bit 告诉我们使用的是哪种IP协议。IPv4版本是“4”&#xff0c;IPv6版本是“6”。 头部长度&#xff08;IHL&#xff0c;Intern…

Leetcode 2158. 每天绘制新区域的数量【Plus题】

1.题目基本信息 1.1.题目描述 有一幅细长的画&#xff0c;可以用数轴来表示。 给你一个长度为 n 、下标从 0 开始的二维整数数组 paint &#xff0c;其中 paint[i] [starti, endi] 表示在第 i 天你需要绘制 starti 和 endi 之间的区域。 多次绘制同一区域会导致不均匀&…

Git Flow

Git Flow深度解析&#xff1a;企业级分支管理实战指南 前言 在持续交付时代&#xff0c;分支策略决定团队协作效率。Git Flow作为经典的分支管理模型&#xff0c;被Apache、Spring等知名项目采用。2023年JetBrains开发者调查报告显示&#xff0c;Git Flow仍是中大型项目最常用…

[Swift]pod install成功后运行项目报错问题error: Sandbox: bash(84760) deny(1)

操作&#xff1a; platform :ios, 14.0target ZKMKAPP do# Comment the next line if you dont want to use dynamic frameworksuse_frameworks!# Pods for ZKMKAPPpod Moyaend pod install成功后运行报错 报错&#xff1a; error: Sandbox: bash(84760) deny(1) file-writ…