import macro from 'vtk.js/Sources/macros'; import vtkAbstractWidgetFactory from 'vtk.js/Sources/Widgets/Core/AbstractWidgetFactory'; import vtkPlanePointManipulator from 'vtk.js/Sources/Widgets/Manipulators/PlaneManipulator'; import vtkPolyLineRepresentation from 'vtk.js/Sources/Widgets/Representations/PolyLineRepresentation'; import vtkSphereHandleRepresentation from 'vtk.js/Sources/Widgets/Representations/SphereHandleRepresentation'; import * as vtkMath from 'vtk.js/Sources/Common/Core/Math';
import widgetBehavior from 'vtk.js/Sources/Widgets/Widgets3D/AngleWidget/behavior'; import stateGenerator from 'vtk.js/Sources/Widgets/Widgets3D/AngleWidget/state';
import { ViewTypes } from 'vtk.js/Sources/Widgets/Core/WidgetManager/Constants';
function vtkAngleWidget(publicAPI, model) { model.classHierarchy.push('vtkAngleWidget');
model.methodsToLink = [ 'activeScaleFactor', 'activeColor', 'useActiveColor', 'glyphResolution', 'defaultScale', 'scaleInPixels', ];
model._onManipulatorChanged = () => { model.widgetState.getMoveHandle().setManipulator(model.manipulator); model.widgetState.getHandleList().forEach((handle) => { handle.setManipulator(model.manipulator); }); };
publicAPI.getRepresentationsForViewType = (viewType) => { switch (viewType) { case ViewTypes.DEFAULT: case ViewTypes.GEOMETRY: case ViewTypes.SLICE: case ViewTypes.VOLUME: default: return [ { builder: vtkSphereHandleRepresentation, labels: ['handles', 'moveHandle'], }, { builder: vtkPolyLineRepresentation, labels: ['handles', 'moveHandle'], }, ]; } };
publicAPI.getAngle = () => { const handles = model.widgetState.getHandleList(); if (handles.length !== 3) { return 0; } if ( !handles[0].getOrigin() || !handles[1].getOrigin() || !handles[2].getOrigin() ) { return 0; } const vec1 = [0, 0, 0]; const vec2 = [0, 0, 0]; vtkMath.subtract(handles[0].getOrigin(), handles[1].getOrigin(), vec1); vtkMath.subtract(handles[2].getOrigin(), handles[1].getOrigin(), vec2); return vtkMath.angleBetweenVectors(vec1, vec2); };
model.widgetState.onBoundsChange((bounds) => { const center = [ (bounds[0] + bounds[1]) * 0.5, (bounds[2] + bounds[3]) * 0.5, (bounds[4] + bounds[5]) * 0.5, ]; model.widgetState.getMoveHandle().setOrigin(center); });
publicAPI.setManipulator( model.manipulator || vtkPlanePointManipulator.newInstance({ useCameraNormal: true }) ); }
const defaultValues = (initialValues) => ({ behavior: widgetBehavior, widgetState: stateGenerator(), ...initialValues, });
export function extend(publicAPI, model, initialValues = {}) { Object.assign(model, defaultValues(initialValues));
vtkAbstractWidgetFactory.extend(publicAPI, model, initialValues); macro.setGet(publicAPI, model, ['manipulator']);
vtkAngleWidget(publicAPI, model); }
export const newInstance = macro.newInstance(extend, 'vtkAngleWidget');
export default { newInstance, extend };
|