Inspired by the vpython manifesto “3D programming for ordinary mortals”, vtkplotter makes it easy to work wth three-dimensional objects, create displays and animations in just a few lines of code, even for those with less programming experience.
Because life is short.
Download and Install:¶
pip install -U vtkplotter
Check out the Git repository here: https://github.com/marcomusy/vtkplotter-examples
Windows-10 users can manually place this file vtkplotter.bat on the desktop to drag&drop files to visualize. (Need to edit the path of their local Anaconda installation).
Intuitive and straightforward API which can be combined with VTK seamlessly in a program, whilst mantaining access to the full range of VTK native classes.
It includes a large set of working examples for the all following functionalities:
Import meshes from VTK format, STL, Wavefront OBJ, 3DS, XML, Neutral, GMSH, PCD (PointCloud), volumetric TIFF stacks, SLC, MHD, 2D images PNG, JPEG.
Export meshes as ASCII or binary to VTK, STL, PLY formats with command vtkconvert.
Mesh analysis through the built-in methods of VTK package. Additional analysis tools like Moving Least Squares, mesh morphing.
Tools to visualize and edit meshes (cutting a mesh with another mesh, slicing, normalizing, moving vertex positions, etc..). Interactive cutter widget.
Split mesh based on surface connectivity. Extract the largest connected area.
Calculate mass properties, like area, volume, center of mass, average size etc.
Calculate vertex and face normals, curvatures, feature edges. Fill mesh holes.
Subdivide faces of a mesh, increasing the number of vertex points. Mesh simplification.
Coloring and thresholding of meshes based on associated scalar or vectorial data.
Point-surface operations: find nearest points, check if a point lies inside or outside a mesh.
Create primitive objects like: spheres, arrows, cubes, torus, ellipsoids…
Generate glyphs (associating a mesh to each vertex of a source mesh).
Create animations easily by just defining the position of the displayed objects in the 3D scene. Add trailing lines to moving objects automatically.
Straightforward support for multiple sync-ed or independent renderers in the same window.
Registration (alignment) of meshes with different techniques.
Mesh smoothing with Laplacian and WindowedSinc algorithms.
Delaunay triangulation in 2D and 3D.
Generate meshes by joining nearby lines in space.
Find the closest path from one point to another, travelling along the edges of a mesh.
Find the intersection of a mesh with a line (or with another mesh).
Analysis of Point Clouds:
Moving Least Squares smoothing of 2D, 3D and 4D clouds
Fit lines, planes and spheres in space
Perform PCA (Principal Component Analysis) on point coordinates
Identify outliers in a distribution of points
Decimate a cloud to a uniform distribution.
Basic histogramming and function plotting in 1D and 2D.
Interpolate scalar and vectorial fields with Radial Basis Functions and Thin Plate Splines.
Analysis of volumetric datasets:
Isosurfacing of volumes
Direct maximum projection rendering
Generate volumetric signed-distance data from an input surface mesh
Probe a volume with lines and planes.
Add sliders and buttons to interact with the scene and the individual objects.
Fully customizable axis style.
Examples with SHTools package for spherical harmonics expansion of a mesh shape.
Integration with the Qt5 framework.
Draw latex-formatted formulas on the rending window.
Export a 3D scene and embed it into a html page.
Support for FEniCS/dolfin package.
Visualization of tensors.
Embed the 3D rendering in a jupyter notebook with the K3D backend.
Export a 3D scene and embed it into a web page.
Interoperability with the trimesh library.
Hello World example¶
In your python script, load a simple
3DS file and display it:
from vtkplotter import show show('flamingo.3ds')
Allowed input objects to the
show() command are:
Visualize a mesh with:
vtkplotter mesh.obj # valid formats: [vtk,vtu,vts,vtp,vtm,ply,obj,stl,3ds,dolfin-xml,neutral,gmsh, # pcd,xyz,txt,byu,tif,off,slc,vti,mhd,dicom,dem,nrrd,bmp,png,jpg]
Voxel-data (mhd, vti, slc, tiff, dicom) files can also be visualized with options -g, e.g.:
vtkplotter -g examples/data/embryo.slc
To visualize multiple files or files time-sequences try -n or -s options. Use -h for the complete list of options.
Use a slider to control isosurfacing of a volume:
Load and browse a sequence of meshes:
vtkplotter -s examples/data/timecourse1d/*.vtk
Visualize colorized voxels:
vtkplotter --lego examples/data/embryo.tif
Run any of the available scripts from the vtkplotter-examples module with:
pip install -U git+https://github.com/marcomusy/vtkplotter-examples vtkplotter --list vtkplotter --run tube.py
More than 280 examples can be found in directories:
Apply a Moving Least Squares algorithm to obtain a smooth surface from a to a large cloud of scattered points in space (moving_least_squares2D.py):
Simulation of a gyroscope hanging from a spring (gyroscope1.py):
Quantum-tunnelling effect integrating the Schroedinger equation with 4th order Runge-Kutta method. The animation shows the evolution of a particle in a box hitting a sinusoidal potential barrier (tunnelling2.py):
Visualizing a Turing system of reaction-diffusion between two molecules (turing.py):
Mesh format conversion¶
vtkplotter-convert can be used to convert multiple files from a format to a different one:
Usage: vtkplotter-convert [-h] [-to] [files [files ...]] allowed targets formats: [vtk, vtp, vtu, vts, ply, stl, byu, xml] Example: > vtkplotter-convert myfile.vtk -to ply