UNPKG

@acransac/vtk.js

Version:

Visualization Toolkit for the Web

94 lines (76 loc) 3.46 kB
import 'vtk.js/Sources/favicon'; import vtkFullScreenRenderWindow from 'vtk.js/Sources/Rendering/Misc/FullScreenRenderWindow'; import vtkHttpDataSetReader from 'vtk.js/Sources/IO/Core/HttpDataSetReader'; import vtkPiecewiseFunction from 'vtk.js/Sources/Common/DataModel/PiecewiseFunction'; import vtkColorTransferFunction from 'vtk.js/Sources/Rendering/Core/ColorTransferFunction'; import vtkVolume from 'vtk.js/Sources/Rendering/Core/Volume'; import vtkVolumeMapper from 'vtk.js/Sources/Rendering/Core/VolumeMapper'; import controlPanel from './controller.html'; // ---------------------------------------------------------------------------- // Standard rendering code setup // ---------------------------------------------------------------------------- const fullScreenRenderer = vtkFullScreenRenderWindow.newInstance({ background: [0.3, 0.3, 0.3], }); const renderer = fullScreenRenderer.getRenderer(); const renderWindow = fullScreenRenderer.getRenderWindow(); fullScreenRenderer.addController(controlPanel); // ---------------------------------------------------------------------------- // Example code // ---------------------------------------------------------------------------- // Server is not sending the .gz and with the compress header // Need to fetch the true file name and uncompress it locally // ---------------------------------------------------------------------------- const reader = vtkHttpDataSetReader.newInstance({ fetchGzip: true }); const actor = vtkVolume.newInstance(); const mapper = vtkVolumeMapper.newInstance(); mapper.setSampleDistance(1.3); actor.setMapper(mapper); // create color and opacity transfer functions const ofun = vtkPiecewiseFunction.newInstance(); ofun.addPoint(-3024, 0.1); ofun.addPoint(-637.62, 0.1); ofun.addPoint(700, 0.5); ofun.addPoint(3071, 0.9); const ctfun = vtkColorTransferFunction.newInstance(); ctfun.addRGBPoint(-3024, 0, 0, 0); ctfun.addRGBPoint(-637.62, 0, 0, 0); ctfun.addRGBPoint(700, 1, 1, 1); ctfun.addRGBPoint(3071, 1, 1, 1); actor.getProperty().setRGBTransferFunction(0, ctfun); actor.getProperty().setScalarOpacity(0, ofun); actor.getProperty().setScalarOpacityUnitDistance(0, 3.0); actor.getProperty().setInterpolationTypeToLinear(); actor.getProperty().setShade(true); actor.getProperty().setAmbient(0.1); actor.getProperty().setDiffuse(0.9); actor.getProperty().setSpecular(0.2); actor.getProperty().setSpecularPower(10.0); mapper.setInputConnection(reader.getOutputPort()); function updateBlendMode(event) { const blendMode = parseInt(event.target.value, 10); mapper.setBlendMode(blendMode); renderWindow.render(); } reader.setUrl(`${__BASE_PATH__}/data/volume/headsq.vti`).then(() => { reader.loadData().then(() => { renderer.addVolume(actor); const interactor = renderWindow.getInteractor(); interactor.setDesiredUpdateRate(15.0); renderer.resetCamera(); renderer.getActiveCamera().elevation(-70); renderWindow.render(); const el = document.querySelector('.blendMode'); el.addEventListener('change', updateBlendMode); }); }); // ----------------------------------------------------------- // Make some variables global so that you can inspect and // modify objects in your browser's developer console: // ----------------------------------------------------------- global.source = reader; global.mapper = mapper; global.actor = actor; global.ofun = ofun; global.renderer = renderer; global.renderWindow = renderWindow;