LibLas学习笔记

las 

什么是Las格式

LAS文件格式是数据用户之间交换三维点云数据的公共文件格式。

虽然这种格式主要用于交换激光雷达点云数据,但是它支持交换任何三维的x、y、z 数组。

这种二进制文件格式可以替代私有系统或许多公司使用的通用ASCII文件交换系统。私有系统的问题很明显,因为数据不能轻易地从一个系统转移到另一个系统。

ASCII文件交换有两个主要问题:

  1. 性能问题: 因为ASCII高程数据的读取和解释可能非常慢,即使对于少量数据,文件大小也可能非常大。
  2. 所有与激光雷达数据相关的信息都会丢失。

Las文件的优势

LAS文件格式是一种二进制文件格式,它维护特定于数据的激光雷达性质的信息,同时不会过于复杂。

Las格式介绍

参考链接

该格式包含由公共头块组成的二进制数据,任意数量的(可选)可变长度记录(vlrs),点数据记录,任意数量(可选)可扩展的可变长度记录。

所有数据是小顶端的格式

公共头文件包含的数据内容:

1. 一般的数据,点的个数和点的边界。

可变长度包含的数据类型:

1. 投影信息

2. 元数据

3. 波形包信息数据

4. 用户应用数据

可扩展的可变长度数据: 可以追加在LAS文件的末尾。


LAS文件数据格式定义

头文件格式的定义:

使用liblas库

  1. 包含所需的头文件和C++标准库
#include <liblas/liblas.hpp>
#include <fstream> // std::ifstream
#include <iostream> // std::cout
  1. 为las文件创建输入流,使用binary模式
  1. std::ifstream ifs; 

  2. ifs.open("file.las", std::ios::in | std::ios::binary); 

  1. 创建ReaderFactory和实例化一个liblas::Reader使用流
liblas::ReaderFactory f;
liblas::Reader reader = f.CreateWithStream(ifs);
  1. 读取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';
  1. 遍历点的数据
while (reader.ReadNextPoint())
{
liblas::Point const& p = reader.GetPoint(); std::cout << p.GetX() << ", " << p.GetY() << ", " << p.GetZ() << "\n";
}
  1. 随机访问数据

    注意:如果是压缩的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学习笔记的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  3. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  4. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  5. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  6. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  7. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  8. HTML学习笔记

    HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...

  9. DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记

    今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...

随机推荐

  1. activemq的高级特性:通配符式分层订阅

    activemq的高级特性之通配符式分层订阅 队列的名称可以分层:aa.bb.cc.dd 可以匹配:aa.bb.cc.dd,aa.*.cc.dd,aa.> *:匹配当前层的内容 >:任何一 ...

  2. 撩妹技能 get,教你用 canvas 画一场流星雨

    开始 妹子都喜欢流星,如果她说不喜欢,那她一定是一个假妹子. 现在就一起来做一场流星雨,用程序员的野路子浪漫一下. 要画一场流星雨,首先,自然我们要会画一颗流星. 玩过 canvas 的同学,你画圆画 ...

  3. Python2.6与Python2.7的format用法区别

    Python2.6不支持format(123456L, ",")或format(123, ",")的format用法,会报下面的错误 ValueError: U ...

  4. Python基础学习笔记(一)安装以及IDE的配置

    一.初识Python Python官方网站:www.python.org 版本:python-3.4.3.amd64 初次接触Python,没有使用Python 2.x进行开发真实项目的经历.所以不知 ...

  5. hive在客户机启动时出现的问题

    运行环境:一拖一分布式集群+客户端 mysql和hive安装在客户机上 问题:在客户机终端启动hive时出现如下问题: 目前还没有找出是什么原因! 解决办法: 参照http://dblab.xmu.e ...

  6. 【Keil】Keil5-改变字的大小和颜色

    点击 Edit / Configuration 出现弹窗,选择Colors & Fonts 底下可以选择要改哪个部分,例如普通代码.数字.关键字.注释...等等,当然也可以改变背景颜色的,英文 ...

  7. Python3中高阶函数lambda,filter,map,reduce,zip的详细用法

    在Python里有五大高阶函数,他们分别是lambda()匿名函数,filter()筛选函数,map()函数,reduce()函数,zip()函数.下面就让我们来详细的了解一下这五种函数的具体用法吧. ...

  8. Selenium_python自动化跨浏览器执行测试(简单多线程案例)

    发生背景: 跨浏览器测试是功能测试的一个分支,用以验证web应用在不同浏览器上的正常工作,通常情况下,我们都期望web类应用能够被我们的用户在任何浏览器上使用,例如有的人喜欢IE浏览器上使用,有的人喜 ...

  9. STM32F103C8T6、STM32F103ZET6工程模板

    STM32F103C8T6工程模板,推荐使用以下最新版本 最终版 2018 7 16  https://pan.baidu.com/s/1lIdZ2awus_quVu332RvJ6Q https:// ...

  10. hash环/consistent hashing一致性哈希算法

        一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT)实现算法,设计目标是为了解决因特网中的热点(Hot spot)问题,初衷和CARP十分类似.一致性哈希修正了CARP使用的 ...