LibLas学习笔记
LibLas学习笔记
什么是Las格式
LAS文件格式是数据用户之间交换三维点云数据的公共文件格式。
虽然这种格式主要用于交换激光雷达点云数据,但是它支持交换任何三维的x、y、z 数组。
这种二进制文件格式可以替代私有系统或许多公司使用的通用ASCII文件交换系统。私有系统的问题很明显,因为数据不能轻易地从一个系统转移到另一个系统。
ASCII文件交换有两个主要问题:
- 性能问题: 因为ASCII高程数据的读取和解释可能非常慢,即使对于少量数据,文件大小也可能非常大。
- 所有与激光雷达数据相关的信息都会丢失。
Las文件的优势
LAS文件格式是一种二进制文件格式,它维护特定于数据的激光雷达性质的信息,同时不会过于复杂。
Las格式介绍
该格式包含由公共头块组成的二进制数据,任意数量的(可选)可变长度记录(vlrs),点数据记录,任意数量(可选)可扩展的可变长度记录。
所有数据是小顶端的格式。
公共头文件包含的数据内容:
1. 一般的数据,点的个数和点的边界。
可变长度包含的数据类型:
1. 投影信息
2. 元数据
3. 波形包信息数据
4. 用户应用数据
可扩展的可变长度数据: 可以追加在LAS文件的末尾。

头文件格式的定义:

使用liblas库
- 包含所需的头文件和C++标准库
#include <liblas/liblas.hpp>
#include <fstream> // std::ifstream
#include <iostream> // std::cout
- 为las文件创建输入流,使用binary模式
- std::ifstream ifs;
- ifs.open("file.las", std::ios::in | std::ios::binary);
- 创建ReaderFactory和实例化一个liblas::Reader使用流
liblas::ReaderFactory f;
liblas::Reader reader = f.CreateWithStream(ifs);
- 读取liblas头文件中的内容
liblas::Header const& header = reader.GetHeader();
std::cout << "Compressed: " << (header.Compressed() == true) ? "true":"false";
std::cout << "Signature: " << header.GetFileSignature() << '\n';
std::cout << "Points count: " << header.GetPointRecordsCount() << '\n';
- 遍历点的数据
while (reader.ReadNextPoint())
{
liblas::Point const& p = reader.GetPoint();
std::cout << p.GetX() << ", " << p.GetY() << ", " << p.GetZ() << "\n";
}
- 随机访问数据
注意:如果是压缩的las数据,会影响性能。如果是批量读取数据请使用Seek方法
reader.ReadPointAt(2);
liblas::Point const& p = reader.GetPoint();
使用las库写数据
Include required header files from libLAS and C++ Standard Library
#include <liblas/liblas.hpp>
#include <fstream> // std::ofstream
#include <iostream> // std::cout
Create output stream and associate it with .las file opened to write data in binary mode
std::ofstream ofs;
ofs.open("file.las", ios::out | ios::binary);
Note It is also possible to open the stream in append mode to add data to an existing file. You should first instantiate a liblas::Reader and fetch the liblas::Header from the file, and then create the liblas::Writer with that header and the ofstream opened in append mode.
liblas::Header header = reader.GetHeader();
std::ios::openmode m = std::ios::out | std::ios::in | std::ios::binary | std::ios::ate;
ofs.open("file.las", m);
liblas::Writer writer(ofs, header);
Create instance of liblas::Header class to define Public Header Block and set some values
liblas::Header header;
header.SetDataFormatId(liblas::ePointFormat1); // Time only
// Set coordinate system using GDAL support
liblas::SpatialReference srs;
srs.SetFromUserInput("EPSG:4326");
header.SetSRS(srs);
// fill other header members
Note Simply setting header.SetCompressed(true) on the header will be sufficient to output a compressed file when the liblas::Writer is created if LASzip support is enabled in libLAS, but it is up to the user to specify the proper file name extension, .laz, when writing the file.
Note The default constructed header object can be used as perfectly valid header. It will define LAS file according to LAS 1.2 and Point Data Format 3.
Create LAS file writer object attached to the output stream and the based on the header object.
liblas::Writer writer(ofs, header);
// here the header has been serialized to disk into the file.las
Write some point records
liblas::Point point(&header);
point.SetCoordinates(10, 20, 30);
// fill other properties of point record
writer.WritePoint(point);
LibLas学习笔记的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
- JAVA GUI编程学习笔记目录
2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- CSS学习笔记
CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...
- HTML学习笔记
HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...
- DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记
今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...
随机推荐
- 简单的 Android 菜单
Android 创建简单的菜单 一:上下文菜单: 1.在 res 下创建菜单项资源文夹 menu app->右击res->new->android resourse director ...
- oracle定时器在项目中的应用
业务需求: 现在业务人员提出了一个需求: 在项目中的工作流,都要有一个流程编号,此编号有一定的规则: 前四五位是流程的字母缩写,中间是8位的日期,后面五位是流水码,要求流水码每天从00001开始.即: ...
- ios开发UI篇—UISlider
概述 UISlider用于从连续范围的值中选择单个值的控件. 当您移动滑块的大拇指时,会将其更新后的值传递给附加的任何动作.滑块的外观是可配置的; 您可以对曲目和大拇指进行着色,并提供出现在滑块末端的 ...
- OO 第五、六、七次作业总结
第五次作业 算法与实现 这次的电梯因为要使用系统时间进行模拟,所以又是推倒了之前的重写的.最后采用三个电梯线程,一个调度线程,一个输入线程的方式. 源码分析图示 类图 方法分析 类分析 由上图看,由于 ...
- BZOJ 2654: tree(二分 最小生成树)
Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 2901 Solved: 1196[Submit][Status][Discuss] Descript ...
- css之层叠上下文和层叠顺序
大家在写网页的时候会不会经常遇到莫名奇妙的样式问题,比如谁覆盖了谁.也找不出原因,为什么z-index高的却没有覆盖掉z-index低的元素呢? 带着这些疑问.我做了个小实验.代码如下: <st ...
- redis学习指南
一.redis安装 # 安装最新版 yum install -y epel-release vim atop htop net-tools git wget gcc-c++ yum clean all ...
- PTA(BasicLevel)-1010 一元多项式求导
一.题目和题意分析 设计函数求一元多项式的导数.x^n [n为整数] 的一阶导数为nx^(n−1). 输入格式: 以指数递降方式输入多项式非零项系数和指数(*绝对值均为不超过 1000 的整数*).数 ...
- 【转载++】fopen返回0(空指针NULL)且GetLastError是0
结论来看,是一个简单又朴素的道理——打开文件句柄用完了得给关上.表现在现象上却是着实让人费解,以至于有人还怀疑起了微软的Winodws系统来了,可笑至极.还是那句话,先把自己的屁股先给擦干净喽再怀疑别 ...
- Circos Ubuntu 安装
下载: http://www.circos.ca/software/download/circos/ Perl 需要5.8及以上的版本. 查看版本的命令: perl -v 解压安装包 安装包是一 ...