Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 | 1x 1x 11x 11x 19x 19x 19x 1x 18x 11x 11x 11x 19x 1x 11x 11x 11x 11x 11x 1x | import CoincidentTopologyHelper from 'vtk.js/Sources/Rendering/Core/Mapper/CoincidentTopologyHelper';
import Constants from 'vtk.js/Sources/Rendering/Core/ImageResliceMapper/Constants';
import macro from 'vtk.js/Sources/macros';
import vtkAbstractImageMapper from 'vtk.js/Sources/Rendering/Core/AbstractImageMapper';
import vtkBoundingBox from 'vtk.js/Sources/Common/DataModel/BoundingBox';
const { SlabTypes } = Constants;
const { staticOffsetAPI, otherStaticMethods } = CoincidentTopologyHelper;
// ----------------------------------------------------------------------------
// vtkImageResliceMapper methods
// ----------------------------------------------------------------------------
function vtkImageResliceMapper(publicAPI, model) {
// Set our className
model.classHierarchy.push('vtkImageResliceMapper');
publicAPI.getBounds = () => {
let bds = [...vtkBoundingBox.INIT_BOUNDS];
const image = publicAPI.getInputData();
if (publicAPI.getSlicePolyData()) {
bds = publicAPI.getSlicePolyData().getBounds();
} else if (image) {
bds = image.getBounds();
if (publicAPI.getSlicePlane()) {
vtkBoundingBox.cutWithPlane(
bds,
publicAPI.getSlicePlane().getOrigin(),
publicAPI.getSlicePlane().getNormal()
);
}
}
return bds;
};
}
// ----------------------------------------------------------------------------
// Object factory
// ----------------------------------------------------------------------------
const DEFAULT_VALUES = {
slabThickness: 0.0,
slabTrapezoidIntegration: 0,
slabType: SlabTypes.MEAN,
slicePlane: null,
slicePolyData: null,
};
// ----------------------------------------------------------------------------
export function extend(publicAPI, model, initialValues = {}) {
Object.assign(model, DEFAULT_VALUES, initialValues);
// Build VTK API
vtkAbstractImageMapper.extend(publicAPI, model, initialValues);
macro.setGet(publicAPI, model, [
'slabThickness',
'slabTrapezoidIntegration',
'slabType',
'slicePlane',
'slicePolyData',
]);
CoincidentTopologyHelper.implementCoincidentTopologyMethods(publicAPI, model);
// Object methods
vtkImageResliceMapper(publicAPI, model);
}
// ----------------------------------------------------------------------------
export const newInstance = macro.newInstance(extend, 'vtkImageResliceMapper');
// ----------------------------------------------------------------------------
export default {
newInstance,
extend,
...staticOffsetAPI,
...otherStaticMethods,
};
|