import '@kitware/vtk.js/favicon';
import '@kitware/vtk.js/Rendering/Profiles/Geometry'; import '@kitware/vtk.js/Rendering/Profiles/Glyph';
import vtkActor from '@kitware/vtk.js/Rendering/Core/Actor'; import vtkConeSource from '@kitware/vtk.js/Filters/Sources/ConeSource'; import vtkFullScreenRenderWindow from '@kitware/vtk.js/Rendering/Misc/FullScreenRenderWindow'; import vtkMapper from '@kitware/vtk.js/Rendering/Core/Mapper'; import vtkPolyLineWidget from '@kitware/vtk.js/Widgets/Widgets3D/PolyLineWidget'; import vtkWidgetManager from '@kitware/vtk.js/Widgets/Core/WidgetManager'; import vtkInteractorObserver from '@kitware/vtk.js/Rendering/Core/InteractorObserver';
import { bindSVGRepresentation } from 'vtk.js/Examples/Widgets/Utilities/SVGHelpers'; import controlPanel from './controlPanel.html';
const { computeWorldToDisplay } = vtkInteractorObserver;
const fullScreenRenderer = vtkFullScreenRenderWindow.newInstance({ background: [0, 0, 0], }); const renderer = fullScreenRenderer.getRenderer();
const cone = vtkConeSource.newInstance(); const mapper = vtkMapper.newInstance(); const actor = vtkActor.newInstance();
actor.setMapper(mapper); mapper.setInputConnection(cone.getOutputPort()); actor.getProperty().setOpacity(0.5);
renderer.addActor(actor);
const widgetManager = vtkWidgetManager.newInstance(); widgetManager.setRenderer(renderer);
const widget = vtkPolyLineWidget.newInstance(); widget.placeWidget(cone.getOutputData().getBounds());
widgetManager.addWidget(widget);
renderer.resetCamera(); widgetManager.enablePicking(); widgetManager.grabFocus(widget);
bindSVGRepresentation(renderer, widget.getWidgetState(), { mapState(widgetState, { size }) { const states = widgetState.getStatesWithLabel('handles') || []; return states .filter((state) => state.getVisible() && state.getOrigin()) .map((state) => { const coords = computeWorldToDisplay(renderer, ...state.getOrigin()); return [coords[0], size[1] - coords[1]]; }); }, render(data, h) { return data.map(([x, y], index) => h( 'text', { key: index, attrs: { x, y, dx: 12, dy: -12, fill: 'white', 'font-size': 32, }, }, `L${index}` ) ); }, });
fullScreenRenderer.addController(controlPanel);
document.querySelector('button').addEventListener('click', () => { widgetManager.grabFocus(widget); });
document .querySelector('input[type=checkbox]') .addEventListener('change', (ev) => { widgetManager.setUseSvgLayer(ev.target.checked); });
|