Preferences

Tab Name

Tab Name Panel

  • Tab Name - if Point Cloud Visualizer is too long for your tabs, you can change to shorter PCV.
  • Custom Tab Name - if set to existing tan name, PCV panel is moved there.

GPU Memory To Max. Points Calculator

Calculator Panel

Calculate theoretical maximum of displayable points for given gpu memory, floored to nearest tens of millions. Result is valid only when Default shader is used and nothing else displayed, i.e. location and color per point only. See Large Datasets for more info.

Libraries

  • Check Environment - Helper operator that checks for legacy PCV libraries that must be uninstalled
  • Resolve Library Conflicts Using Python Subprocess - If library conflict is detected, execute operation in separate python subprocess, operation will take more time because input/output data will be written/read to/from disk in temporary directory bpy.app.tempdir

Defaults when using "PCV > Load" operator

Load Operator Panel

Default options for load operator: 3d Viewport sidebar > PCV tab and click Choose File .

Defaults when using "Add > Point Cloud Visualizer" helper operator

Add Operator Panel

Default options for helper operator (adds empty object to scene and loads points for each selected file): 3D Viewport > Add > Point Cloud Visualizer Shift+A

Fast Navigation

Fast Navigation Panel

Draw low resolution point cloud during viewport navigation. See Fast Navigation for more info.

  • Delay - Delay drawing of high resolution point cloud to viewport after navigation ended
  • Percentage - Low resolution point cloud percentage, used until point count exceeds Maximum
  • Maximum (Millions) - Low resolution point cloud maximum number of points, used when point count exceeds Percentage
  • Auto Exclude (Millions) - Skip Fast Navigation if instance point count is lower, set to zero to disable and use on all instances, will not apply on points if low resolution is already generated in current session, reload files to update

UI

UI Panel

Tools

Tools Panel

  • Show Help Panel At Tool Start - Disable to hide help panel for each tool.
  • Show Tools Color Theme - Edit color theme of Tools to fit your Blender theme.

Packer

Packer Panel

Store loaded points as hidden mesh datablock with attributes in blend file. Automatically restore and draw points from datablock at blend file load, save points to datablock on blend file save.

This operation is meant to be fully automatic (if Auto Pack and Auto Optimize options in preferences are enabled, they are by default) once loaded point data are marked for packing clicking Pack icon next to file path on main PCV panel (this will work for any file formats, even those loaded using Import panel).

If Packer is enabled, main operators (Draw, Erase, Reload etc.) will prioritize packed data (if available) over loading from ply file.

Packer adds utility operators to 3D Viewport Panel as well as list of packed datablocks in blend file. See Packer for more info.

  • Auto Pack: pack all points that are loaded and/or displayed when blend file is being saved
  • Auto Optimize: remove packed datablocks on blend file save if container object is not found in scene

Utilities

Utilities Panel

  • Reset PCV On Active Object - Reset all PCV properties stored on active object
  • Reset PCV Preferences - Reset all PCV Preferences

Experimental > Patch 'pye57' library

Patch pye57 reader class at runtime to read files with scans without translation and rotation elements in its header.

Helps when reading e57 file ends in error E57 element path well formed but not defined (E57_ERROR_PATH_UNDEFINED) and in console with lines similar to this:

  File "/Users/redacted/.local/lib/python3.10/site-packages/pye57/e57.py", line 214, in read_scan
    xyz = self.to_global(xyz, header.rotation, header.translation)
  File "/Users/redacted/.local/lib/python3.10/site-packages/pye57/scan_header.py", line 32, in rotation
    q = Quaternion([e.value() for e in self.node["pose"]["rotation"]])
pye57.libe57.E57Exception: E57 element path well formed but not defined (E57_ERROR_PATH_UNDEFINED)