当前位置: 首页 > news >正文

WxGL应用实例:绘制点云

WxGL附带了几个工具函数,其中read_pcfile用来解析.ply和.pcd格式的点云文件,该函数返回一个PointCloudData类实例,包含以下属性:

  • PointCloudData.ok - 数据是否可用,布尔型
  • PointCloudData.info - 数据可用性说明,字符串
  • PointCloudData.raw - 解读出来的原始数据,字典
  • PointCloudData.fields - 数据字段(项)名称,列表
  • PointCloudData.xyz - 点的坐标数据,None或者numpy数组(ndarray)
  • PointCloudData.rgb - 点的颜色数据,None或者numpy数组(ndarray)
  • PointCloudData.intensity - 点的强度数据,None或者numpy数组(ndarray)

以下代码在IDLE中演示了read_pcfile函数的用法,其中用到的点云文件可从这个地址下载:https://github.com/xufive/wxgl/tree/master/example/res/pointcloud。

>>> import wxgl
>>> ds = wxgl.read_pcfile('/Users/xufive/MyCode/pc/bunny.ply')
>>> ds.ok
True
>>> ds.info
'正常:数据可用'
>>> ds.fields
['x', 'y', 'z', 'confidence', 'intensity']
>>> ds.raw['intensity'].shape
(35947,)
>>> ds.xyz.shape
(35947, 3)

数据解读出来之后,调用app.scatter方法即可绘制出点云模型。

>>> app = wxgl.App()
>>> app.scatter(ds.xyz)
>>> app.show()

这就是大名鼎鼎的斯坦福兔子。模型使用了WxGL自动分配的颜色,也可以使用color参数指定颜色。
在这里插入图片描述

通常点云数据不携带颜色信息,但可能包含激光反射强度。如果数据中有颜色信息,或者用强度信息映射为颜色,则需要用户自行判别并在app.scatter方法中提供color(颜色)参数,或者data(数据)和cm(调色板)参数。还有另外一种更简单的方式,那就是直接使用app.pointcloud方法,只需要一个点云文件参数即可绘制出点云模型,该方法会自动识别文件是否包含颜色信息和激光强度信息。

>>> import wxgl
>>> app = wxgl.App(haxis='z', bg='#001020')
>>> app.pointcloud('/Users/xufive/MyCode/pc/isprs/4.pcd', cm='jet')
>>> app.show()

这段代码中的.pcd文件为二进制压缩格式,采用LZF压缩算法。WxGL内置了一个Pytho版的LZF解压缩算法,省去了安装liblzf库的麻烦,但速度较慢。想要更快的速度,请安装python-lzf模块。绘制出来的点云模型使用蓝黑背景,并使用jet调色板将激光反射强度映射为颜色。
在这里插入图片描述

http://www.lryc.cn/news/65725.html

相关文章:

  • 一个月内面了30家公司,薪资从18K变成28K,真行啊····
  • 《计算机网络——自顶向下方法》精炼——1.4到1.7
  • 消息队列 (Message Queue)
  • JavaScript原型链污染学习记录
  • 顶级白帽黑客必备的十大黑客技术
  • 【关于认证鉴权一些概念梳理】
  • 16.网络爬虫—字体反爬(实战演示)
  • BOM概述
  • 3.Docker实用技术
  • 群体无人机:协同作战的未来
  • 如何在Windows AD域中驻留ACL后门
  • LVGL移植——stm32f4
  • ASEMI代理ADP5054ACPZ-R7原装ADI车规级ADP5054ACPZ-R7
  • TCP/IP相关面试题
  • MySQL数据库——MySQL存储过程是什么?
  • 消息队列中的事务消息
  • 03. 路由参数.重定向.视图
  • Flowable入门
  • Scala Option类型,异常处理,IO,高阶函数
  • unity进阶学习笔记:单例模式
  • 软件测试——性能指标
  • leetcode 405. 数字转换为十六进制数
  • 部门来了个软件测试,听说是00后,上来一顿操作给我看呆了...
  • 使用篇丨链路追踪(Tracing)很简单:链路拓扑
  • 2023年厦门等保二级备案办理流程
  • 提高开发效率,从这些小技巧开始——5个让你爱上IDEA的增加体验小技巧
  • Python基础合集 练习22 (错误与异常处理语句2)
  • ELK -- kibana 用nginx代理后无法访问
  • 什么是分布式事务
  • 在 Python 中将整数转换为罗马数字