import '@kitware/vtk.js/favicon';
import '@kitware/vtk.js/Rendering/Profiles/Geometry';
import vtkFullScreenRenderWindow from '@kitware/vtk.js/Rendering/Misc/FullScreenRenderWindow'; import vtkOrientationMarkerWidget from '@kitware/vtk.js/Interaction/Widgets/OrientationMarkerWidget'; import vtkAnnotatedCubeActor from '@kitware/vtk.js/Rendering/Core/AnnotatedCubeActor';
import vtkActor from '@kitware/vtk.js/Rendering/Core/Actor'; import vtkConeSource from '@kitware/vtk.js/Filters/Sources/ConeSource'; import vtkMapper from '@kitware/vtk.js/Rendering/Core/Mapper';
import vtkImageStream from '@kitware/vtk.js/IO/Core/ImageStream'; import SmartConnect from 'wslink/src/SmartConnect';
const fullScreenRenderer = vtkFullScreenRenderWindow.newInstance(); const renderer = fullScreenRenderer.getRenderer(); const renderWindow = fullScreenRenderer.getRenderWindow();
const imageStream = vtkImageStream.newInstance(); const config = { sessionURL: 'ws://localhost:1234/ws' }; const smartConnect = SmartConnect.newInstance({ config }); smartConnect.onConnectionReady((connection) => { const session = connection.getSession();
imageStream.connect(session); const viewStream = imageStream.createViewStream('-1'); fullScreenRenderer.getApiSpecificRenderWindow().setViewStream(viewStream);
viewStream.setInteractiveQuality(75); viewStream.setInteractiveRatio(0.5); viewStream.setCamera(renderer.getActiveCamera()); viewStream.pushCamera();
renderWindow.getInteractor().onStartAnimation(viewStream.startInteraction); renderWindow.getInteractor().onEndAnimation(viewStream.endInteraction); });
smartConnect.onConnectionError(console.error); smartConnect.onConnectionClose(console.error); smartConnect.connect();
const coneSource = vtkConeSource.newInstance(); const actor = vtkActor.newInstance(); const mapper = vtkMapper.newInstance();
actor.setMapper(mapper); mapper.setInputConnection(coneSource.getOutputPort());
actor.getProperty().setRepresentation(1); actor.getProperty().setColor(0, 0, 0); actor.getProperty().setInterpolationToFlat();
renderer.addActor(actor);
const axes = vtkAnnotatedCubeActor.newInstance(); axes.setDefaultStyle({ text: '+X', fontStyle: 'bold', fontFamily: 'Arial', fontColor: 'black', fontSizeScale: (res) => res / 2, faceColor: '#0000ff', faceRotation: 0, edgeThickness: 0.1, edgeColor: 'black', resolution: 400, });
axes.setXMinusFaceProperty({ text: '-X', faceColor: '#ffff00', faceRotation: 90, fontStyle: 'italic', }); axes.setYPlusFaceProperty({ text: '+Y', faceColor: '#00ff00', fontSizeScale: (res) => res / 4, }); axes.setYMinusFaceProperty({ text: '-Y', faceColor: '#00ffff', fontColor: 'white', }); axes.setZPlusFaceProperty({ text: '+Z', edgeColor: 'yellow', }); axes.setZMinusFaceProperty({ text: '-Z', faceRotation: 45, edgeThickness: 0 });
const orientationWidget = vtkOrientationMarkerWidget.newInstance({ actor: axes, interactor: renderWindow.getInteractor(), }); orientationWidget.setEnabled(true); orientationWidget.setViewportCorner( vtkOrientationMarkerWidget.Corners.BOTTOM_RIGHT ); orientationWidget.setViewportSize(0.15); orientationWidget.setMinPixelSize(100); orientationWidget.setMaxPixelSize(300);
renderer.resetCamera(); renderWindow.render();
global.renderWindow = renderWindow;
|