import '@kitware/vtk.js/favicon';
import '@kitware/vtk.js/Rendering/Profiles/Geometry';
import vtkFullScreenRenderWindow from '@kitware/vtk.js/Rendering/Misc/FullScreenRenderWindow'; import vtkActor from '@kitware/vtk.js/Rendering/Core/Actor'; import vtkDiskSource from '@kitware/vtk.js/Filters/Sources/DiskSource'; import vtkMapper from '@kitware/vtk.js/Rendering/Core/Mapper';
import controlPanel from './controlPanel.html';
const fullScreenRenderer = vtkFullScreenRenderWindow.newInstance(); const renderer = fullScreenRenderer.getRenderer(); const renderWindow = fullScreenRenderer.getRenderWindow();
const diskSource = vtkDiskSource.newInstance(); const actor = vtkActor.newInstance(); const mapper = vtkMapper.newInstance();
actor.setMapper(mapper); actor.getProperty().setColor(1, 0, 0); mapper.setInputConnection(diskSource.getOutputPort());
renderer.addActor(actor);
renderer.resetCamera(); renderWindow.render();
fullScreenRenderer.addController(controlPanel);
[ 'innerRadius', 'outerRadius', 'radialResolution', 'circumferentialResolution', ].forEach((propertyName) => { document.querySelector(`.${propertyName}`).addEventListener('input', (e) => { const value = Number(e.target.value); diskSource.set({ [propertyName]: value }); renderWindow.render(); }); });
|