import '@kitware/vtk.js/favicon';
import '@kitware/vtk.js/Rendering/Profiles/Volume';
import vtkFullScreenRenderWindow from '@kitware/vtk.js/Rendering/Misc/FullScreenRenderWindow'; import vtkVolume from '@kitware/vtk.js/Rendering/Core/Volume'; import vtkVolumeMapper from '@kitware/vtk.js/Rendering/Core/VolumeMapper'; import vtkPiecewiseFunction from '@kitware/vtk.js/Common/DataModel/PiecewiseFunction'; import vtkColorTransferFunction from '@kitware/vtk.js/Rendering/Core/ColorTransferFunction';
import vtkHttpDataSetReader from '@kitware/vtk.js/IO/Core/HttpDataSetReader'; import vtkXMLImageDataReader from '@kitware/vtk.js/IO/XML/XMLImageDataReader'; import vtkXMLImageDataWriter from '@kitware/vtk.js/IO/XML/XMLImageDataWriter'; import vtkXMLWriter from '@kitware/vtk.js/IO/XML/XMLWriter';
import '@kitware/vtk.js/IO/Core/DataAccessHelper/HttpDataAccessHelper';
const fullScreenRenderer = vtkFullScreenRenderWindow.newInstance(); const renderer = fullScreenRenderer.getRenderer(); const renderWindow = fullScreenRenderer.getRenderWindow();
const reader = vtkHttpDataSetReader.newInstance({ fetchGzip: true });
const writer = vtkXMLImageDataWriter.newInstance(); writer.setFormat(vtkXMLWriter.FormatTypes.BINARY); writer.setInputConnection(reader.getOutputPort());
const writerReader = vtkXMLImageDataReader.newInstance();
reader .setUrl(`${__BASE_PATH__}/data/volume/headsq.vti`, { loadData: true }) .then(() => { const fileContents = writer.write(reader.getOutputData());
const textEncoder = new TextEncoder(); writerReader.parseAsArrayBuffer(textEncoder.encode(fileContents)); renderer.resetCamera(); renderWindow.render();
const blob = new Blob([fileContents], { type: 'text/plain' }); const a = window.document.createElement('a'); a.href = window.URL.createObjectURL(blob, { type: 'text/plain' }); a.download = 'headsq.vti'; a.text = 'Download'; a.style.position = 'absolute'; a.style.left = '50%'; a.style.bottom = '10px'; document.body.appendChild(a); a.style.background = 'white'; a.style.padding = '5px'; });
const actor = vtkVolume.newInstance(); const mapper = vtkVolumeMapper.newInstance(); mapper.setSampleDistance(1.1); actor.setMapper(mapper);
mapper.setInputConnection(writerReader.getOutputPort());
const ctfun = vtkColorTransferFunction.newInstance(); ctfun.addRGBPoint(200.0, 1.0, 1.0, 1.0); ctfun.addRGBPoint(2000.0, 0.0, 0.0, 0.0); const ofun = vtkPiecewiseFunction.newInstance(); ofun.addPoint(200.0, 0.0); ofun.addPoint(1200.0, 0.2); ofun.addPoint(4000.0, 0.4); actor.getProperty().setRGBTransferFunction(0, ctfun); actor.getProperty().setScalarOpacity(0, ofun); actor.getProperty().setScalarOpacityUnitDistance(0, 4.5);
actor.getProperty().setInterpolationTypeToLinear();
renderer.addActor(actor);
global.writer = writer; global.writerReader = writerReader; global.mapper = mapper; global.actor = actor; global.renderer = renderer; global.renderWindow = renderWindow;
|