.. DO NOT EDIT. .. THIS FILE WAS AUTOMATICALLY GENERATED BY SPHINX-GALLERY. .. TO MAKE CHANGES, EDIT THE SOURCE PYTHON FILE: .. "_gallery/other/load_open3d_pointcloud.py" .. LINE NUMBERS ARE GIVEN BELOW. .. only:: html .. note:: :class: sphx-glr-download-link-note :ref:`Go to the end ` to download the full example code. .. rst-class:: sphx-glr-example-title .. _sphx_glr__gallery_other_load_open3d_pointcloud.py: Load Open3D Pointcloud ====================== Demonstrates loading pointclouds from open3d. .. GENERATED FROM PYTHON SOURCE LINES 9-16 .. warning:: An external model is needed to run this example. To run this example, you need a model from the source repo's example folder. If you are running this example from a local copy of the code (dev install) no further actions are needed. Otherwise, you may have to replace the path below to point to the location of the model. .. GENERATED FROM PYTHON SOURCE LINES 16-31 .. code-block:: Python import os from pathlib import Path import numpy as np import pygfx as gfx try: # modify this line if your model is located elsewhere model_dir = Path(__file__).parents[1] / "data" except NameError: # compatibility with sphinx-gallery model_dir = Path(os.getcwd()).parent / "data" .. GENERATED FROM PYTHON SOURCE LINES 32-33 Once the path is set correctly, you can use the model as follows: .. GENERATED FROM PYTHON SOURCE LINES 33-82 .. code-block:: Python from importlib.util import find_spec if not find_spec("open3d"): raise ImportError( "The `open3d` library is required for this example: pip install open3d" ) import open3d as o3d def create_example_point_cloud() -> o3d.geometry.PointCloud: # read teapot and create pointcloud out of it teapot = o3d.io.read_triangle_mesh(str(model_dir / "teapot.stl")) pcd: o3d.geometry.PointCloud = teapot.sample_points_poisson_disk(2000) # give pointcloud colors # Assuming `point_cloud` is an open3d.geometry.PointCloud object points = np.asarray(pcd.points) # Normalize the points between 0 and 1 for RGB mapping min_bound = points.min(axis=0) max_bound = points.max(axis=0) normalized_points = (points - min_bound) / (max_bound - min_bound) # Assign normalized points as colors pcd.colors = o3d.utility.Vector3dVector(normalized_points) # o3d.visualization.draw_geometries([pcd]) return pcd open3d_point_cloud = create_example_point_cloud() # create pygfx scene scene = gfx.Scene() scene.add(gfx.AmbientLight(), gfx.DirectionalLight()) # create point cloud object geometry = gfx.geometries.geometry_from_open3d(open3d_point_cloud) material = gfx.PointsMaterial(size=2, color_mode="vertex") points = gfx.Points(geometry, material) scene.add(points) if __name__ == "__main__": disp = gfx.Display() disp.show(scene, up=(0, 1, 0)) .. _sphx_glr_download__gallery_other_load_open3d_pointcloud.py: .. only:: html .. container:: sphx-glr-footer sphx-glr-footer-example .. container:: sphx-glr-download sphx-glr-download-jupyter :download:`Download Jupyter notebook: load_open3d_pointcloud.ipynb ` .. container:: sphx-glr-download sphx-glr-download-python :download:`Download Python source code: load_open3d_pointcloud.py ` .. container:: sphx-glr-download sphx-glr-download-zip :download:`Download zipped: load_open3d_pointcloud.zip ` .. only:: html .. rst-class:: sphx-glr-signature `Gallery generated by Sphinx-Gallery `_ .. only:: html Interactive example ------------------- Try this example in your browser using Pyodide. Might not work with all examples and all devices. Check the output and your browser's console for details. .. raw:: html