ubuntu 编译使用 liblas 读取点云

在ubuntu上使用las读取点云

1、环境配置

1.1、安装libgeotiff

下载依赖

sudo apt-get install libtiff-dev  //安装libtiff
sudo apt-get install libproj-dev  //安装libproj

下载源码,编译
如下该是libgeotiff-1.3.0版本安装包

wget https://download.osgeo.org/geotiff/libgeotiff/libgeotiff-1.3.0.tar.gz
# 解压后
./configure
make
sudo make install

1.2、liblas安装

git clone https://github.com/libLAS/libLAS.git
cd libLAS
mkdir build
cd build
cmake .. 或 cmake -G "Unix Makefiles" ../
make
sudo make install

1.3、测试liblas

las_read.cpp

#include <iostream>
#include <liblas/liblas.hpp>
#include <pcl/io/io.h>
#include <pcl/io/pcd_io.h>
#include <pcl/point_types.h>
using namespace std;
int main(int argc,char **argv)
{//----------------------------- 打开LAS格式点云文件并读取 ----------------------------std::ifstream ifs("****.las", std::ios::in | std::ios::binary); if (!ifs.is_open()){std::cout << "cannot open .las" << std::endl;return (0);}liblas::ReaderFactory f;liblas::Reader reader = f.CreateWithStream(ifs); //读取LAS文件信息头liblas::Header const& header = reader.GetHeader();double maxX = header.GetMaxX();double minX = header.GetMinX();double maxY = header.GetMaxY();double minY = header.GetMinY();double maxZ = header.GetMaxZ();double minZ = header.GetMinZ();int nbPoints = header.GetPointRecordsCount();string signature = header.GetFileSignature();cout << "maxX: " << maxX << endl;cout << "minX: " << minX << endl;cout << "maxY: " << maxY << endl;cout << "minY: " << minY << endl;cout << "maxZ: " << maxZ << endl;cout << "minZ: " << minZ << endl;cout << "点个数: " << maxX << endl;cout << "signature: " << signature << endl;pcl::PointCloud<pcl::PointXYZRGB> cloud;cloud.width = nbPoints;	cloud.height = 1;cloud.is_dense = false;cloud.points.resize(cloud.width * cloud.height);int i = 0;uint16_t r1, g1, b1;int r2, g2, b2;uint32_t rgb;//读取点云坐标和色彩信息while (reader.ReadNextPoint()){// 获取las数据的x,y,z信息cloud.points[i].x = reader.GetPoint().GetX();cloud.points[i].y = reader.GetPoint().GetY();cloud.points[i].z = reader.GetPoint().GetZ();// 获取las数据的r,g,b信息r1 = reader.GetPoint().GetColor().GetRed();g1 = reader.GetPoint().GetColor().GetGreen();b1 = reader.GetPoint().GetColor().GetBlue();r2 = ceil(((float)r1 / 65536)*(float)256);g2 = ceil(((float)g1 / 65536)*(float)256);b2 = ceil(((float)b1 / 65536)*(float)256);rgb = ((int)r2) << 16 | ((int)g2) << 8 | ((int)b2);cloud.points[i].rgb = *reinterpret_cast<float*>(&rgb);i++;}pcl::io::savePCDFile("***.pcd",cloud);return 0;
}//==================================================================

CMakeLists.txt 文件

cmake_minimum_required(VERSION 2.8 FATAL_ERROR)
project(LasRead)find_package(PCL 1.8 REQUIRED)
find_package(libLAS REQUIRED)include_directories(${PCL_INCLUDE_DIRS})
#或者指定搜寻pcl路径
#include_directories("/usr/include/pcl-1.8")link_directories(${PCL_LIBRARY_DIRS})
add_definitions(${PCL_DEFINITIONS})add_executable (las_read las_read.cpp)
target_link_libraries (las_read ${PCL_LIBRARIES} ${libLAS_LIBRARIES})

参考链接

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

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

相关文章

【蓝桥杯冲冲冲】旅行计划

蓝桥杯备赛 | 洛谷做题打卡day18 文章目录 蓝桥杯备赛 | 洛谷做题打卡day18旅行计划题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示题解代码我的一些话 旅行计划 题目描述 Kira酱要去一个国家旅游。这个国家有 N N N 个城市&#xff0c;编号为 1 1 1 至 N N…

计算机网络(第六版)复习提纲11

二、CSMA/CD协议 1.广播信道上的一对一通信 2.以太网的两个措施 a)采用无连接的方法&#xff0c;不可靠 b)发送的数据都是用曼彻斯特编码 3.CSMA/CD协议&#xff08;先听后说&#xff0c;边听边说&#xff09; a)前身是ALOHA协议&#xff0c;想发就发&#xff0c;冲突时随机等待…

SpringSecurity(16)——OAuth2客户端授权模式

工作流程 基本使用 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId><version>2.3.12.RELEASE</version> </dependency> <dependency><groupId>…

大数据Doris(五十九):SQL函数之字符串函数(三)

文章目录 SQL函数之字符串函数(三) 一、​​​​​​​NULL_OR_EMPTY (VARCHAR str)

力扣1312. 让字符串成为回文串的最少插入次数

动态规划 思路&#xff1a; 通过插入字符构造回文串&#xff0c;要想插入次数最少&#xff0c;可以将字符串 s 的逆序 s 进行比较找出最长公共子序列&#xff1b;可以先分析&#xff0c;字符串 s 通过插入得到回文串 ps&#xff0c;其中间的字符应该不会变化&#xff1a; 若 s…

IO复用之epoll模型

什么是epoll epoll 是 Linux 操作系统提供的一种高性能的事件通知机制&#xff0c;用于处理大量文件描述符上的事件。它是一种 I/O 事件通知机制&#xff0c;通常用于处理网络编程中的并发连接。 在传统的 I/O 模型中&#xff0c;程序通常使用 select 或 poll 函数来等待多个…

基于springboot+vue的校园资料分享平台(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目背景…

数据灾难恢复:应对._locked勒索病毒的有效方法

导言&#xff1a; 近年来&#xff0c;网络犯罪愈发猖獗&#xff0c;其中一种威胁备受关注——._locked勒索病毒。这种恶意软件的攻击方式主要通过加密用户的数据文件&#xff0c;随后勒索受害者以解密密钥为代价。在这篇文章中&#xff0c;我们将介绍._locked勒索病毒的特点、…

qt学习:实战 http请求获取qq的吉凶

目录 利用的api是 聚合数据 的qq号码测吉凶 编程步骤 配置ui界面 添加头文件&#xff0c;定义网络管理者和http响应槽函数 在界面的构造函数里创建管理者对象&#xff0c;关联http响应槽函数 实现按钮点击事件 实现槽函数 效果 利用的api是 聚合数据 的qq号码测吉凶 先…

2024 高级前端面试题之 CSS 「精选篇」

该内容主要整理关于 CSS 的相关面试题&#xff0c;其他内容面试题请移步至 「最新最全的前端面试题集锦」 查看。 CSS模块精选篇 1. 盒模型2. BFC3. 层叠上下文4. 居中布局5. 选择器权重计算方式6. 清除浮动7. link 与 import 的区别8. CSS3的新特性9. CSS动画和过渡10. 有哪些…

LabVIEW继电器触点接触电阻自动测试

继电器作为工业中的重要组件&#xff0c;其性能直接影响着整个生产线的可靠性和安全性。触点接触电阻是衡量继电器性能的重要参数&#xff0c;传统的测试方法效率低下且成本高昂。为了解决这些问题&#xff0c;采用LabVIEW软件&#xff0c;结合专业的硬件平台&#xff0c;实现了…

OceanMind海睿思入选《2023大数据产业年度创新技术突破奖》,并蝉联多项图谱

近日&#xff0c;由数据猿和上海大数据联盟主办&#xff0c;上海市经济和信息化委员会、上海市科学技术委员会指导的“第六届金猿季&魔方论坛——大数据产业发展论坛”在上海成功举行&#xff0c;吸引了数百位业界精英的参与。中新赛克海睿思作为国内数字化转型优秀厂商代表…

用C语言实现贪吃蛇游戏!!!(破万字)

前言 大家好呀&#xff0c;我是Humble&#xff0c;不知不觉在CSND分享自己学过的C语言知识已经有三个多月了&#xff0c;从开始的C语言常见语法概念说到C语言的数据结构今天用C语言实现贪吃蛇已经有30余篇博客的内容&#xff0c;也希望这些内容可以帮助到各位正在阅读的小伙伴…

【 C++私房菜】模板的入门与进阶

目录 一、模板的定义 a.函数模板的调用 b.类模板的定义 2、模板的重载 3、非类型模板参数和模板类型参数 4、模板的编译 二、模板的特化 1、函数模板特化 2、类模板特化 a.全特化 b.偏特化 三、模板相关定义 一、模板的定义 a.函数模板的调用 理在的 C编译器实现…

头歌C++之For循环性质编程实训

目录 第1关:求1到n间所有整数的和 本关必读 本关任务 测试说明 第2关:求s=a+aa+aaa+aaaa+aa...a的值 本关必读 本关任务 测试说明 第3关:求1!+2!+3!+⋯+n!的值 本关必读 本关任务

确定软件项目范围基准 5个重点

软件项目范围基准明确了项目的边界、目标和主要交付成果&#xff0c;有助于提高项目成本、进度和资源估算的准确性&#xff0c;便于实施项目控制&#xff0c;而且还可以帮助我们清楚分派责任&#xff0c;防止范围蔓延&#xff0c;从而提升项目的成功率。 如果没有明确确定范围基…

Pointnet++改进优化器系列:全网首发AdamW优化器 |即插即用,实现有效涨点

简介:1.该教程提供大量的首发改进的方式,降低上手难度,多种结构改进,助力寻找创新点!2.本篇文章对Pointnet++特征提取模块进行改进,加入AdamW优化器,提升性能。3.专栏持续更新,紧随最新的研究内容。 目录 1.理论介绍 2.修改步骤 2.1 步骤一 2.2 步骤二 2.3 步

网络基础---初识网络

前言 作者&#xff1a;小蜗牛向前冲 名言&#xff1a;我可以接受失败&#xff0c;但我不能接受放弃 如果觉的博主的文章还不错的话&#xff0c;还请点赞&#xff0c;收藏&#xff0c;关注&#x1f440;支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、局域网…

算法训练营Day59(单调栈)

下一个更大元素II 503. 下一个更大元素 II - 力扣&#xff08;LeetCode&#xff09; 最直接的方法&#xff0c;我自己写的。。 class Solution {public int[] nextGreaterElements(int[] nums) {int len nums.length*2;int [] nums2 new int[len];for(int i 0;i<len;i…

Nav2笔记

1、源码安装 git clone https://github.com/ros-planning/navigation2.git -b humble 1.1 一键安装依赖 wget http://fishros.com/install -O fishros && . fishros rosdepc install -r --from-paths src --ignore-src --rosdistro $ROS_DISTRO -y 1.2 编译 colc…