Note
Go to the end to download the full example code
Silhouette Highlight#
Extract a subset of the edges of a polygonal mesh to generate an outline (silhouette) of a mesh.
import pyvista
from pyvista import examples
Prepare a triangulated PolyData
bunny = examples.download_bunny()
Now we can display the silhouette of the mesh and compare the result:
plotter = pyvista.Plotter(shape=(1, 2))
plotter.subplot(0, 0)
plotter.add_mesh(bunny, color='lightblue', silhouette=True)
plotter.add_text("Silhouette")
plotter.view_xy()
plotter.subplot(0, 1)
plotter.add_mesh(bunny, color='lightblue')
plotter.add_text("No silhouette")
plotter.view_xy()
plotter.show()
Maybe the default parameters are not enough to really notice the silhouette.
But by using a dict
, it is possible to modify the properties of the
outline. For example, color and width could be specified like so:
plotter = pyvista.Plotter()
silhouette = dict(
color='red',
line_width=8.0,
)
plotter.add_mesh(bunny, silhouette=silhouette)
plotter.view_xy()
plotter.show()
By default, PyVista uses a pretty aggressive decimation level but we might want to disable it. It is also possible to display sharp edges:
cylinder = pyvista.Cylinder(
center=(0, 0.04, 0), direction=(0, 1, 0), radius=0.15, height=0.03
).triangulate()
plotter = pyvista.Plotter(shape=(1, 3))
plotter.subplot(0, 0)
plotter.add_mesh(
cylinder,
color='lightblue',
smooth_shading=True,
silhouette=dict(color='red', line_width=8.0, decimate=None, feature_angle=True),
)
plotter.add_text("Silhouette with sharp edges")
plotter.view_isometric()
plotter.subplot(0, 1)
plotter.add_mesh(
cylinder,
color='lightblue',
smooth_shading=True,
silhouette=dict(color='red', line_width=8.0, decimate=None),
)
plotter.add_text("Silhouette without sharp edges")
plotter.view_isometric()
plotter.subplot(0, 2)
plotter.add_mesh(cylinder, color='lightblue', smooth_shading=True)
plotter.add_text("No silhouette")
plotter.view_isometric()
plotter.show()
Here is another example:
dragon = examples.download_dragon()
plotter = pyvista.Plotter()
plotter.set_background('black', 'blue')
plotter.add_mesh(
dragon,
color="green",
specular=1,
smooth_shading=True,
silhouette=dict(line_width=8, color='white'),
)
plotter.add_mesh(
cylinder,
color='lightblue',
smooth_shading=True,
silhouette=dict(decimate=None, feature_angle=True, line_width=8, color='white'),
)
plotter.camera_position = [
(-0.2936731887752889, 0.2389060430625446, 0.35138839367034236),
(-0.005878899246454239, 0.12495124898850918, -0.004603400826454163),
(0.34348225747312017, 0.8567703221182346, -0.38466160965007384),
]
plotter.show()
Total running time of the script: (0 minutes 10.324 seconds)