UNPKG

@acransac/vtk.js

Version:

Visualization Toolkit for the Web

88 lines (76 loc) 2.65 kB
import 'vtk.js/Sources/favicon'; import vtkFullScreenRenderWindow from 'vtk.js/Sources/Rendering/Misc/FullScreenRenderWindow'; import vtkActor from 'vtk.js/Sources/Rendering/Core/Actor'; import vtkConeSource from 'vtk.js/Sources/Filters/Sources/ConeSource'; import vtkMapper from 'vtk.js/Sources/Rendering/Core/Mapper'; import vtkOrientationMarkerWidget from 'vtk.js/Sources/Interaction/Widgets/OrientationMarkerWidget'; import vtkAnnotatedCubeActor from 'vtk.js/Sources/Rendering/Core/AnnotatedCubeActor'; // ---------------------------------------------------------------------------- // Standard rendering code setup // ---------------------------------------------------------------------------- const fullScreenRenderer = vtkFullScreenRenderWindow.newInstance({ background: [0.2, 0.2, 0.2], }); const renderer = fullScreenRenderer.getRenderer(); const renderWindow = fullScreenRenderer.getRenderWindow(); // ---------------------------------------------------------------------------- // Example code // ---------------------------------------------------------------------------- // create cone const coneSource = vtkConeSource.newInstance(); const actor = vtkActor.newInstance(); const mapper = vtkMapper.newInstance(); actor.setMapper(mapper); mapper.setInputConnection(coneSource.getOutputPort()); renderer.addActor(actor); // create axes 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.setXPlusFaceProperty({ text: '+X' }); 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 }); // create orientation widget 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;