open3d——点云/3D (随机生成数据显示点云 & 可视化pcd文件 & ply转为pcd/可视化ply文件)

 

自己(随机)生成数据点显示点云

import os
import numpy as np
from open3d import *


points = np.random.rand(10000, 3)
point_cloud = PointCloud()
point_cloud.points = Vector3dVector(points)


draw_geometries([point_cloud])

 

可视化pcd文件

import open3d as o3d
import numpy as np

ply = o3d.io.read_point_cloud('11.pcd') 

o3d.visualization.draw_geometries([ply])

 

同时显示多个pcd文件

import open3d as o3d
import numpy as np
 
ply = o3d.io.read_point_cloud('table_scene_mug_stereo_textured_cylinder.pcd') 
ply1 = o3d.io.read_point_cloud('table_scene_mug_stereo_textured_plane.pcd') 

o3d.visualization.draw_geometries([ply,ply1])

同时显示在一个页面里

 

用不同颜色同时显示多个点云

import open3d as o3d
import numpy as np
src_cloud_file = '0040_cloud.pcd'
tgt_cloud_file = "0071_cloud.pcd"


src_pcd = o3d.io.read_point_cloud(src_cloud_file)
tgt_pcd = o3d.io.read_point_cloud(tgt_cloud_file)

src_pcd.paint_uniform_color([1, 0.706, 0])  # 黄色
tgt_pcd.paint_uniform_color([0, 0.651, 0.929])  # 蓝色

o3d.visualization.draw_geometries([tgt_pcd, src_pcd])
#或者写作([tgt_pcd] + [src_pcd])

 

添加坐标轴

import open3d as o3d
import numpy as np
src_cloud_file = '0040_cloud.pcd'
tgt_cloud_file = "0071_cloud.pcd"

FOR1 = o3d.create_mesh_coordinate_frame(size=5, origin=[0, 0, 0])

src_pcd = o3d.io.read_point_cloud(src_cloud_file)
tgt_pcd = o3d.io.read_point_cloud(tgt_cloud_file)

src_pcd.paint_uniform_color([1, 0.706, 0])  # 黄色
tgt_pcd.paint_uniform_color([0, 0.651, 0.929])  # 蓝色


o3d.visualization.draw_geometries([FOR1, tgt_pcd, src_pcd])

红色是X轴,绿色是Y轴,蓝色是Z

 

显示单个点

import open3d
import numpy as np
import cv2

# 在3D坐标上绘制点:坐标点[x,y,z]对应R,G,B颜色
points = np.array([[0.1, 0.1, 0.1], [1, 0, 0], [0, 1, 0], [0, 0, 1]])
colors = [[1, 1, 1], [1, 0, 0], [0, 1, 0], [0, 0, 1]]

test_pcd = open3d.geometry.PointCloud()  # 定义点云
 
test_pcd.points = open3d.utility.Vector3dVector(points)  # 定义点云坐标位置

open3d.visualization.draw_geometries([test_pcd,axis_pcd], window_name="Open3D2")

也可以不设定颜色

 

动态显示3D点云

需要open3d==0.8.0

import os
import numpy as np
import open3d as o3d

vis = o3d.visualization.Visualizer()
vis.create_window()
pointcloud = o3d.geometry.PointCloud()
to_reset = True
vis.add_geometry(pointcloud)
for i in range(124):
    pcd = o3d.io.read_point_cloud(str(i).zfill(4)+'_cloud.pcd') 
    pcd = np.asarray(pcd.points).reshape((-1, 3))
    pointcloud.points = o3d.utility.Vector3dVector(pcd)  # 如果使用numpy数组可省略上两行
    vis.update_geometry()
    if to_reset:
        vis.reset_view_point(True)
        to_reset = False
    vis.poll_events()
    vis.update_renderer()

 

 

 

 

 

ply转为pcd & 可视化ply文件

import open3d as o3d
import numpy as np

ply = o3d.io.read_point_cloud('bun_zipper.ply') 
o3d.io.write_point_cloud("bun_zipper.pcd", ply)  # 将ply类型转换为pcd类型
o3d.visualization.draw_geometries([ply])  #可视化

 

 

### 回答1: 在 TURBO C 2.0 中,您可以使用 biosdisk() 函数来格式化软盘。 下面是一段代码示例: ``` #include <stdio.h> #include <dos.h> int main() { // 定义扇区的大小 unsigned int sector_size[3] = {512, 512, 1024}; // 定义填充字节 unsigned char fill_char[3] = {0xF6, 0xF6, 0x48}; // 格式化磁道 70 面 0 的前三个扇区 for (int i = 0; i < 3; i++) { int result = biosdisk(2, 0, 70, 0, i + 1, 1, sector_size[i], fill_char[i]); if (result != 0) { printf("格式化扇区 %d 失败,返回码: %d\n", i + 1, result); } } return 0; } ``` 请注意,在使用 biosdisk() 函数之前,需要包含 dos.h 头文件。 希望这能帮到您! ### 回答2: 使用TURBO C 2.0语言,可以通过以下代码格式化软盘的70磁道0面,并分别格式化3个扇区,大小分别为512字节、512字节和1024字节。其中,前两个扇区使用F6填充,第三个扇区使用48填充。 ```c #include<stdlib.h> #include<stdio.h> #include<dos.h> void formatFloppyDisk(){ union REGS regs; regs.h.ah = 0x0;// To format a floppy disk, we set AH=0 regs.h.dl = 0;// Drive number (0=A, 1=B, etc.) regs.x.cx = 0;// Track number to format regs.h.dh = 0;// Head number regs.h.al = 0;// Sector size (0=default, 1=512 bytes, 2=1024 bytes, 3=2048 bytes etc.) int FILL_BYTE = 0;// The byte value to fill the sectors with during formatting int NUM_SECTORS = 3;// Number of sectors to format // To format 70th track 0th head regs.x.ax = 0x1301; // 0x13 = Reset disk system, 01H = Reset only specified drive int86(0x13, &regs, &regs); // BIOS interrupt to reset disk system for (int i=0; i<NUM_SECTORS; i++){ regs.x.ax = 0x3101; // 0x31 = Write Format, 01H = Format only current track regs.x.bx = 0x0001; // 0x00 = Drive A:, 01H = Head 1, 0 = Generate ID Field depending on the disk in the drive 1 = Keep the ID Field all zeros regs.x.cx = 0x0170; // Track number=70(0-79 range) regs.h.dh = 0x00; // Head number=0 or 1 regs.h.al = 0x02; // Control byte=always zero regs.x.dx = i+1; // Sector number starting from 1 regs.x.si = 0x0000; // segment and offset of read/write buffer regs.x.di = 0x0000; // segment and offset of result if(i == 2){ FILL_BYTE = 0x48; // Fill the third sector with 48 regs.x.ax = 0x3102; // 0x31 = Write Format, 02H = Format sequential tracks immediately following the one being formatted }else{ FILL_BYTE = 0xF6; // Fill the first two sectors with F6 } regs.h.ah = FILL_BYTE; // Fill the sector with specified byte int86(0x13, &regs, &regs); // BIOS interrupt to format the specified sector } } int main(){ formatFloppyDisk(); return 0; } ``` 上述代码使用了INT 0x13,即BIOS中断服务例程,来执行软盘格式化操作。通过设置寄存器的不同参数,可以指定要格式化的磁道、面、扇区大小和填充字节。在这个例子中,我们格式化了软盘70磁道0面的3个扇区,前两个扇区使用F6填充,第三个扇区使用48填充。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值