Skip to main content

Macro components for ParaView

Project description

ParaView Trame Components

This project gather helper classes that can be used with ParaView to create quickly and simply web solution for interacting with your data.

Usage example

The ./examples/ directory gather simple Python scripts using ParaView and exposing them as standalone trame applications.

Virtual Environment setup

Since ParaView does not come with trame, you need to create a virtual environment that brings all the missing dependency for paraview to use.

# Create and activate venv
python3.10 -m venv .venv
source .venv/bin/activate

# Install published package
pip install paraview-trame-components

# Let ParaView know about the location of that venv
export PV_VENV=$PWD/.venv

Running examples

# Adjust path to point to your ParaView executable
export PVPYTHON=/Applications/ParaView-5.12.0.app/Contents/bin/pvpython

# Run the scripts
$PVPYTHON --force-offscreen-rendering ./examples/cone.py
$PVPYTHON --force-offscreen-rendering ./examples/cone-with-slider.py
$PVPYTHON --force-offscreen-rendering ./examples/wavelet-contour-state.py
$PVPYTHON --force-offscreen-rendering ./examples/pipeline.py
$PVPYTHON --force-offscreen-rendering ./examples/selection.py

Scripts structure

Each script add import paraview.web.venv at the top to enable your virtual environment via the PV_VENV environment variable.

Then we use the ptc (ParaView Trame Components) package to quickly create a trame application to view the data.

The wavelet-contour-state.py script was created by ParaView when saving its state as a Python file. Then we added few lines at the end to create an interactive web viewer.

Check code

# one time
pip install ".[dev]"
pre-commit install

# check but automatic on commit
pre-commit run --all-files

ParaView code example

import paraview.web.venv
from ptc import Viewer
from paraview import simple

cone = simple.Cone()
simple.Show()
simple.Render()

# Make it a web app
web_app = Viewer()
web_app.start()

And if you want to add some UI

import paraview.web.venv
from paraview import simple

from ptc import Viewer
from trame.widgets.vuetify3 import VSlider

cone = simple.Cone()
simple.Show()
simple.Render()

# Make it a web app
web_app = Viewer()

with web_app.side_top:
    VSlider(
        v_model=("resolution", 6),
        min=3, max=60, step=1,
    )

@web_app.state.change("resolution")
def on_resolution_change(resolution, **kwargs):
    cone.Resolution = resolution
    web_app.update()

web_app.start()

Example in image

Code Web App
Write some python code And get a web app

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

paraview_trame_components-0.14.1.tar.gz (29.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

paraview_trame_components-0.14.1-py3-none-any.whl (36.8 kB view details)

Uploaded Python 3

File details

Details for the file paraview_trame_components-0.14.1.tar.gz.

File metadata

File hashes

Hashes for paraview_trame_components-0.14.1.tar.gz
Algorithm Hash digest
SHA256 55bccfc58be6c8fcb3a2b6556cc8451fc2b1ff756a7da1b2f1f8474c499ab0ef
MD5 c21a514636d1d8d16ecc97f9686c8cc1
BLAKE2b-256 9d081ed65e1d4b11a8c68e64c9f2d4f53e9dad33af644a00677d46790c21f715

See more details on using hashes here.

File details

Details for the file paraview_trame_components-0.14.1-py3-none-any.whl.

File metadata

File hashes

Hashes for paraview_trame_components-0.14.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7e8ca0bb235f4cb7bd8786ebda32100334525df7444631971d0dd561c45ffaf8
MD5 2c9132c0293eeac488e1241a9084da3b
BLAKE2b-256 bc391fc8596ad08239193d05afe58b1e17612cba06ca89d9b6dab54aee194b33

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page