1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
"""How to use PyVista's ``PyVistaLocalView`` trame view component.
This is a full-fledged example on building your own user interface
with client-side rendering.
"""
from __future__ import annotations
from trame.app import get_server
from trame.ui.vuetify3 import SinglePageLayout
from trame.widgets import vuetify3
import pyvista as pv
from pyvista import examples
from pyvista.trame import PyVistaLocalView
server = get_server(client_type='vue3')
state, ctrl = server.state, server.controller
state.trame__title = 'PyVistaLocalView'
# -----------------------------------------------------------------------------
mesh = examples.load_random_hills()
plotter = pv.Plotter(off_screen=True)
actor = plotter.add_mesh(mesh)
plotter.set_background('lightgrey')
# -----------------------------------------------------------------------------
# GUI
# -----------------------------------------------------------------------------
with SinglePageLayout(server) as layout:
layout.icon.click = ctrl.view_reset_camera
layout.title.set_text('PyVistaLocalView')
with layout.toolbar:
vuetify3.VSpacer()
with layout.content:
with vuetify3.VContainer(
fluid=True,
classes='pa-0 fill-height',
):
view = PyVistaLocalView(plotter)
ctrl.view_update = view.update
ctrl.view_reset_camera = view.reset_camera
# hide footer
layout.footer.hide()
# -----------------------------------------------------------------------------
# Main
# -----------------------------------------------------------------------------
if __name__ == '__main__':
server.start()
|