UNPKG

@acransac/vtk.js

Version:

Visualization Toolkit for the Web

65 lines (46 loc) 2.17 kB
import 'vtk.js/Sources/favicon'; import vtkActor from 'vtk.js/Sources/Rendering/Core/Actor'; import vtkCubeSource from 'vtk.js/Sources/Filters/Sources/CubeSource'; import vtkFullScreenRenderWindow from 'vtk.js/Sources/Rendering/Misc/FullScreenRenderWindow'; import vtkMapper from 'vtk.js/Sources/Rendering/Core/Mapper'; import vtkAngleWidget from 'vtk.js/Sources/Widgets/Widgets3D/AngleWidget'; import vtkWidgetManager from 'vtk.js/Sources/Widgets/Core/WidgetManager'; import controlPanel from './controlPanel.html'; // ---------------------------------------------------------------------------- // Standard rendering code setup // ---------------------------------------------------------------------------- const fullScreenRenderer = vtkFullScreenRenderWindow.newInstance({ background: [0, 0, 0], }); const renderer = fullScreenRenderer.getRenderer(); const cone = vtkCubeSource.newInstance(); const mapper = vtkMapper.newInstance(); const actor = vtkActor.newInstance(); actor.setMapper(mapper); mapper.setInputConnection(cone.getOutputPort()); actor.getProperty().setOpacity(0.5); renderer.addActor(actor); // ---------------------------------------------------------------------------- // Widget manager // ---------------------------------------------------------------------------- const widgetManager = vtkWidgetManager.newInstance(); widgetManager.setRenderer(renderer); const widget = vtkAngleWidget.newInstance(); widget.placeWidget(cone.getOutputData().getBounds()); widgetManager.addWidget(widget); renderer.resetCamera(); widgetManager.enablePicking(); // ----------------------------------------------------------- // UI control handling // ----------------------------------------------------------- fullScreenRenderer.addController(controlPanel); widget.getWidgetState().onModified(() => { document.querySelector('#angle').innerText = widget.getAngle(); }); document.querySelector('button').addEventListener('click', () => { widgetManager.grabFocus(widget); }); // ----------------------------------------------------------- // globals // ----------------------------------------------------------- global.widget = widget;