@kitware/vtk.js
Version:
Visualization Toolkit for the Web
149 lines (116 loc) • 5.38 kB
JavaScript
import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray';
import _defineProperty from '@babel/runtime/helpers/defineProperty';
import macro from '../../macros.js';
import vtkDataArray from './DataArray.js';
import { VtkDataTypes } from './DataArray/Constants.js';
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
// Global methods
// ----------------------------------------------------------------------------
function extractCellSizes(cellArray) {
var currentIdx = 0;
return cellArray.filter(function (value, index) {
if (index === currentIdx) {
currentIdx += value + 1;
return true;
}
return false;
});
}
function getNumberOfCells(cellArray) {
var cellId = 0;
for (var cellArrayIndex = 0; cellArrayIndex < cellArray.length;) {
cellArrayIndex += cellArray[cellArrayIndex] + 1;
cellId++;
}
return cellId;
} // ----------------------------------------------------------------------------
// Static API
// ----------------------------------------------------------------------------
var STATIC = {
extractCellSizes: extractCellSizes,
getNumberOfCells: getNumberOfCells
}; // ----------------------------------------------------------------------------
// vtkCellArray methods
// ----------------------------------------------------------------------------
function vtkCellArray(publicAPI, model) {
// Set our className
model.classHierarchy.push('vtkCellArray');
var superClass = _objectSpread({}, publicAPI);
publicAPI.getNumberOfCells = function (recompute) {
if (model.numberOfCells !== undefined && !recompute) {
return model.numberOfCells;
}
if (model.cellSizes) {
model.numberOfCells = model.cellSizes.length;
} else {
model.numberOfCells = getNumberOfCells(publicAPI.getData());
}
return model.numberOfCells;
};
publicAPI.getCellSizes = function (recompute) {
if (model.cellSizes !== undefined && !recompute) {
return model.cellSizes;
}
model.cellSizes = extractCellSizes(publicAPI.getData());
return model.cellSizes;
};
/**
* When `resize()` is being used, you then MUST use `insertNextCell()`.
*/
publicAPI.resize = function (requestedNumTuples) {
var oldNumTuples = publicAPI.getNumberOfTuples();
superClass.resize(requestedNumTuples);
var newNumTuples = publicAPI.getNumberOfTuples();
if (newNumTuples < oldNumTuples) {
if (newNumTuples === 0) {
model.numberOfCells = 0;
model.cellSizes = [];
} else {
// We do not know how many cells are left.
// Set to undefined to ensure insertNextCell works correctly.
model.numberOfCells = undefined;
model.cellSizes = undefined;
}
}
};
publicAPI.setData = function (typedArray) {
superClass.setData(typedArray, 1);
model.numberOfCells = undefined;
model.cellSizes = undefined;
};
publicAPI.getCell = function (loc) {
var cellLoc = loc;
var numberOfPoints = model.values[cellLoc++];
return model.values.subarray(cellLoc, cellLoc + numberOfPoints);
};
publicAPI.insertNextCell = function (cellPointIds) {
var cellId = publicAPI.getNumberOfCells();
publicAPI.insertNextTuples([cellPointIds.length].concat(_toConsumableArray(cellPointIds))); // By computing the number of cells earlier, we made sure that numberOfCells is defined
++model.numberOfCells;
if (model.cellSizes != null) {
model.cellSizes.push(cellPointIds.length);
}
return cellId;
};
} // ----------------------------------------------------------------------------
// Object factory
// ----------------------------------------------------------------------------
function defaultValues(initialValues) {
return _objectSpread({
empty: true,
numberOfComponents: 1,
dataType: VtkDataTypes.UNSIGNED_INT
}, initialValues);
} // ----------------------------------------------------------------------------
function extend(publicAPI, model) {
var initialValues = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
vtkDataArray.extend(publicAPI, model, defaultValues(initialValues));
vtkCellArray(publicAPI, model);
} // ----------------------------------------------------------------------------
var newInstance = macro.newInstance(extend, 'vtkCellArray'); // ----------------------------------------------------------------------------
var vtkCellArray$1 = _objectSpread({
newInstance: newInstance,
extend: extend
}, STATIC);
export { STATIC, vtkCellArray$1 as default, extend, newInstance };