UNPKG

@kitware/vtk.js

Version:

Visualization Toolkit for the Web

102 lines (89 loc) 3.95 kB
import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray'; import macro from '../../macros.js'; import vtkMatrixBuilder from '../../Common/Core/MatrixBuilder.js'; import vtkPolyData from '../../Common/DataModel/PolyData.js'; function vtkViewFinderSource(publicAPI, model) { publicAPI.requestData = function (inData, outData) { var _vtkMatrixBuilder$bui; var dataset = vtkPolyData.newInstance(); var points = macro.newTypedArray(model.pointType, 3 * 16); points[0] = model.radius; points[1] = model.radius / model.width; points[2] = 0; points[3] = model.radius + model.spacing; points[4] = model.radius / model.width; points[5] = 0; points[6] = model.radius; points[7] = model.radius / model.width * -1; points[8] = 0; points[9] = model.radius + model.spacing; points[10] = model.radius / model.width * -1; points[11] = 0; points[12] = model.radius * -1; points[13] = model.radius / model.width; points[14] = 0; points[15] = (model.radius + model.spacing) * -1; points[16] = model.radius / model.width; points[17] = 0; points[18] = model.radius * -1; points[19] = model.radius / model.width * -1; points[20] = 0; points[21] = (model.radius + model.spacing) * -1; points[22] = model.radius / model.width * -1; points[23] = 0; points[24] = model.radius / model.width; points[25] = model.radius; points[26] = 0; points[27] = model.radius / model.width; points[28] = model.radius + model.spacing; points[29] = 0; points[30] = model.radius / model.width * -1; points[31] = model.radius; points[32] = 0; points[33] = model.radius / model.width * -1; points[34] = model.radius + model.spacing; points[35] = 0; points[36] = model.radius / model.width; points[37] = model.radius * -1; points[38] = 0; points[39] = model.radius / model.width; points[40] = (model.radius + model.spacing) * -1; points[41] = 0; points[42] = model.radius / model.width * -1; points[43] = model.radius * -1; points[44] = 0; points[45] = model.radius / model.width * -1; points[46] = (model.radius + model.spacing) * -1; points[47] = 0; // prettier-ignore var cells = Uint8Array.from([3, 0, 1, 2, 3, 2, 1, 3, 3, 4, 6, 5, 3, 6, 5, 7, 3, 8, 11, 9, 3, 8, 10, 11, 3, 12, 13, 15, 3, 12, 15, 14]); (_vtkMatrixBuilder$bui = vtkMatrixBuilder.buildFromRadian()).translate.apply(_vtkMatrixBuilder$bui, _toConsumableArray(model.center)).rotateFromDirections([1, 0, 0], model.orientation).apply(points); dataset.getPoints().setData(points, 3); dataset.getPolys().setData(cells, 1); outData[0] = dataset; }; } // ---------------------------------------------------------------------------- // Object factory // ---------------------------------------------------------------------------- var DEFAULT_VALUES = { radius: 1, spacing: 2, width: 4, pointType: 'Float64Array' }; // ---------------------------------------------------------------------------- function extend(publicAPI, model) { var initialValues = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; model.center = [0, 0, 0]; model.orientation = [1, 0, 0]; Object.assign(model, DEFAULT_VALUES, initialValues); // Build VTK API macro.obj(publicAPI, model); macro.setGet(publicAPI, model, ['radius', 'spacing', 'width']); macro.setGetArray(publicAPI, model, ['center', 'orientation'], 3); macro.algo(publicAPI, model, 0, 1); vtkViewFinderSource(publicAPI, model); } // ---------------------------------------------------------------------------- var newInstance = macro.newInstance(extend, 'vtkArrow2DSource'); // ---------------------------------------------------------------------------- var vtkViewFinderSource$1 = { newInstance: newInstance, extend: extend }; export { vtkViewFinderSource$1 as default, extend, newInstance };