Skip to main content

React based declarative usage of vtk.js for Dash

Project description

Dash VTK

Dash VTK lets you integrate the vtk.js visualization pipeline directly into your Dash app. It is powered by react-vtk-js.

 A demo of dash-vtk in action

Getting started

Quickstart (Python)

First, install the library through pip:

pip install dash-vtk

Then, create a file called app.py and add the following example:

import dash
import dash_vtk
import dash_html_components as html

app = dash.Dash(__name__)

app.layout = html.Div(
    style={"width": "100%", "height": "calc(100vh - 16px)"},
    children=dash_vtk.View([
        dash_vtk.GeometryRepresentation([
            dash_vtk.Algorithm(
                vtkClass="vtkConeSource",
                state={"resolution": 64, "capping": False},
            )
        ]),
    ]),
)

if __name__ == "__main__":
    app.run_server(debug=True)

Now, simply run the app:

python app.py

For a more detailed example, see usage.py.

Quickstart (R)

First, install the package from GitHub (the package is not yet available via CRAN):

remotes::install_github("plotly/dash-vtk")

then, create your component and add it to your layout:

library(dash)
library(dashVtk)
library(dashHtmlComponents)

app <- Dash$new()

app$layout(htmlDiv(
    style = list("width" = "100%", "height" = "calc(100vh - 16px)"),
    children = vtkView(list(
        vtkGeometryRepresentation(
            vtkAlgorithm(
                vtkClass = "vtkConeSource",
                state = list("resolution" = 64, "capping" = FALSE),
            )
        )
    )
)

app$run_server()

Contributing

See docs/CONTRIBUTING.md to learn about:

  • Setting up the environment
  • Coding Style
  • Code quality & design
  • Tests
  • Publishing

Running the demos

First clone the project (replace <name> with the desired demo):

git clone https://github.com/plotly/dash-vtk.git
cd dash-vtk/demos/<name>/

Create a venv and install the requirements:

python -m venv venv
source venv/bin/activate  # for Windows, use venv\Scripts\activate.bat
pip install -e ../../  # IMPORTANT! If you skip you will get the pip version of dash-vtk
pip install -r requirements.txt

Run the demo:

python app.py

Python environments

Depending on your Python environment, you may run into deployment issue related to the vtk version that get pulled in.

Ideally we want a version of vtk equal or newer than 9. When using such version of VTK, dash-vtk won't even try to load the rendering module of VTK and if OpenGL is not available on your system everything will still be fine.

On the other hand, if you are running python-3.6 and/or pip-18 or less and you don't upgrade your pip version, you will only be able to use vtk<=8.1.2. With vtk 8, there is no way to prevent the loading of the GL library which means that you will have to install libGL on your system, or you will run into errors like this:

  File ".../python/lib/python3.6/site-packages/vtkmodules/all.py", line 29, in <module>
    from .vtkRenderingOpenGL2 import *
ImportError: libGL.so.1: cannot open shared object file: No such file or directory
[2021-02-08 18:36:15 +0000] [10] [INFO] Worker exiting (pid: 10)

or this:

  File ".../python3.7/site-packages/vtk/__init__.py", line 12, in <module>
    from .vtkOpenGLKit import *
  File ".../python3.7/site-packages/vtk/vtkOpenGLKit.py", line 9, in <module>
    from vtkOpenGLKitPython import *
ModuleNotFoundError: No module named 'vtkOpenGLKitPython'

Heroku and Dash Enterprise handle it is slightly different because you will have to install libgl1-mesa-glx via some apt files. In the case of Heroku, you will have to use a buildpack and add libgl1-mesa-glx to a Aptfile located in the root of your project. In the case of Dash Enterprise, you do not need to change the buildpack (it is handled automatically) but you will need to add libgl1-mesa-glx to a apt-packages file instead of Aptfile; see this app as an example.

References

You can find the complete API reference in docs/REFERENCES.md for each of the following components:

Demos

Usage for dash_vtk.Algorithm

  • Code
  • Online Demo (coming soon)

A demo of the usage-algorithm app

Point Cloud with PyVista

  • Code
  • Online Demo (coming soon)

A demo of the pyvista-point-cloud app

Terrain deformation using PyVista and dash-vtk

  • Code
  • Online Demo (coming soon)

A demo of the pyvista-terrain-following-mesh app

Volume Rendering

  • Code
  • Online Demo (coming soon)

A demo of the volume-rendering app

VTK for data processing and dash-vtk for rendering

  • Code
  • Online Demo (coming soon)

A demo of the usage-vtk-cfd app

Synthetic Volume Rendering

  • Code
  • Online Demo (coming soon)

A demo of the synthetic-volume-rendering 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

dash_vtk-0.0.4.tar.gz (957.4 kB view details)

Uploaded Source

Built Distribution

dash_vtk-0.0.4-py3-none-any.whl (978.6 kB view details)

Uploaded Python 3

File details

Details for the file dash_vtk-0.0.4.tar.gz.

File metadata

  • Download URL: dash_vtk-0.0.4.tar.gz
  • Upload date:
  • Size: 957.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.3

File hashes

Hashes for dash_vtk-0.0.4.tar.gz
Algorithm Hash digest
SHA256 da44b1bd166a44f2f6e68a8ac7f5cf77062f629bfdc014bb1dfcbbfb6821eb3c
MD5 25e33ee17618683e39596439adb9f98f
BLAKE2b-256 09811577bce4861f2f33c75fa93e40ee09d25b086eea5108cf952375d4ed3a82

See more details on using hashes here.

Provenance

File details

Details for the file dash_vtk-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: dash_vtk-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 978.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/46.4.0.post20200518 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.8.3

File hashes

Hashes for dash_vtk-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 1e93c73956508e7d5e0d07a76f0274fc4e99fc5fe6416bda471027ee4689b073
MD5 ed1d4f4dcd209a36addce2f15e4b6b23
BLAKE2b-256 4a5b1c0ed122cdfb46ca2e984e9e1ac881225c02608107bfdf52736998c86e21

See more details on using hashes here.

Provenance

Supported by

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