C++ 【 Open3D 】 点云按高程进行赋色

一、 Open3D中根据点云的高程度信息为点云中的每个点附上颜色,并保存颜色渲染结果!

#include<iostream>
#include<open3d/Open3D.h>using namespace std;int main()
{//-------------------------------读取点云---------------------------------auto cloud = std::make_shared<open3d::geometry::PointCloud>();if (open3d::io::ReadPointCloud("hand.pcd", *cloud) == 0){open3d::utility::LogInfo("点云读取失败!!!");return -1;}// ---------------------------计算高程取值范围----------------------------double maxZvalue = cloud->GetMaxBound()[2];double minZvalue = cloud->GetMinBound()[2];cout << "最大值为:: " << maxZvalue << ",最小值为: " << minZvalue << endl;// ----------------------根据高程对点云进行颜色渲染-----------------------cloud->colors_.resize(cloud->points_.size());open3d::visualization::ColorMapJet colormap;for (size_t i = 0; i < cloud->points_.size(); ++i){// 高程归一化double normZvalue = (cloud->points_[i][2] - minZvalue) / (maxZvalue - minZvalue);cloud->colors_[i] = colormap.GetColor(normZvalue); // 颜色渲染}open3d::io::WritePointCloudToPCD("Elevation.pcd", *cloud, false);// ------------------------------结果可视化------------------------------open3d::visualization::DrawGeometries({ cloud }, u8"点云按高程赋色", 800, 600);return 0;
}

二、测试结果为:

请添加图片描述

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

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

相关文章

nasa数据集——1 度网格单元的全球月度土壤湿度统计数据

AMSR-E/Aqua level 3 global monthly Surface Soil Moisture Averages V005 (AMSRE_AVRMO) at GES DISC GES DISC 的 AMSR-E/Aqua 第 3 级全球地表土壤水分月平均值 V005 (AMSRE_AVRMO) AMSR-E/Aqua level 3 global monthly Surface Soil Moisture Standard Deviation V005 (…

优化 .NET Core 应用程序的安全性和性能以应对高负载

一. .NET Core 中的安全措施 1. 身份验证和授权 实施强大的身份验证和授权机制是保护应用程序资源的基础。.NET Core 内置支持各种身份验证方案&#xff0c;例如 JWT&#xff08;JSON Web 令牌&#xff09;、OAuth 和 OpenID Connect。通过配置身份验证中间件并定义授权策略&…

vue中el-table单元格复制功能

一、单页面中使用 1.在el-table上绑定单击事件 cell-click“copyText” 或双击事件 cell-dblclick“copyText” 注&#xff1a;cell-dblclick函数有四个参数&#xff0c;分别是row, column, cell, event&#xff1b; row&#xff1a;可看到被其操作单元格所在行的所有的数据&…

【IT领域新生必看】解锁 `final` 关键字的秘密:Java 编程中的终极武器

文章目录 引言什么是 final 关键字&#xff1f;一、 final 变量final 局部变量final 实例变量final 静态变量 二、 final 方法三、 final 类四、 final 关键字的实际应用1. 定义常量2. 防止方法被重写3. 创建不可变类4. 优化性能 五、 final 的一些常见误区1. final 变量不能在…

力扣995.K连续位的最小翻转次数

力扣995.K连续位的最小翻转次数 因为翻转顺序改变不影响最终结果 因此从头找每个位置翻转后的结果如果为0 将从它开始的K长的数组翻转 class Solution {public:int minKBitFlips(vector<int>& nums, int k) {int n nums.size();vector<int> s(n1);int res0…

05.FFMPEG日志系统

一、头文件 #include <libavutil/log.h> 二、常用函数 1、av_log_set_level void av_log_set_level(int level);该函数用于设置全局日志级别。 2、av_log void av_log(void* avcl, int level, const char* fmt, ...);该函数用于输出日志消息。avcl 参数是相关联的上下…

uboot学习:(三)目录分析

目录 目录分析 uboot自带 编译生成的文件 分析之前需要编译一次uboot源码&#xff0c;编译之后的uboot源码会多出来很多文件 目录分析 uboot自带 api 与硬件无关的API函数arch 与架构体系有关的代码 里面有x86,arm等架构文件夹 架构文件夹里面有cpu&#xff0c;设备树等…

使用 Nuxt 3 搭建国际官网

搭建国际官网是一个复杂的任务,涉及多方面的技术和策略。在这篇文章中,我们将探讨如何使用 Nuxt 3 框架搭建一个国际化官网,并展示其在 SEO 优势和全栈可维护性方面的卓越性能。 使用 Nuxt 3 搭建国际官网 1. Nuxt 3 简介 Nuxt 3 是一个基于 Vue 3 和 Vite 的框架,旨在构…

大数据面试题之ElasticSearch(2)

目录 ElasticSearch的单播、多播和广播 什么是Zen Discovery机制 ElasticSearch和Solr主要区别 ElasticSearch和Solr各自适用于哪些场景 Elasticsearch的同类产品有哪些 Elasticsearch有哪些主要应用场景 Elasticsearch 中执行搜索的各种可能方式有哪些 Elasticsearch 中…

UWB系列教程(一)UWB简介

UWB系列教程&#xff08;一&#xff09;&#xff1a;UWB简介 超宽带&#xff08;Ultra-Wideband, UWB&#xff09;技术作为一种先进的无线通信技术&#xff0c;近年来在多个领域展现出了巨大的潜力和应用前景。 什么是超宽带&#xff08;UWB&#xff09;技术&#xff1f; 超…

Java中的数据缓存技术及其应用

Java中的数据缓存技术及其应用 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在现代应用程序中&#xff0c;数据缓存是一种重要的技术手段&#xff0c;用于提…

linux中的僵尸进程

僵尸进程&#xff08;Zombie Process&#xff09;是指在操作系统中&#xff0c;一个进程已经终止执行了&#xff08;即已经退出&#xff09;&#xff0c;但是其父进程还没有通过 wait() 系统调用来获取该进程的终止状态&#xff08;exit status&#xff09;&#xff0c;因此该进…

Python面试宝典第10题:精选选择题

题目1 在以下函数中&#xff0c;b和a的关系是___。 def add_one_to_list(lst):lst.append(1)return lsta [1, 2, 3] b add_one_to_list(a) A. b是a的浅拷贝 B. b和a是同一个列表对象 C. b是a的深拷贝 D. b是a的一个子列表 题目2 以下函数的作用是___。 def operate_s…

C++多态的实现原理

静态多态&#xff08;编译期&#xff09; 函数重载&#xff1a; 允许在同一个作用域中声明多个功能类似的同名函数函数的参数列表不同&#xff08;参数个数&#xff0c;参数类型&#xff0c;参数顺序&#xff09;注意&#xff1a;不能通过函数返回值区分&#xff08;name man…

(补充)IDEA项目结构

文章目录 前言一、pycharm中Python项目结构二、IDEA中的java项目结构设计总结前言 本文主要介绍一下pycharm和IDEA里面的项目结构的使用方法 一、pycharm中Python项目结构 之前我们在pycharm做过python项目,项目结构很清晰,还是比较灵活的。 一般项目里面就是 数据驱动、数…

【JavaSE】程序逻辑控制

目录 1. 顺序结构 2. 分支结构 2.1 if语句 2.1.1 语法格式1 2.1.2 语法格式2 2.1.3 语法格式3 2.1.4 练习 2.1.5 注意事项 2.2 switch 语句 3. 循环结构 3.1 while循环 3.1.1 语法格式 3.1.2 代码示例 3.1.3 注意事项 3.2 break 3.3 continue 3.4 for循环 …

scratch3编程05-画笔绘制圆及与圆相关的图形

目录 一&#xff0c;圆 1&#xff0c;空心圆 2&#xff0c;实心圆 3&#xff0c;嵌套在一起的圆 4&#xff0c;圆环 二&#xff0c;五角星 1&#xff0c;空心五角星 1&#xff09;思路 2&#xff09;完整的程序 2&#xff0c;实心五角星 1&#xff09;思路 2&…

C# 预处理器指令

C# 预处理器指令 概述 C# 预处理器指令是编译器在编译代码之前处理的指令。这些指令用于控制编译过程,包括条件编译、编译指令的定义和取消等。预处理器指令以 # 开头,不包含在代码的执行逻辑中,仅在编译阶段起作用。 常用的预处理器指令 1. #define 和 #undef #define…

RK3568笔记三十三: helloworld 驱动测试

若该文为原创文章&#xff0c;转载请注明原文出处。 报着学习态度&#xff0c;接下来学习驱动是如何使用的&#xff0c;从简单的helloworld驱动学习起。 开始编写第一个驱动程序—helloworld 驱动。 一、环境 1、开发板&#xff1a;正点原子的ATK-DLRK3568 2、系统&#xf…

d3dcompiler_43.dll文件是什么?如何快速有效的解决d3dcompiler_43.dll文件丢失问题

dcompiler_43.dll 是一个Windows系统中的系统文件&#xff0c;属于DirectX软件的一部分。这个dcompiler_43.dll&#xff08;动态链接库&#xff09;文件主要用于处理与3D图形编程有关的任务&#xff0c;是运行许多游戏和高级图形程序必需的组件之一。那么如果电脑丢失d3dcompil…